SlideShare a Scribd company logo
Android Jetpack Compose
A modern toolkit for building native UI
From: Ajinkya Saswade
What is Jetpack Compose?
Android’s modern toolkit for building native UI
Jetpack compose accelerates UI development on Android with less
code, powerful tools and intuitive Kotlin APIs.
Note : Jetpack Compose is currently in Developer preview and not ready for production.
Inspired by
● React
● Litho
● Vue.js
● Flutter
...but it’s written completely in Kotlin and is fully compatible with the
existing Android view system
Why are they building it?
When we have existing UI toolkit.
“API design is building future regret”
- Chet Hase
Move android.widget to a support library Jetpack
API regret
View.java
API regret
Button
And the list goes on with Fragment and other stuff.
What is Compose?
● New set of Jetpack UI widgets
● A Kotlin compiler plugin
● Fully compatible with your existing app/code.
(Both Java or Kotlin).
In compose “Everything is a function”
What goals are achieve?
● Simplify
● Less code
● Fix what’s broken.
Building with Compose
Adding into Existing Project -
Gradle Configuration
Adding into Existing Project - Gradle Configuration
Jetpack Compose Basics
Define a composable function
Preview function
Layouts
Layouts
Components (Functions)
Layouts
● Column
● Row
● Flex (Column / Row)
● ConstraintLayout (in process)
Built-in Components
● Button
● Checkbox
● Drawers
● AppBars
Custom View
● Draw
● Layout
What problem does Compose solve?
Separation of Concerns
Coupling
VS
Cohesion
Separation of Concerns
Framing into more familiar way
There is lot of depency hidden here.
There is lot of coupling between the ViewModel & layout.xml
Separation of Concerns
Now because we’re in the same language some of the dependencies might start to become more explicit.
After doing some refactoring some of the coupling is reduce and cohesion is increased
There’s actually a forced line of separation
State Management Over Time
● Observability is required
● Compose adds @Model classes
● @Model allows cross-cutting observation
● We can still use LiveData, Rx, etc.
One of the concerns of the UI developer is solved i.e How your UI changes over the time
Data Flow
Eg.
Eg.
Eg.
Eg.
Compose Architecture
Compose UI Core
Compose UI Foundation
Compose UI Material
Compatibility
Declarative VS Imperative
Imperative way
Declarative way
How does it work?
Compose works on Gap Buffer data structure
Gap Buffer
Gap Buffer
Jetpack Compose
Questions?
Learn more about Jetpack Compose
Jetpack Compose
Android Compose Tutorial
Codelabs
Using Jetpack Compose to build UI in Android
Exploring Jetpack Compose: Text
Jetpack Compose
Thank You!
about.me/ajinkyasaswade

More Related Content

What's hot (20)

PDF
Try Jetpack Compose
LutasLin
 
PPTX
Jetpack Compose - Android’s modern toolkit for building native UI
Gilang Ramadhan
 
PDF
Jetpack compose
LutasLin
 
PPTX
Kotlin Jetpack Tutorial
Simplilearn
 
PDF
Compose Camp - Jetpack Compose for Android Developers Introduction Session De...
JassGroup TICS
 
PDF
Jetpack Compose.pdf
SumirVats
 
PPTX
Kotlin Multiplatform
Kevin Galligan
 
PDF
Understanding react hooks
Samundra khatri
 
PDF
Jetpack Compose - A Lightning Tour
Matthew Clarke
 
PPSX
Kotlin Language powerpoint show file
Saurabh Tripathi
 
PDF
Android Jetpack
Tudor Sirbu
 
PPTX
React workshop
Imran Sayed
 
PPTX
Introduction to react_js
MicroPyramid .
 
PPTX
Kotlin InDepth Tutorial for beginners 2022
Simplilearn
 
PDF
A quick and fast intro to Kotlin
XPeppers
 
PDF
Android Development with Kotlin, Part 1 - Introduction
Andreas Jakl
 
PPTX
Intro to React
Justin Reock
 
PPTX
Kotlin presentation
MobileAcademy
 
PPTX
Angular interview questions
Goa App
 
Try Jetpack Compose
LutasLin
 
Jetpack Compose - Android’s modern toolkit for building native UI
Gilang Ramadhan
 
Jetpack compose
LutasLin
 
Kotlin Jetpack Tutorial
Simplilearn
 
Compose Camp - Jetpack Compose for Android Developers Introduction Session De...
JassGroup TICS
 
Jetpack Compose.pdf
SumirVats
 
Kotlin Multiplatform
Kevin Galligan
 
Understanding react hooks
Samundra khatri
 
Jetpack Compose - A Lightning Tour
Matthew Clarke
 
Kotlin Language powerpoint show file
Saurabh Tripathi
 
Android Jetpack
Tudor Sirbu
 
React workshop
Imran Sayed
 
Introduction to react_js
MicroPyramid .
 
Kotlin InDepth Tutorial for beginners 2022
Simplilearn
 
A quick and fast intro to Kotlin
XPeppers
 
Android Development with Kotlin, Part 1 - Introduction
Andreas Jakl
 
Intro to React
Justin Reock
 
Kotlin presentation
MobileAcademy
 
Angular interview questions
Goa App
 

Similar to Android jetpack compose | Declarative UI (20)

PDF
Mobile Programming - 2 Jetpack Compose
AndiNurkholis1
 
PDF
Andriod Blueprint @ AISSMS Institute Of Information Techonology
tecopo6080
 
PPTX
Compose UI
Ulvi Jabbarli
 
PPTX
Modern app development with Jetpack Compose.pptx
Md Shamsul Arafin Mahtab
 
PDF
Compose Camp Day 3 PPT.pptx.pdf
METDSC
 
PDF
Introduction to compose camps.pdf
AnkurAgarwal151093
 
PDF
Mobile Programming - 6 Textfields, Button, Showing Snackbars and Lists
AndiNurkholis1
 
PPTX
Compose in Theory
Garth Gilmour
 
PDF
Jetpack joyride!
Tony Kazanjian
 
PDF
compose_speaker_session.pdf
AnkurAgarwal151093
 
PPTX
Jetpack compose session1 (1).pptx
ShubhamJogdand8
 
PDF
Android info session
GDSC
 
PDF
Compose Camp 1.pdf
AbhishekS325285
 
PPTX
Compose Camp ppt.pptx
GoogleDevelopersClub
 
PDF
Compose Camp Day 4 PPT.pptx.pdf
METDSC
 
PDF
Compose Camp 1.pdf
AbhishekS325285
 
PPTX
Compose camp 2.pptx
MadheswarKonidela
 
PDF
What's new in android: jetpack compose 2024
Toru Wonyoung Choi
 
PPTX
Compose In Practice
Kelvin Harron
 
PPTX
compose 3.pptx
SumirVats
 
Mobile Programming - 2 Jetpack Compose
AndiNurkholis1
 
Andriod Blueprint @ AISSMS Institute Of Information Techonology
tecopo6080
 
Compose UI
Ulvi Jabbarli
 
Modern app development with Jetpack Compose.pptx
Md Shamsul Arafin Mahtab
 
Compose Camp Day 3 PPT.pptx.pdf
METDSC
 
Introduction to compose camps.pdf
AnkurAgarwal151093
 
Mobile Programming - 6 Textfields, Button, Showing Snackbars and Lists
AndiNurkholis1
 
Compose in Theory
Garth Gilmour
 
Jetpack joyride!
Tony Kazanjian
 
compose_speaker_session.pdf
AnkurAgarwal151093
 
Jetpack compose session1 (1).pptx
ShubhamJogdand8
 
Android info session
GDSC
 
Compose Camp 1.pdf
AbhishekS325285
 
Compose Camp ppt.pptx
GoogleDevelopersClub
 
Compose Camp Day 4 PPT.pptx.pdf
METDSC
 
Compose Camp 1.pdf
AbhishekS325285
 
Compose camp 2.pptx
MadheswarKonidela
 
What's new in android: jetpack compose 2024
Toru Wonyoung Choi
 
Compose In Practice
Kelvin Harron
 
compose 3.pptx
SumirVats
 
Ad

Recently uploaded (20)

PDF
Powering GIS with FME and VertiGIS - Peak of Data & AI 2025
Safe Software
 
PDF
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pdf
Varsha Nayak
 
PPTX
Agentic Automation Journey Session 1/5: Context Grounding and Autopilot for E...
klpathrudu
 
PDF
MiniTool Partition Wizard 12.8 Crack License Key LATEST
hashhshs786
 
PPTX
An Introduction to ZAP by Checkmarx - Official Version
Simon Bennetts
 
PDF
Salesforce CRM Services.VALiNTRY360
VALiNTRY360
 
PDF
Alarm in Android-Scheduling Timed Tasks Using AlarmManager in Android.pdf
Nabin Dhakal
 
PPTX
Feb 2021 Cohesity first pitch presentation.pptx
enginsayin1
 
PPTX
Fundamentals_of_Microservices_Architecture.pptx
MuhammadUzair504018
 
PDF
vMix Pro 28.0.0.42 Download vMix Registration key Bundle
kulindacore
 
PDF
Mobile CMMS Solutions Empowering the Frontline Workforce
CryotosCMMSSoftware
 
PDF
Understanding the Need for Systemic Change in Open Source Through Intersectio...
Imma Valls Bernaus
 
PPTX
Platform for Enterprise Solution - Java EE5
abhishekoza1981
 
PDF
Capcut Pro Crack For PC Latest Version {Fully Unlocked} 2025
hashhshs786
 
PDF
GetOnCRM Speeds Up Agentforce 3 Deployment for Enterprise AI Wins.pdf
GetOnCRM Solutions
 
PDF
Build It, Buy It, or Already Got It? Make Smarter Martech Decisions
bbedford2
 
PPTX
How Apagen Empowered an EPC Company with Engineering ERP Software
SatishKumar2651
 
PDF
Digger Solo: Semantic search and maps for your local files
seanpedersen96
 
PPT
MergeSortfbsjbjsfk sdfik k
RafishaikIT02044
 
PPTX
Engineering the Java Web Application (MVC)
abhishekoza1981
 
Powering GIS with FME and VertiGIS - Peak of Data & AI 2025
Safe Software
 
Why Businesses Are Switching to Open Source Alternatives to Crystal Reports.pdf
Varsha Nayak
 
Agentic Automation Journey Session 1/5: Context Grounding and Autopilot for E...
klpathrudu
 
MiniTool Partition Wizard 12.8 Crack License Key LATEST
hashhshs786
 
An Introduction to ZAP by Checkmarx - Official Version
Simon Bennetts
 
Salesforce CRM Services.VALiNTRY360
VALiNTRY360
 
Alarm in Android-Scheduling Timed Tasks Using AlarmManager in Android.pdf
Nabin Dhakal
 
Feb 2021 Cohesity first pitch presentation.pptx
enginsayin1
 
Fundamentals_of_Microservices_Architecture.pptx
MuhammadUzair504018
 
vMix Pro 28.0.0.42 Download vMix Registration key Bundle
kulindacore
 
Mobile CMMS Solutions Empowering the Frontline Workforce
CryotosCMMSSoftware
 
Understanding the Need for Systemic Change in Open Source Through Intersectio...
Imma Valls Bernaus
 
Platform for Enterprise Solution - Java EE5
abhishekoza1981
 
Capcut Pro Crack For PC Latest Version {Fully Unlocked} 2025
hashhshs786
 
GetOnCRM Speeds Up Agentforce 3 Deployment for Enterprise AI Wins.pdf
GetOnCRM Solutions
 
Build It, Buy It, or Already Got It? Make Smarter Martech Decisions
bbedford2
 
How Apagen Empowered an EPC Company with Engineering ERP Software
SatishKumar2651
 
Digger Solo: Semantic search and maps for your local files
seanpedersen96
 
MergeSortfbsjbjsfk sdfik k
RafishaikIT02044
 
Engineering the Java Web Application (MVC)
abhishekoza1981
 
Ad

Android jetpack compose | Declarative UI