Sample App:
AppIntro is an Android Library that helps you make a cool intro for your app, like the ones in Google apps.
Watch YouTube video here.
##How to use Add this to your build.gradle:
repositories {
mavenCentral()
}
dependencies {
compile 'com.github.paolorotolo:appintro:3.3.0'
}
Create a new Activity that extends AppIntro:
public class MyIntro extends AppIntro {
// Please DO NOT override onCreate. Use init
@Override
public void init(Bundle savedInstanceState) {
// Add your slide's fragments here
// AppIntro will automatically generate the dots indicator and buttons.
addSlide(first_fragment);
addSlide(second_fragment);
addSlide(third_fragment);
addSlide(fourth_fragment);
// Instead of fragments, you can also use our default slide
// Just set a title, description, background and image. AppIntro will do the rest
addSlide(AppIntroFragment.newInstance(title, description, image, background_colour));
// OPTIONAL METHODS
// Override bar/separator color
setBarColor(Color.parseColor("#3F51B5"));
setSeparatorColor(Color.parseColor("#2196F3"));
// Hide Skip/Done button
showSkipButton(false);
showDoneButton(false);
// Turn vibration on and set intensity
// NOTE: you will probably need to ask VIBRATE permesssion in Manifest
setVibrate(true);
setVibrateIntensity(30);
}
@Override
public void onSkipPressed() {
// Do something when users tap on Skip button.
}
@Override
public void onDonePressed() {
// Do something when users tap on Done button.
}
}
Please, DO NOT override onCreate. Just use init instead
If you want to try new layout (as seen in Google's Photo app), just extend AppIntro2 in your Activity. That's all :)
public class MyIntro extends AppIntro2 {
[...]
}
### Easy implementation of Slide Fragments As you can see, things have changed in AppIntro 3.0.0. Now it's so easy to add new slides to AppIntro.
For example: * Copy the class **SampleSlide** from my [example project](https://github.com/PaoloRotolo/AppIntro/blob/master/example/src/main/java/com/github/paolorotolo/appintroexample/SampleSlide.java). * Add a new slide with ```addSlide(SampleSlide.newInstance(R.layout.your_slide_here));```
There's no need to create one class for fragment anymore. :)
No problem, just use this method and AppIntro will generate a new slide for you.
addSlide(AppIntroFragment.newInstance(title, description, image, background_colour));
AppIntro comes with some pager animations. Choose the one you like and then active it with:
// Put this method in init()
setFadeAnimation();
Available animations:
setFadeAnimation()
setZoomAnimation()
setFlowAnimation()
setSlideOverAnimation()
setDepthAnimation()
If you want to create nice parallax effect or your own custom animation, create your own PageTransformer and call:
// Put this method in init()
setCustomTransformer(transformer);
Click here to see how I did it in the example app.
Android 6.0 introduced a new permissions model for developers. Now all your apps have to request permissions which can be a tetious thing to implement.
However, AppIntro simplifies this down to one single line of code!
// Put this in init()
askForPermissions(new String[]{Manifest.permssion.CAMERA}, 2); // OR
// This will ask for the camera permission AND the contacts permission on the same slide.
// Ensure your slide talks about both so as not to confuse the user.
askForPermissions(new String[]{Manifest.permision.CAMERA, Manifest.permission.READ_CONTACTS}, 2);
NOTE: It is advised that you only put one permission in the String array unless you want the app to ask for multiple perms on the same slide.
ANOTHER NOTE: The intro does not do anything based on the users acceptance or denying of requested permissions. This is intentional and support for this will probably not become available. The reason is that an app should request permissions and, regardless of the user's input, continue flowing along. Someone suggested it would be proper for the intro to stop until permissions were granted. This is annoying and would probably result in the user uninstalling your app. If a permission is not granted, briefly alert the user and continue on. There's no need to lock up the UI simply because they don't want their location shared.
See example code here on Github. You can also see it live. Download this app from Google Play..
Do you need inspiration? A lot of apps are using AppIntro out there:
Planets
Hermes - Material IRC Client
If you are using AppIntro in your app and would like to be listed here, please let us know opening a new issue!
- Numix Hermes;
- Audio Reminder Pro;
- Wizr Daily Quotes;
- Planets;
- Weather Delta;
- PDF Me;
- Circles;
- Task Master;
- Smoothie Recipes;
- SideBar Notes;
- Just food;
- [AlarmSMS] (https://play.google.com/store/apps/details?id=com.qhutch.alarmsms);
- [Aware] (https://play.google.com/store/apps/details?id=com.bunemekyakilika.aware);
- neutriNote;
- Handwriting Note;
- Friends Roulette;
- Karting Tools;
- ChineseDictionary (粵韻漢典離線粵語普通話發聲中文字典);
- Sifter: the Insta of Timehop;