Skip to content
This repository has been archived by the owner on Mar 23, 2023. It is now read-only.

Latest commit

 

History

History
17 lines (10 loc) · 2.01 KB

screens_as_custom_views.md

File metadata and controls

17 lines (10 loc) · 2.01 KB

Screens as custom Views

Press uses custom Views for designing screens instead of Fragments because Fragments are terrible and Views are great. They offer a simpler, synchronous lifecycle that is easy to use and carry none of the implicit gotchas that Fragments bring.

A single Activity is used for navigating between these Views. The navigation stack is built on top of square/flow and can be seen here.

Graduating from XML

Press uses custom Views are written in Kotlin code with minimal dependency on Xml because of multiple reasons:

1. Runtime themes

Press will have support for multiple themes soon. Unfortunately, changing themes on Android requires an Activity restart they cannot be modified on runtime either because they’re immutable. Forcing the user to restart the app would be terrible so Press keeps everything in code instead. Views listen to changes in themes and update at runtime (example).

2. Contour

The current state of Xml layouts leaves a lot to be desired. Tooling has been bad for a while, the layout preview is good only for basic layouts and achieving dynamic layouts can become very verbose because of the static nature of Xml. Press embraces Kotlin and maths by using Contour for writing layouts. So far it has been a great experience and I’ve barely missed writing layouts in Xml.

The downside of the above two decisions is that Press has to fight the framework because it’s predominantly Xml-first. Want to change the cursor color in a text field at runtime? No way to do it. Press goes to great lengths to find a work-around.