PrettyBundle

General

Category
Free
Tag
Bundles
License
Apache License, Version 2.0
Registered
Mar 6, 2015
Favorites
4
Link
https://github.com/talenguyen/PrettyBundle
See also
TypedBundle
AutoBundle
AutoBundle
Lyra

Additional

Language
Java
Version
1.0.3 (Jun 8, 2015)
Created
Jan 30, 2015
Updated
Aug 23, 2017 (Retired)
Owner
Nguyen Truong Giang (talenguyen)
Contributors
Ravindra Kumar (ravidsrk)
Nguyen Truong Giang (talenguyen)
The Gitter Badger (gitter-badger)
3
Activity
Badge
Generate
Download
Source code

Status

PrettyBundle

Android library which uses annotation processor to help Android Developer easy to deal with Bundle to communicate between Activity, Fragment and Service.

PrettyBundle is inspired by Dart

Release version 1.0.3 - 06/08/2014

  • Support to support v4 Fragment.

Getting start

Activity

Inject extras in Activity. (Borrow the idea of ButterKnife and Dart).

public class TargetActivity extends Activity {
    @Extra String name;
    @Extra int age;

    @Override public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        PrettyBundle.inject(this); // call to inject the extra.
        // TODO: uses the extras properties
    }
}

To set extras and start the TargetActivity

Intent intent = Activities.createTargetActivityIntent("Giang", 26);
startActivity(intent);

Activities is the utility class which is generated by the library processor.

Activityes.createTargetActivityIntent() is the corresponding method to create new instance of the Intent class which will be used to start the TargetActivity

Fragment

Inject extras in Fragment.

public class TargetFragment extends Fragment {
    @Extra String name;
    @Extra int age;

    @Override public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        PrettyBundle.inject(this); // call to inject the extra.
        // TODO: uses the extras properties
    }
}

Set extras and create an instance of TargetFragment.

TargetFragment targetFragment = Fragments.createTargetFragment("Giang", 26);

Fragments is the utility class which is generated by the library processor.

Fragments.createTargetFragment() is the corresponding method to create new instance of the TargetFragment.

Service

Inject extras in Service.

public class TargetService extends Service {
    @Extra String name;
    @Extra int age;

    @Override public IBinder onBind(Intent intent) {
        return null;
    }

    @Override public int onStartCommand(Intent intent, int flags, int startId) {
        PrettyBundle.inject(this, intent);
        return super.onStartCommand(intent, flags, startId);
    }
}

To set extras and start the TargetService

Intent intent = Services.createTargetServiceIntent("Giang", 26);
startService(intent);

Download

Latest version is 1.0.3

Gradle

compile 'com.github.talenguyen:prettybundle:1.0.3'
compile 'com.github.talenguyen:prettybundleprocessor:1.0.3'

Maven

<dependency>
  <groupId>com.github.talenguyen</groupId>
  <artifactId>prettybundle</artifactId>
  <version>1.0.3</version>
</dependency>

<dependency>
  <groupId>com.github.talenguyen</groupId>
  <artifactId>prettybundleprocessor</artifactId>
  <version>1.0.3</version>
  <optional>true</optional>
</dependency>

JARs

Download latest JARs

License

Copyright 2016 Giang Nguyen

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.