Deprecated: this will be maintained under https://github.com/tikivn/android-template/tree/master/intents
Java Shell
Clone or download
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
app
ci
gradle/wrapper
prettybundle
prettybundleprocessor
.gitignore
.travis.yml
LICENSE
README.md
build.gradle
deploy.gradle
gradle.properties
gradlew
gradlew.bat
settings.gradle

README.md

Status

Join the chat at https://gitter.im/talenguyen/PrettyBundle Build 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.