Android 5.X新特性详解(二)

Tinting 和 Clipping

Android 5.X在对图像的操作上有了更多的功能,下面来看看 Android 5.X 的两个对操作图像的新功能 —-Tinting(着色)和 Clipping(裁剪)。

  • Tinting(着色)
    Tinting 的使用非常简单,只要在XML中配置好tint和tintMode 就可以了,对于配置的组合效果,只需要大家实际操作一下,就能非常清楚的理解处理效果了。在下面的代码中,设置了不同的tint 和 tintMode来演示Tinting效果,代码如下所示:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:layout_width="match_parent"
              android:layout_height="match_parent"
    android:orientation="vertical">


    <ImageView
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:elevation="5dip"
        android:layout_gravity="center"
        android:src="@mipmap/ic_launcher"/>

    <ImageView
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:elevation="5dip"
        android:layout_gravity="center"
        android:src="@mipmap/ic_launcher"
        android:tint="@android:color/holo_blue_bright"/>

    <ImageView
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:elevation="5dip"
        android:layout_gravity="center"
        android:src="@mipmap/ic_launcher"
        android:tintMode="add"
        android:tint="@android:color/holo_blue_bright"/>

    <ImageView
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:elevation="5dip"
        android:layout_gravity="center"
        android:src="@mipmap/ic_launcher"
        android:tintMode="multiply"
        android:tint="@android:color/holo_blue_bright"/>

</LinearLayout>

效果如下图:
这里写图片描述
Tint 通过修改图像的 Alpha 遮罩来修改图像的颜色,从而达到重新着色的目的。

  • Clipping (裁剪)
    Clipping可以让我们改变一个视图的外形,要使用 Clipping,首先需要使用 ViewOutlineProvider 来修改 outline,然后在通过 setOutlineProvider 将outline作用给视图。
    在下面这个实例中,将一个正方形的TextView 通过 Clipping 裁剪成了一个圆角正方形和一个圆,以此来帮助大家理解Clipping 的使用思路,代码如下所示:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:layout_width="match_parent"
              android:layout_height="match_parent"
    android:orientation="vertical">

    <TextView
        android:id="@+id/tv_rect"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_marginTop="20dp"
        android:elevation="1dip"
        android:layout_gravity="center"
        android:gravity="center"
        android:text="Rect"/>

    <TextView
        android:id="@+id/tv_circle"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:elevation="1dip"
        android:layout_gravity="center"
        android:gravity="center"
        android:text="Circle"/>

</LinearLayout>

程序代码如下所示:

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        //setContentView(R.layout.layout2);
        setContentView(R.layout.layout3);

        View v1 = findViewById(R.id.tv_rect);
        View v2 = findViewById(R.id.tv_circle);

        //获取Outline
        ViewOutlineProvider viewOutlineProvider1 = new ViewOutlineProvider() {
            @Override
            public void getOutline(View view, Outline outline) {
                //修改outline 为特定形状
                outline.setRoundRect(0,0,view.getWidth(),view.getHeight(),30);
            }
        };

        //获取Outline
        ViewOutlineProvider viewOutlineProvider2 = new ViewOutlineProvider() {
            @Override
            public void getOutline(View view, Outline outline) {
               outline.setOval(0,0,view.getWidth(),view.getHeight());
            }
        };
        //重新设置形状
        v1.setOutlineProvider(viewOutlineProvider1);
        v2.setOutlineProvider(viewOutlineProvider2);
    }

效果如下:
Clipping 效果

文章出自 《Android 群英传

猜你喜欢

转载自blog.csdn.net/zhu522959034/article/details/82019159