ym—— Android 5.0学习之Tinting和Clipping

最后更新于:2022-04-01 09:35:01

**转载请注明本文出自Cym的博客([http://blog.csdn.net/cym492224103](http://blog.csdn.net/cym492224103)****),谢谢支持!** ** ** 前言 Android 5.0的知识点讲完,下一篇要给大家带来一个综合例子的Demo,以及谈谈我对Android 5.0的看法。 有人肯定会想为什么不是每一篇博文带一个demo,我觉得无论学习什么东西都需要自己去实践,所以我没有提供Demo,想先让大家自己去按照我写的博文步骤去实现这个,在实现的过程中会遇到困难,然后自己去查找解决方案,最后自己做出来,这样学习到的东西才能让我们印象深刻。 Drawable Tinting(着色) 设置 ImageView 的 android:tint 属性,可以达到以下效果: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-23_56cc074085123.jpg) layout: ~~~ <ImageView android:layout_width="100dp" android:layout_height="100dp" android:elevation="1dip" android:layout_gravity="center" android:src="@drawable/ic_launcher" /> <ImageView android:layout_width="100dp" android:layout_height="100dp" android:elevation="1dip" android:layout_gravity="center" android:src="@drawable/ic_launcher" android:tint="@android:color/holo_red_dark" /> ~~~ 不仅可以设置tint还可以设置tintMode,分别设置不同的mode效果如下: srceen ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-23_56cc07409712e.jpg) multiply ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-23_56cc0740b69ce.jpg) add ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-23_56cc0740c9e1b.jpg) src_atop/src_in/src_over ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-23_56cc0740d8f88.jpg) Clipping Views(裁剪视图) 首先我们layout,设置两个正方形的TextView ~~~ <TextView android:id="@+id/tv_1" android:layout_width="100dp" android:layout_height="100dp" android:elevation="1dip" android:layout_gravity="center" /> <TextView android:id="@+id/tv_2" android:layout_width="100dp" android:layout_height="100dp" android:elevation="1dip" android:layout_gravity="center" /> ~~~ 然后我们将它们两分别裁剪成圆角正方形和圆形: ~~~ <span style="white-space:pre"> </span>v1 = findViewById(R.id.tv_1); v2 = findViewById(R.id.tv_2); ViewOutlineProvider viewOutlineProvider = new ViewOutlineProvider() { @Override public void getOutline(View view, Outline outline) { outline.setRoundRect(0, 0, view.getWidth(), view.getHeight(), 10); } }; ViewOutlineProvider viewOutlineProvider1 = new ViewOutlineProvider() { @Override public void getOutline(View view, Outline outline) { outline.setRoundRect(0, 0, view.getWidth(), view.getHeight(), view.getHeight() / 2); } }; v1.setOutlineProvider(viewOutlineProvider); v2.setOutlineProvider(viewOutlineProvider1); ~~~ 效果如下: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-02-23_56cc0740ebe6f.jpg)
';