Slide 1

Slide 1 text

Androidify Yourself!

Slide 2

Slide 2 text

Alexey Buzdin Aleksey Nikolaenko @AlexeyBuzdin @echoAlexey

Slide 3

Slide 3 text

Google Developers Group • Place to discuss, learn, and share passion for technology • Focused on developer culture & technical content • Free as beer

Slide 4

Slide 4 text

No content

Slide 5

Slide 5 text

Today’s agenda • Setup environment • Introduction to Android • Android application development • GDG Raffle http://goo.gl/HIYmeC

Slide 6

Slide 6 text

Android Studio • IntelliJ IDEA based • Gradle build support • Comes with Android SDK • Layout editor with preview and much more…

Slide 7

Slide 7 text

Android platform • Android is a Linux-based operating system and a software stack designed for touchscreen mobile devices

Slide 8

Slide 8 text

Android Anatomy

Slide 9

Slide 9 text

Android Runtime • On Android you develop in Java • ... but Android does not run Java Bytecode !

Slide 10

Slide 10 text

Android Runtime • Custom Virtual Machine. Why? Constraints Designed for 64M RAM No swap Phone tech v. Desktop CPU specific Oracle JVM problems Memory Hog Slow startup IP licensing restrictions

Slide 11

Slide 11 text

Anatomy of Android application • AndroidManifest • Activities • Fragments • Intents • Services • Content providers • Broadcast receivers

Slide 12

Slide 12 text

Android Manifest • general configuration for your application • contains all component definitions of your appication

Slide 13

Slide 13 text

Activity • An activity represents a single screen with a user interface • An activity is implemented as a subclass of Activity

Slide 14

Slide 14 text

Fragment • A Fragment represents a behavior or a portion of user interface in an Activity • Affected by lifecycle of Activity • subclass of Fragment

Slide 15

Slide 15 text

Intent Intent is used to invoke different components: • Start a service • Launch an activity • Display a web page • Broadcast a message

Slide 16

Slide 16 text

Service • Background process that performs long- running operations or remote processes • No user interface for service • A service is implemented as a subclass of Service • Service can be local (accessed within application) or remote (scope of device)

Slide 17

Slide 17 text

Content providers • Content providers are used to share data between applications • Can store data in SQLite, Web and other storages and perform CRUD operations with Content providers • subclass of ContentProvider

Slide 18

Slide 18 text

Broadcast receiver • Component that responds to system-wide broadcast announcements (e.g.. Screen is turns on-off, SMS received, • Broadcast delivered as Intent • Don’t have user interface • Subclass of BroadcastReceiver

Slide 19

Slide 19 text

Android UI fundamentals

Slide 20

Slide 20 text

Android UI fundamentals Screen size • actual physical size, measured as the screen's diagonal • 2.55”, 3.2”, 4.0”, 10.1”, ... Android groups into four generalized sizes: • Small • Normal • Large • Xlarge

Slide 21

Slide 21 text

Android UI fundamentals Screen density • quantity of pixels within a physical area of the screen (dots per inch, dpi). • "low" density screen has fewer pixels • Android groups actual screen densities into four generalized densities: • Low (ldpi, 120) • Medium (mdpi, 160) • High (hdpi, 240) • Extra high (xhdpi, 320)

Slide 22

Slide 22 text

Android UI fundamentals Density-independent pixel (dp) • virtual pixel unit to express layout dimensions or position in a density-independent way • equivalent to one physical pixel on a 160 dpi screen • px = dp * (dpi / 160) • system transparently handles any scaling of the dp units

Slide 23

Slide 23 text

Android UI fundamentals Best practices • Do not use hard-coded pixel values in your application code • Use size and density-specific resources • Use wrap_content, match_parent, or the dp unit for layout dimensions • Test Your Application on Multiple Screens

Slide 24

Slide 24 text

Android resources

Slide 25

Slide 25 text

Resources Android supports the externalization of resources • strings, colors, images, themes, menus, layouts • system resources Why? • easier to maintain, update, and manage • easier to define alternative resource values for internationalization and to support variations in hardware

Slide 26

Slide 26 text

res/ & R res/ • Generated by ADT Wizard • Each resource type is stored in a different subfolder R.java • Resources from /res are „indexed“ by ADT or aapt tool • Enables to reference resources in code

Slide 27

Slide 27 text

Default v. Alternative Resources • For any type of resource, we can specify default and multiple alternative resources • Default resources are used regardless of the device configuration when no alternative resources match the current configuration • Alternative resources are designed for use with a specific configuration

Slide 28

Slide 28 text

How to specify Alternative Resources • Create a new directory in res/ • res/- • specifies a configuration for which these resources are to be used • Save your alternative resources in new directory and name it as the default resource files

Slide 29

Slide 29 text

Resource types • Layouts • Simple values – Strings – Plurals – Colors – Dimensions – Styles – String or integer arrays Stored within XML files in the res/values folder

Slide 30

Slide 30 text

Resource types Styles and Themes • Let your applications maintain a consistent look and feel by enabling you to specify the attribute values used by Views • The most common use of is to store the colors and fonts for an application

Slide 31

Slide 31 text

Building User Interfaces

Slide 32

Slide 32 text

View View • base class for all visual interface elements controls, widgets • an object that draws something on the screen that the user can interact with View Group • extends View class • an object that holds other Views View group is an invisible container that organizes child views, while the child views draw some part of the UI

Slide 33

Slide 33 text

Android Layouts • A layout defines the visual structure for a user interface, such as the UI for an activity or app widget. • Can be defined in XML or programmatically during runtime. • XML layouts stored in res/layout folder and are qualified as resource

Slide 34

Slide 34 text

Layout Advantages of declaring UI in XML • Separation of the presentation from the code that controls its behavior • modify UI without having to modify source code • create XML layouts for different screen orientations, different device screen sizes, and different languages • Easier to visualize the structure of your UI • Easier to design/debug UI • Visualizer tool (ADT)

Slide 35

Slide 35 text

Layout example ViewGroup View

Slide 36

Slide 36 text

Layout types LinearLayout • Aligns all children in a single direction - vertically or horizontally • All children are stacked one after the other • Layout weight (android: layout_weight) assigns an "importance" value to a view in terms of how much space is should occupy on the screen

Slide 37

Slide 37 text

LinearLayout

Slide 38

Slide 38 text

Layout types RelativeLayout • view group that displays child views in relative positions • can eliminate nested view groups and keep your layout hierarchy flat, that improves performance • specify the location of child objects relative to each other (child A to the left of child B) or to the parent

Slide 39

Slide 39 text

Layout Parameters Layout Parameters (layout_something) • parent view group defines layout parameters for each child view (including the child view group) • child element must define LayoutParams that are appropriate for its parent

Slide 40

Slide 40 text

Basic widget toolbox

Slide 41

Slide 41 text

Questions & Answers

Slide 42

Slide 42 text

Want to host a workshop or presentation? gdgriga@gmail.com

Slide 43

Slide 43 text

No content