forked from LeddaZ/frameworks_base
2.1 KiB
2.1 KiB
Bouncer
KeyguardBouncer is the component responsible for displaying the security method set by the user (password, PIN, pattern) as well as SIM-related security methods, allowing the user to unlock the device or SIM.
Supported States
- Phone, portrait mode - The default and typically only way to view the bouncer. Screen cannot rotate.
- Phone, landscape - Can only get into this state via lockscreen activities. Launch camera, rotate to landscape, tap lock icon is one example.
- Foldables - Both landscape and portrait are supported. In landscape, the bouncer can appear on either of the hinge and can be dragged to the other side. Also refered to as "OneHandedMode in KeyguardSecurityContainerController
- Tablets - The bouncer is supplemented with user icons and a multi-user switcher, when available.
Components
The bouncer contains a hierarchy of controllers/views to render the user's security method and to manage the authentication attempts.
- KeyguardBouncer - Entrypoint for managing the bouncer visibility.
- KeyguardHostViewController - Intercepts media keys. Can most likely be merged with the next item.
- KeyguardSecurityContainerController - Manages unlock attempt responses, determines the correct security view layout, which may include a user switcher or enable one-handed use.
- KeyguardSecurityViewFlipperController - Based upon the KeyguardSecurityModel#SecurityMode, will instantiate the required view and controller. PIN, Pattern, etc.
- KeyguardSecurityContainerController - Manages unlock attempt responses, determines the correct security view layout, which may include a user switcher or enable one-handed use.
- KeyguardHostViewController - Intercepts media keys. Can most likely be merged with the next item.
Fun fact: Naming comes from the concept of a bouncer at a bar or nightclub, who prevent troublemakers from entering or eject them from the premises.