本文主要是介绍Android使用Vector进行适配和瘦身,2021Android常见面试题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
app:layout_heightPercent=“50%”
app:layout_widthPercent=“100%”
app:srcCompat="@drawable/ic_icon_one" />
在代码中设置:
mImageview.setImageResource(R.drawable.ic_icon_one);
在TextView中使用:
因此Textview(包括Butten等控件)中使用Vector只能使用代码设置:
mTextview = (TextView) findViewById(R.id.textview);
mTextview.setBackgroundResource(R.drawable.ic_icon_one);
Vector在布局选择器中的使用
- 首先构建两个Vector
vector1.xml
<vector xmlns
:android=“http://schemas.android.com/apk/res/android”
android:width=“24dp”
android:height=“24dp”
android:viewportHeight=“24.0”
android:viewportWidth=“24.0”>
<path
android:fillColor="#FF000000"
android:pathData=“M14.59,8L12,10.59 9.41,8 8,9.41 10.59,12 8,14.59 9.41,16 12,13.41 14.59,16 16,14.59 13.41,12 16,9.41 14.59,8zM12,2C6.47,2 2,6.47 2,12s4.47,10 10,10 10,-4.47 10,-10S17.53,2 12,2zM12,20c-4.41,0 -8,-3.59 -8,-8s3.59,-8 8,-8 8,3.59 8,8 -3.59,8 -8,8z” />
vector2.xml
<vector xmlns:android=“http://schemas.android.com/apk/res/android”
android:width=“24dp”
android:height=“24dp”
android:viewportHeight=“24.0”
android:viewportWidth=“24.0”>
<path
android:fillColor="#fa0303"
android:pathData=“M14.59,8L12,10.59 9.41,8 8,9.41 10.59,12 8,14.59 9.41,16 12,13.41 14.59,16 16,14.59 13.41,12 16,9.41 14.59,8zM12,2C6.47,2 2,6.47 2,12s4.47,10 10,10 10,-4.47 10,-10S17.53,2 12,2zM12,20c-4.41,0 -8,-3.59 -8,-8s3.59,-8 8,-8 8,3.59 8,8 -3.59,8 -8,8z” />
- 创建选择器
selector.xml
<?xml version="1.0" encoding="utf-8"?>- 使用选择器
<android.support.percent.PercentFrameLayout xmlns:android=“http://schemas.android.com/apk/res/android”
xmlns:tools=“http://schemas.android.com/tools”
android:layout_width=“match_parent”
android:layout_height=“match_parent”
tools:context=“tsou.com.simple.mytestdemo.SVGButtenActivity”>
<Button
android:id="@+id/butten"
android:layout_width=“100dp”
android:layout_height=“100dp”
android:layout_gravity=“center”
android:background="@drawable/selector" />
<RadioButton
android:layout_width=“wrap_content”
android:layout_height=“wrap_content”
android:layout_margin=“10dp”
android:button="@drawable/selector"
android:text=“我是RadioButton” />
</android.support.percent.PercentFrameLayout>
动态Vector(使用Vector实现动画)
- 使用Vector构建动画内容
<vector xmlns:android=“http://schemas.android.com/apk/res/android”
android:width=“120dp”
android:height=“120dp”
android:viewportHeight=“24.0”
android:viewportWidth=“24.0”>
<path
android:fillColor="#FF000000"
android:pathData=“M9.01,14L2,14v2h7.01v3L13,15l-3.99,-4v3”/>
<path
android:fillColor="#FF000000"
android:pathData=“M14.99,13v-3L22,10L22,8h-7.01L14.99,5L11,9l3.99,4”/>
可以发现,这里的Vector图像比之前我们看见的要多了一个group标签。group标签的作用有两个:
对Path进行分组,由于我们后面需要针对Path进行动画,所以可以让具有同样动画效果的Path在同一个Group中;
拓展动画效果,单个的path标签是没有translateX和translateY属性的,因此无法使用属性动画来控制path translateY,而group标签是有的,所以我们需要先将相关的path标签元素包裹在一个个的group标签中.
- 动画效果
anim_left.xml
<objectAnimator xmlns:android=“http://schemas.android.com/apk/res/android”
android:duration=“1000”
android:interpolator="@android:interpolator/anticipate_overshoot"
android:propertyName=“translateX”
android:repeatCount=“infinite”
android:repeatMode=“reverse”
android:valueFrom=“0”
android:valueTo="-10"
android:valueType=“floatType” />
anim_right.xml
<objectAnimator
xmlns:android=“http://schemas.android.com/apk/res/android”
android:duration=“1000”
android:interpolator="@android:interpolator/anticipate_overshoot"
android:propertyName=“translateX”
android:repeatCount=“infinite”
android:repeatMode=“reverse”
android:valueFrom=“0”
android:valueTo=“10”
android:valueType=“floatType”/>
- 动态Vector
<animated-vector
xmlns:android=“http://schemas.android.com/apk/res/android”
xmlns:tools=“http://schemas.android.com/tools”
android:drawable="@drawable/ic_arrow"
tools:targetApi=“lollipop”>
<target
android:name=“left”
android:animation="@animator/anim_left"/>
<target
android:name=“right”
android:animation="@animator/anim_right"/>
- 使用动画
private void initView() {
mImageview = (ImageView) findViewById(R.id.imageview);
AnimatedVectorDrawableCompat animatedVectorDrawableCompat = AnimatedVectorDrawableCompat.create(
this, R.drawable.animated_vector
);
mImageview.setImageDrawable(animatedVectorDrawableCompat);
((Animatable) mImageview.getDrawable()).start();
}
- 使用动画
private void initView() {
mImageview = (ImageView) findViewById(R.id.imageview);
AnimatedVectorDrawableCompat animatedVectorDrawableCompat = AnimatedVectorDrawableCompat.create(
this, R.drawable.animated_vector
);
mImageview.setImageDrawable(animatedVectorDrawableCompat);
((Animatable) mImageview.getDrawable()).start();
}
这篇关于Android使用Vector进行适配和瘦身,2021Android常见面试题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!