A Preliminary Study on CoordinatorLayout and Behaviors in Android Support Design

A Preliminary Study on CoordinatorLayout and Behaviors in Android Support Design

After the release of Android M Preview, we got a new support library - Android Design Support Library, which is used to implement Google's Material Design and provides a series of controls that meet design standards.

There are many controls, the most complex and powerful one is CoordinatorLayout. As the name suggests, it is a parent view used to organize the collaboration between its child views. CoordinatorLayout can be understood as a FrameLayout by default, and its layout method is stacked layer by layer by default.

Well, the magic of CoordinatorLayout lies in the Behavior object.

Look at the Overview of the CoordinatorLayout.Behavior object

  1. Interaction behavior plugin for child views of CoordinatorLayout.
  2.  
  3. Behavior implements one or more interactions that a user can take on a child view. These interactions may include drags, swipes, flings, or any other gestures.

It can be seen that the Behavior object is used for interaction with the subviews of CoordinatorLayout.

The Behavior interface has many methods. Let's take AppBarLayout as an example. There are two Behaviors in AppBarLayout, one for itself and the other for its sibling nodes. Let's focus on the AppBarLayout.ScrollingViewBehavior class.

Let's look at the following methods in this class

0. dependency

  1. public   boolean layoutDependsOn(CoordinatorLayout parent, View child, View dependency) {
  2. return dependency instanceof AppBarLayout;
  3. }

This method tells CoordinatorLayout that this view depends on AppBarLayout. The father can use this method to find all the sibling nodes that this child depends on.

1. measure

  1. public   boolean onMeasureChild(CoordinatorLayout parent, View child, int parentWidthMeasureSpec, int widthUsed, int parentHeightMeasureSpec, int heightUsed)

This is a method in which CoordinatorLayout uses Behavior objects to measure the size of child views during the measure process.

In this method, we can use the parent.getDependencies(child); method to get the view that the child depends on, and then determine its own size by getting the size of the view that the child depends on.

2. layout

  1. public   boolean onLayoutChild(CoordinatorLayout parent, View child, int layoutDirection)

This method is used by subviews to layout themselves. If they depend on other views, the system will call it first.

public boolean onDependentViewChanged(CoordinatorLayout parent, View child, View dependency)

This method can record some location information of the dependency in this callback, use the saved information to perform calculations in onLayoutChild, and then get its own specific location.

3. Nested scroll

  1.   public   boolean onStartNestedScroll(CoordinatorLayout coordinatorLayout, AppBarLayout child, View directTargetChild, View target, int nestedScrollAxes)
  2.  
  3. public   void onNestedPreScroll(CoordinatorLayout coordinatorLayout, AppBarLayout child, View target, int dx, int dy, int [] consumed)
  4.  
  5. public   void onNestedScroll(CoordinatorLayout coordinatorLayout, AppBarLayout child, View target, int dxConsumed, int dyConsumed, int dxUnconsumed, int dyUnconsumed)
  6.  
  7. public   void onStopNestedScroll(CoordinatorLayout coordinatorLayout, AppBarLayout child, View target)

Do these methods look familiar to you? I have introduced them in the article NestedScrolling in Android. These methods are exactly the methods of NestedScrollingParent, which is a proxy for CoordinatorLayout. That is, CoordinatorLayout does not process these messages by itself, but passes them to the Behavior of the child view for processing. This method is used to achieve interaction and visual coordination (layout, sliding) between views.

Summarize

You can see that CoordinatorLayout implements a layout that can be delegated to child views. This is different from the traditional ViewGroup. Child views now know each other's existence, and changes in one child view can notify another child view. What CoordinatorLayout does is to act as a communication bridge to connect different views. Use Behavior objects for communication.

Our specific implementation can refer to the official Android documentation to tell us the function of each method and rewrite it to achieve the various complex functions we want.

https://developer.android.com/reference/android/support/design/widget/…

With such a mechanism, it is more convenient and quick to realize the interaction between components.

<<:  After failure in India, Google's Android One is set to fail in Africa

>>:  10 Practical but Paranoid Java Programming Techniques

Recommend

Marketing skills of online store promotion software

The most mature project on the Internet is Taobao...

collect! Google Ads Terms That Marketers Must Know

The following common Google Ads terms will help y...

A guide to creating a short video matrix for “Reading Books in Your Palm”!

I believe everyone is familiar with ZhanDuShu , w...

Case practice: How can lottery activities attract users?

Last night, there was a very interesting discussi...

Can Google still make a living if it returns to the Chinese market?

Recently, there is news that Google has made a pr...

Why is Huawei HiSilicon's octa-core processor so awesome?

The day before yesterday, Samsung released the hig...

Let’s talk about 5 aspects: How to do brand cross-border marketing?

Cross-border marketing is the process of combinin...

Unity3d MOBA real-time competitive game development with engineering materials

Course Catalog: ├──MOBA competitive | ├──39_MOBA ...