/android-examples

:shipit: [Examples] Simple basic isolated apps, for budding android devs.

Primary LanguageJavaApache License 2.0Apache-2.0

Image

Featured in

AndroidDev Digest

Show some ❤️ and star the repo to support the project

GitHub stars GitHub forks GitHub watchers GitHub followers
Twitter Follow

Main repository containing all the example apps demonstrating features/functionality/integrations in android application development

NOTE: If you are going to download just a single example app (using the download link), make sure you follow the below procedure

  1. Create a folder android-examples
  2. Next download and add the dependencies.gradle to this android-examples folder
  3. Now move the example app folder inside the android-examples folder

The reason this is required because each single app uses ext variables defined and referenced from dependencies.gradle file from the parent folder namely android-examples.

Example apps

  1. ActivityLifecycle
  2. AnimatedGradientBackground
  3. AudioRecording
  4. AutoCompleteTextview
  5. AutoInitLibrary
  6. BasicMVP
  7. BoundServices
  8. BottomSheet
  9. BottomNavigationView
  10. BroadcastReceiver
  11. BuilderPattern
  12. BuildVariants
  13. CallsAndSMS
  14. CameraX
  15. ChangeThemeDuringRuntime
  16. CheckIfPhoneOrTablet
  17. CheckIfScreenLocked
  18. ChromeCustomTabs
  19. CircularImage
  20. CleanProject
  21. CollapsibleToolbar
  22. CommonConfigForModules
  23. CompileOnly
  24. ComposeTheme
  25. CustomBroadcastPermissions
  26. CustomOnboardingIntro
  27. CustomView
  28. DataBinding
  29. DebuggingWebViews
  30. DepsManagementViaBuildSrc
  31. Encryption
  32. ExtractingColorFromBitmap
  33. FingerprintAPI
  34. Firebase
  35. FirebaseCloudMessaging
  36. GCMNetworkManager
  37. GPSLocation
  38. GestureDetection
  39. GitVersioning
  40. GridView
  41. HeadlessFragment
  42. ImplementingEmoticons
  43. IntentService
  44. Intents
  45. InterProcessService
  46. JNI
  47. JUnitTests
  48. LifeCycleCompForLib
  49. ListView
  50. ListViewWithCustomAdapter
  51. LoadHtmlIntoWebview
  52. LocalBroadcastManager
  53. MobileVisionAPI2ReadBarCodes
  54. ModulesUnderSubdirectory
  55. NavigationDrawer
  56. NestedModules
  57. Notification
  58. OSSLicenseActivity
  59. ParallaxHeaderListview
  60. PopupMenu
  61. ProductFlavors
  62. QuickSettingsTile
  63. RadioButton
  64. RatingBar
  65. ReadJSONFile
  66. RecyclerView
  67. RuntimePermissions
  68. SQLite
  69. SearchView
  70. SearchViewInToolbar
  71. Service
  72. SharedElementTransitions
  73. SimulateClick
  74. SnackBar
  75. SnapHelper
  76. SpeechRecognition
  77. SplashScreen
  78. SplitSigninConfig
  79. TabLayout
  80. TextToSpeech
  81. TranslucentStatusBar
  82. UnitTestingWithRoboelectric
  83. UsingAppintro
  84. UsingArcMenu
  85. UsingBottomNavigationBar
  86. UsingButterKnife
  87. UsingDBFlow
  88. UsingDagger2
  89. UsingEasyGCMlib
  90. UsingFragmentsForResponsiveLayout
  91. UsingFirebaseJobDispatcher
  92. UsingFontAwesomeLib
  93. UsingKotlin
  94. UsingLitho
  95. UsingMPChartsLib
  96. UsingOpenNLP
  97. UsingParceler
  98. UsingParcelize
  99. UsingPercentSupportLib
  100. UsingPocketSphinxForVoiceRecognition
  101. UsingRetrofit2
  102. UsingRobolectric
  103. UsingRoomORM
  104. UsingRxJava
  105. UsingRxJava2
  106. UsingStetho
  107. UsingSugarORM
  108. UsingTimberLogger
  109. UsingAltBeaconLib
  110. VectorDrawables
  111. ViewPager
  112. WebViewDialogueBox

Example apps from my android libraries

  1. UsingEasyDeviceInfo
  2. UsingSensey
  3. UsingRecyclerViewHelper
  4. UsingScreenshott
  5. UsingStackedHorizontalProgressbar
  6. UsingQREader
  7. UsingPackageHunter
  8. UsingAndroidUtils
  9. UsingZentone
  10. UsingOptimusHTTP
  11. UsingShoutout

Pull Requests

I welcome and encourage all pull requests. It usually will take me within 24-48 hours to respond to any issue or request. Here are some basic rules to follow to ensure timely addition of your request:

  1. Match coding style (braces, spacing, etc.) This is best achieved using Reformat Code feature of Android Studio CMD+Option+L on Mac and CTRL + ALT + L on Linux + Windows .

  2. If its a feature, bugfix, or anything please only change code to what you specify.

  3. Please keep PR titles easy to read and descriptive of changes, this will make them easier to merge :)

  4. Pull requests must be made against develop branch. Any other branch (unless specified by the maintainers) will get rejected.

  5. Check for existing issues first, before filing an issue.

  6. Make sure you follow the set standard as all other projects in this repo do

    • Upgrade your gradle wrapper to the one all other apps are using. Use the below command at root of your project

      ./gradlew wrapper --gradle-version <version_name>
      

      i.e ./gradlew wrapper --gradle-version 6.0.1

    • Use ext variables as defined in dependencies.gradle, in your build.gradle files to make sure all apps are in sync with configurations and dependencies. Take a look here and here

    • Use the package name of the format github.nisrulz.* where * is the example you are adding to the repo. I am trying to follow a set standard in the repo, please adhere to that.

  7. Have fun!

NOTE: There is a quick bootstrapping cookiecutter template to create an Android example project that adheres to all wiring up and standards for this repo. Read how to use use it from links below:

Extra

Since the repo is pretty large now , I am sure many folks would like to download only some of the projects. To tackle that follow the steps below:

  • Install svn using homebrew (mac/linux)

    brew install svn
  • Copy the name of the example folder in this repo i.e AccessingGoogleDrive

  • Next replace example_folder in the below command:

    svn checkout https://github.com/nisrulz/android-examples/trunk/example_folder

    i.e Consider AccessingGoogleDrive is the name of the example's folder, the command becomes:

    svn checkout https://github.com/nisrulz/android-examples/trunk/AccessingGoogleDrive
  • Done! You should have the specific example all checked out!

Author & support

This project was created by Nishant Srivastava but hopefully developed and maintained by many others. See the the list of contributors here.

If you appreciate my work, consider buying me a cup of ☕ to keep me recharged 🤘 [PayPal]

License

Apache Version 2.0 | Copyright 2016 Nishant Srivastava