小程序动画和css

一、css动画

动画过程中,可以使用 bindtransitionend bindanimationstart bindanimationiteration bindanimationend 来监听动画事件。

事件名 含义
transitionend CSS 渐变结束或 wx.createAnimation 结束一个阶段
animationstart CSS 动画开始
animationiteration CSS 动画结束一个阶段
animationend CSS 动画结束
<view class="box {{extraClasses}}"
  bindtransitionend="transitionEnd" // CSS 渐变结束或 [wx.createAnimation]调用
  bindanimationstart="animationStart"
  bindanimationiteration="animationIteration"/>

二、关键帧动画

从小程序基础库 2.9.0 支持this.animate更友好的动画创建代替旧的 wx.createAnimation ,它具有更好的性能和更可控的接口

官方api

1、小程序动画api - this.animate
2、小程序动画api - wx.createAnimation

参考:

1、css3与api实现方式
2、【小程序动画合集】10种小程序动画效果实现方法

小程序的动画和css的动画区别:
还原时需要手动清除动画过程添加的参数

1、过渡动画
wx.createAnimation 新版小程序基础库中推荐使用this.animate接口代替,使用方式和this.animate相似

通过该接口,只能使用这些提供好的属性,不能使用额外的css属性!
this.animate('选择器',[{
    offset:0,       当前动画的占比,0-1
    offset          
    ease    linear  
    transformOrigin 
    backgroundColor 
    bottom:Number|String            
    height          
    left            
    width           
    opacity         
    right           
    top             
    matrix          
    matrix3d        
    rotate          
    rotate3d        
    rotateX         
    rotateY         
    rotateZ         
    scale:[x方向缩放,y方向缩放]         
    scale3d         
    scaleX          
    scaleY          
    scaleZ          
    skew            
    skewX           
    skewY           
    translate       
    translate3d     
    translateX      
    translateY      
    translateZ      
},{
    offset:0.5      当前动画的占比时间
    ...可设置多个动画帧
    
}],过渡时间,function(){
    动画结束回调,回调中注意绑定this
}.bind(this))

2、滚动过程动画
滚动过程和this.animate不同,滚动过程设置的属性可以是this.animate提供的属性以外的css属性,使用驼峰命名

this.animate('选择器,只支持选择scroll-view中的元素',[{

    除了支持this.animate中的配置外,还支持驼峰命名的其他css属性
    borderRadius: '25%',
    borderColor: 'blue',
    transform: 'scale(.65) translateY(-20px)',
    
},{...}], 动画时间, {
    scrollSource            指定滚动元素的选择器(只支持scroll-view),该元素滚动时会驱动动画的进度
    orientation             指定滚动的方向,效值为"horizontal"|"vertical"
    startScrollOffset       n,指定开始驱动动画进度的滚动偏移量,单位px
    endScrollOffset         n,指定停止驱动动画进度的滚动偏移量,单位px
    timeRange               起始和结束的滚动范围映射的时间长度,该时间可用于与关键帧动画里的时间(duration)相匹配,单位ms
                                当设置了滚动动画后,duration等已经失效,动画只和滚动距离有关
                                当timeRange=动画时间,则抵达endScrollOffset时结束动画
                                当timeRange>动画时间,则抵达endScrollOffset之前结束动画
                                当timeRange<动画时间,则抵达endScrollOffset之后也不会到动画的最后一帧
})

3、css方式
通过css来设置动画,如果setData过多,会造成小程序僵死
优化:通过wxs来绑定事件等产生动画,在视图层处理,避免与逻辑层交互

4、监听动画
transitionend CSS 渐变结束或wx.createAnimation结束一个阶段
animationstart CSS 动画开始
animationiteration CSS 动画结束一个阶段
animationend CSS 动画结束

这几个事件都不是冒泡事件,需要绑定在真正发生了动画的节点上才会生效。
使用时:bindtransitionend

5、清除动画
调用animate API后会在节点上新增一些样式属性覆盖掉原有的对应样式。
如果需要清除这些样式,可在该节点上的动画全部执行完毕后使用this.clearAnimation清除这些属性。

this.clearAnimation('选择器',{
    要清除的属性,不写全部清除
    opacity: true, 
    rotate: true,
    ...
}, function(){
    清除完成后的回调函数
})

————————————————
版权声明:本文为CSDN博主「神奇大叔」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_43294560/article/details/120971317

demo

一、使用wx.createAnimation

<view class="animation_ll">
    <view class="animation_view" animation="{{animationData}}"></view>
</view>
<button class="btn" bindtap="rotateAndScaleThenTranslate">先旋转同时放大,然后平移</button>
<button class="btn" bindtap="rotateAndScale">旋转同时放大</button>
<button class="btn" bindtap="rotateThenScale">先旋转后放大</button>
<button class="btn" bindtap="reset">还原</button>
Page({
    onShow() {
        this.animation = wx.createAnimation({
            duration: 1000, // 动画持续时间,单位 ms
            timingFunction: 'linear', // 动画的效果, linear动画从头到尾的速度是相同的
            delay: 0, // 动画延迟时间,单位 ms
        });
    },
    
    /**
     * 先旋转同时放大,然后平移
     */
    rotateAndScaleThenTranslate() {
        // 先旋转同时放大,然后平移
        this.animation.rotate(45).scale(2, 2).step();
        this.animation.translate(100, 100).step({ duration: 1000 });
        this.setData({
            animationData: this.animation.export()
        });
    },

    /**
     * 旋转同时放大
     */
    rotateAndScale() {
        this.animation.rotate(45).scale(2, 2).step();
        this.setData({
            animationData: this.animation.export()
        });
    },

    /**
     * 先旋转后放大
     */
    rotateThenScale() {
        this.animation.rotate(45).step();
        this.animation.scale(2, 2).step();
        this.setData({
            animationData: this.animation.export()
        });
    },

    /**
     * 重置
     */
    reset() {
        this.animation.rotate(0, 0)
            .scale(1)
            .translate(0, 0)
            .skew(0, 0)
            .step({ duration: 0 });
        this.setData({
            animationData: this.animation.export()
        });
    }
});
.animation_ll {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 250rpx 0;
}
.animation_view {
    width: 200rpx;
    height: 200rpx;
    background-color: #1AAD19;
}

.btn {
    background: deepskyblue;
    color: #ffffff;
    height: 80rpx;
    width: 500rpx;
    padding: 0 20rpx;
    font-size: 30rpx;
    line-height: 80rpx;
    margin-top: 30rpx;
    
}

二、使用this.animate

Page({
    clickAnimate() {
        this.animate('#container', [
            { opacity: 1.0, rotate: 0, backgroundColor: '#FF0000' },
            { opacity: 0.5, rotate: 45, backgroundColor: '#00FF00' },
            { opacity: 0.1, rotate: 80, backgroundColor: '#007dff' },
        ], 2000, function () {
            this.clearAnimation('#container', { opacity: true, rotate: true }, function () {
                console.log('清除了#container上的 opacity 和rotate属性');
            });
        }.bind(this));
    },

    /**
     * 重置
     */
    reset() {
        this.animation.rotate(0, 0)
            .scale(1)
            .translate(0, 0)
            .skew(0, 0)
            .step({ duration: 0 });
        this.setData({
            animationData: this.animation.export()
        });
    }
});

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,717评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,501评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,311评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,417评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,500评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,538评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,557评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,310评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,759评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,065评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,233评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,909评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,548评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,172评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,420评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,103评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,098评论 2 352

推荐阅读更多精彩内容

  • 小程序中适当使用微型动画,可以给交互带来更好的体验。 按照小程序开发指南的介绍,在小程序中,通常可以使用 CSS ...
    姜姜蒋阅读 3,183评论 0 1
  • 每天的学习记录,可能有的地方写的不对,因为刚学,以后发现错的话会回来改掉整体流程 https://develope...
    有点健忘阅读 4,651评论 0 7
  • 这一周工作主要围绕了微信小程序的动画效果展开,微信小程序的动画实际上是对原生的css3动画进行了一层封装,所以其动...
    LilacSun阅读 602评论 1 7
  • 小程序开发入门 最近开发了几个微信小程序,现在将其中比较重要的点列出来,供参考。在文中,开发者服务器(以下简称:服...
    伞U阅读 496评论 0 5
  • 官方API : https://developers.weixin.qq.com/miniprogram/dev/...
    杀个程序猿祭天阅读 21,424评论 1 2