时间:2021-05-02
最近公司需求做个类似小红书的标签呼吸灯动画,经过一段时间研究使用两种方式实现了该效果...
第一种方式使用定时器加 uiview动画,核心方法如下
? 1 2 3 4 5 6 7 8 9 10 11 12 13 -(void)begigflashanimation { // 缩放 + 透明度动画 self.flashview.transform = cgaffinetransformmakescale(0.1, 0.1); [uiview animatewithduration:3 animations:^{ self.flashview.transform = cgaffinetransformmakescale(1,1); self.flashview.alpha = 1.0; [uiview beginanimations:@"flash" context:nil]; [uiview setanimationduration:2]; [uiview setanimationcurve:uiviewanimationcurvelinear]; self.flashview.alpha = 0; [uiview commitanimations]; }]; }第二种方式使用核心动画的动画组,核心方法如下
? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 - (caanimationgroup *)groups { if (!_groups) { // 缩放动画 cabasicanimation * scaleanim = [cabasicanimation animation]; scaleanim.keypath = @"transform.scale"; scaleanim.fromvalue = @0.1; scaleanim.tovalue = @1; scaleanim.duration = 2; // 透明度动画 cabasicanimation *opacityanim=[cabasicanimation animationwithkeypath:@"opacity"]; opacityanim.fromvalue= @1; opacityanim.tovalue= @0.1; opacityanim.duration= 2; // 创建动画组 _groups =[caanimationgroup animation]; _groups.animations = @[scaleanim,opacityanim]; _groups.removedoncompletion = no; _groups.fillmode = kcafillmodeforwards; _groups.duration = 2; _groups.repeatcount = flt_max; } return _groups; }对比两种方法,第一种方法需要使用定时器,第二个则不需要,不知道这样是否第二个性能性对来说会好点呢?
github项目地址:https://github.com/caiflower/xxtwinkleview.git
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://www.jianshu.com/p/885e97f398de
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言在Android中,动画Animation的实现有两种方式:TweenAnimation(补间动画)和FrameAnimation(帧动画)。渐变动画是通过
JavaScript原生定时器实现动画的缓动效果,供大家参考,具体内容如下原理很简单通过定时器修改边距达到移动动画效果实现速度的变化缓动必然移动速度会有变化,这
前言之前说过了在Android中,动画Animation的实现有两种方式:TweenAnimation(渐变动画)和FrameAnimation(帧动画)。渐变
使用RxJava实现定时器功能可以通过两种方式来实现,具体实现如下:一、使用timer操作符privateDisposablemDisposable;/***启
本文介绍了通过css3动画和opacity透明度实现呼吸灯效果的方法,分享给大家,具体如下:呼吸灯bo