android自定义svg,Android自定义View-SVG动画

1、SVG与Bitmap的区别:

SVG是可缩放矢量图形,全称Scalable Vector Graphics。经过数学计算利用直线和曲线绘制而成,无论怎么放大,都不会出现马赛克现象。可以使用Illustrator矢量图绘图软件来进行绘图。

Bitmap 是位图,由一个个像素点组成,放大后会出现马赛克。可以使用PhotoShop位图绘图软件来进行绘图。

2、SVG的优势:

1、使用xml格式定义图形,读取和修改的工具多。

2、不会失真,无需根据分辨率适配多套图标。

3、占用空间小。

4、可以转换为Path路径,与Path动画相结合,形成更丰富的动画。

3、静态SVG的使用

1、使用Android Studio转换美工提供的SVG文件为vector的xml文件:

Android Studio->File->New->Vector Asset->Local File->RTL->drawable/ic_love.xml

65cb76805af31d2e8040d0727e2e2f51.png

2、加载vector的xml文件:

app:layout_constraintTop_toTopOf="parent"

app:layout_constraintRight_toRightOf="parent"

app:layout_constraintLeft_toLeftOf="parent"

android:layout_width="100dp"

android:src="@drawable/ic_love"

android:layout_height="100dp">

4、动态SVG的使用

1、使用Android Studio转换美工提供的SVG文件为vector的xml文件:

android:width="72dp"

android:height="50dp"

android:viewportWidth="72.0"

android:viewportHeight="50.0">

android:name="animate_logo_target"

android:pathData="M60,5,L10,5,V15,A1,1,0,0,0,65,20,L65,10"

android:strokeWidth="10"

android:strokeColor="#03DAC5" />

2、创建SVG对应的动画

android:duration="3000"

android:propertyName="trimPathEnd"

android:repeatCount="0"

android:valueFrom="0"

android:valueTo="1"

android:valueType="floatType"/>

其中propertyName:

trimPathStart 属性表示截掉从起点到某个位置的部分,保留剩下的部分;

trimPathEnd 属性表示截掉从某个位置到终点的部分,保留剩下的部分。

3、启动动画

private void start() {

AnimatedVectorDrawableCompat animatedVectorDrawableCompat = AnimatedVectorDrawableCompat.create(

this, R.drawable.ic_logo

);

mIvSvgVectorAnimation.setImageDrawable(animatedVectorDrawableCompat);

((Animatable) mIvSvgVectorAnimation.getDrawable()).start();

}

319461e8568ffb0acb462dba8d421762.gif

5、Lottie加载SVG动画

Lottie可以轻松加载SVG动画,只需美工提供JSON文件即可,Lottie的GitHub地址:https://github.com/airbnb/lottie-android

1、test.json文件置于assets文件夹中。

2、编写布局控件:

android:id="@+id/animation_view"

android:layout_width="wrap_content"

app:layout_constraintTop_toTopOf="parent"

app:layout_constraintRight_toRightOf="parent"

app:layout_constraintLeft_toLeftOf="parent"

android:layout_height="wrap_content"

app:lottie_loop="true"

app:lottie_autoPlay="true" />

3、启动动画

private void initTest() {

mLavGift.setAnimation("test.json");

mLavGift.setRepeatCount(INFINITE);

mLavGift.playAnimation();

}

95ff0b78dfa369cf90684b7594a4ee94.gif

6、SVGA加载SVG动画

SVGA可以轻松加载SVG动画,只需美工提供SVGA文件即可,SVGA的GitHub地址:https://github.com/svga/SVGAPlayer-Android

1、posche.svga置于assets文件夹中。

2、直接编写布局控件加载:

android:layout_height="200dp"

android:layout_width="200dp"

app:layout_constraintTop_toTopOf="parent"

app:layout_constraintLeft_toLeftOf="parent"

app:source="love.svga"

app:autoPlay="true"

android:id="@+id/svga_test"/>

3、从assets中加载:

SVGAImageView svgaImageView = new SVGAImageView(this);

SVGAParser.Companion.shareParser().init(this);

SVGAParser parser = SVGAParser.Companion.shareParser();

parser = new SVGAParser(this);

parser.decodeFromAssets("posche.svga", new SVGAParser.ParseCompletion() {

@Override

public void onComplete(SVGAVideoEntity svgaVideoEntity) {

SVGADrawable drawable = new SVGADrawable(svgaVideoEntity);

svgaImageView.setImageDrawable(drawable);

mFlSvga1.addView(svgaImageView );

svgaImageView.startAnimation();

}

@Override

public void onError() {

System.out.println("解析错误decodeFromAssets");

}

});

4、从url中加载:

SVGAImageView svgaImageView1 = new SVGAImageView(this);

SVGAParser parser1 = SVGAParser.Companion.shareParser();

parser1 = new SVGAParser(this);

URL url = new URL("https://github.com/yyued/SVGA-Samples/blob/master/posche.svga raw=true");

parser1.decodeFromURL(url, new SVGAParser.ParseCompletion() {

@Override

public void onComplete(SVGAVideoEntity svgaVideoEntity) {

SVGADrawable drawable = new SVGADrawable(svgaVideoEntity);

svgaImageView1.setImageDrawable(drawable);

mFlSvga2.addView(svgaImageView1 );

svgaImageView1.startAnimation();

}

@Override

public void onError() {

System.out.println("解析错误decodeFromURL");

}

});

0fe9f71a84ec5bb8fd06ec9a48008ac1.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值