1. 先上图
2. 引言
在android design 库中,增添了许多的控件,如前文转载的文章Android Design Support Library的代码实验 。该库中CoordinatorLayout是其中比较强大的类,承担协调View的责任。如一个view的滚动,相应的另一个view做对应处理。其强大处理能力得益于其内部类Behavior。传统实现两个view之间的联动,需要在处理一个收到事件view传递相应的事件。这里Behavior内部进行了事件的拦截处理,只需要简单的实现如下文所述方法就可以达到效果。
3. 实例
本文实现一个view跟随另一个view做移动动画。
public class DependentBehavior extends CoordinatorLayout.Behavior<View> {
public DependentBehavior(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
public boolean layoutDependsOn(CoordinatorLayout parent, View child, View dependency) {
return dependency instanceof View;
}
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
@Override
public boolean onDependentViewChanged(CoordinatorLayout parent, View child, View dependency) {
child.setY(dependency.getY() + dependency.getHeight());
return true;
}
}
需要做一下说明:
1. 两个参数构造函数不可少。 (在xml中需要反射调用)
2. 首先我们要知道依赖谁(view),依赖的那个返回true即可
@Override public boolean layoutDependsOn(CoordinatorLayout parent, View child, View dependency) { return dependency instanceof View; }
3. 以下函数,是当依赖的view变化(位移等)时,child即 CoordinatorLayout下的child view 相应做哪些变化。
@Override public boolean onDependentViewChanged(CoordinatorLayout parent, View child, View dependency) { 。。。
return true;
}
XML布局:
注意 这里的layout_behavior 引用的整个类名。这里是通过这个类名来反射调用其构造函数生成对应的实例。<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="10dp" android:orientation="vertical" tools:context=".MainActivity"> <View android:id="@+id/first" android:layout_width="match_parent" android:layout_height="128dp" android:background="@android:color/holo_blue_light" tools:ignore="NewApi"/> <View android:id="@+id/second" android:layout_width="match_parent" android:layout_height="128dp" android:background="@android:color/holo_green_light" app:layout_behavior="com.example.gzlanhengwu.behaviordemo.DependentBehavior" tools:ignore="NewApi"/> </android.support.design.widget.CoordinatorLayout>
4 使用
public class MainActivity extends AppCompatActivity {
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final View view = findViewById(R.id.first);
final ObjectAnimator objectAnimator = new ObjectAnimator().ofFloat(view, "translationY", 0f, 200f);
objectAnimator.setDuration(1000);
view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
objectAnimator.start();
}
});
}
}