android design Behavior 初见

来源:互联网 发布:牛元js防水多少钱一桶 编辑:程序博客网 时间:2024/05/21 19:48

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即可

@Overridepublic boolean layoutDependsOn(CoordinatorLayout parent, View child, View dependency) {    return dependency instanceof View;}

3. 以下函数,是当依赖的view变化(位移等)时,child即 CoordinatorLayout下的child view 相应做哪些变化。

@Overridepublic boolean onDependentViewChanged(CoordinatorLayout parent, View child, View dependency) {。。。   
 return true;}


XML布局:

<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>
注意 这里的layout_behavior 引用的整个类名。这里是通过这个类名来反射调用其构造函数生成对应的实例。

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();            }        });    }}
0 0
原创粉丝点击