微信小程序开发之『弹出菜单』特效

先看下效果图. 

代码: 

1.popMenu.js

Page({
    data: {
        isPopping: false,//是否已经弹出
        animPlus: {},//旋转动画
        animCollect: {},//item位移,透明度
        animTranspond: {},//item位移,透明度
        animInput: {},//item位移,透明度
    },
    //点击弹出
    plus: function () {
        if (this.data.isPopping) {
            //缩回动画
            this.popp();
            this.setData({
                isPopping: false
            })
        } else if (!this.data.isPopping) {
            //弹出动画
            this.takeback();
            this.setData({
                isPopping: true
            })
        }
    },
    input: function () {
        console.log("input")
    },
    transpond: function () {
        console.log("transpond")
    },
    collect: function () {
        console.log("collect")
    },

    //弹出动画
    popp: function () {
        //plus顺时针旋转
        var animationPlus = wx.createAnimation({
            duration: 500,
            timingFunction: 'ease-out'
        })
        var animationcollect = wx.createAnimation({
            duration: 500,
            timingFunction: 'ease-out'
        })
        var animationTranspond = wx.createAnimation({
            duration: 500,
            timingFunction: 'ease-out'
        })
        var animationInput = wx.createAnimation({
            duration: 500,
            timingFunction: 'ease-out'
        })
        animationPlus.rotateZ(180).step();
        animationcollect.translate(-100, -100).rotateZ(180).opacity(1).step();
        animationTranspond.translate(-140, 0).rotateZ(180).opacity(1).step();
        animationInput.translate(-100, 100).rotateZ(180).opacity(1).step();
        this.setData({
            animPlus: animationPlus.export(),
            animCollect: animationcollect.export(),
            animTranspond: animationTranspond.export(),
            animInput: animationInput.export(),
        })
    },
    //收回动画
    takeback: function () {
        //plus逆时针旋转
        var animationPlus = wx.createAnimation({
            duration: 500,
            timingFunction: 'ease-out'
        })
        var animationcollect = wx.createAnimation({
            duration: 500,
            timingFunction: 'ease-out'
        })
        var animationTranspond = wx.createAnimation({
            duration: 500,
            timingFunction: 'ease-out'
        })
        var animationInput = wx.createAnimation({
            duration: 500,
            timingFunction: 'ease-out'
        })
        animationPlus.rotateZ(0).step();
        animationcollect.translate(0, 0).rotateZ(0).opacity(0).step();
        animationTranspond.translate(0, 0).rotateZ(0).opacity(0).step();
        animationInput.translate(0, 0).rotateZ(0).opacity(0).step();
        this.setData({
            animPlus: animationPlus.export(),
            animCollect: animationcollect.export(),
            animTranspond: animationTranspond.export(),
            animInput: animationInput.export(),
        })
    },


    onLoad: function (options) {
        // 生命周期函数--监听页面加载
    },
    onReady: function () {
        // 生命周期函数--监听页面初次渲染完成
    },
    onShow: function () {
        // 生命周期函数--监听页面显示
    },
    onHide: function () {
        // 生命周期函数--监听页面隐藏
    },
    onUnload: function () {
        // 生命周期函数--监听页面卸载
    },
    onPullDownRefresh: function () {
        // 页面相关事件处理函数--监听用户下拉动作
    },
    onReachBottom: function () {
        // 页面上拉触底事件的处理函数
    },
    onShareAppMessage: function () {
        // 用户点击右上角分享
        return {
            title: 'title', // 分享标题
            desc: 'desc', // 分享描述
            path: 'path' // 分享路径
        }
    }
})

2.popMenu.wxml

<view>
  <image src="/pages/images/collect.png" class="img-style" animation="{{animCollect}}" bindtap="collect"></image>
  <image src="/pages/images/transpond.png" class="img-style" animation="{{animTranspond}}" bindtap="transpond"></image>
  <image src="/pages/images/input.png" class="img-style" animation="{{animInput}}" bindtap="input"></image>
  <image src="/pages/images/plus.png" class="img-plus-style" animation="{{animPlus}}" bindtap="plus"></image>
</view>

3.popMenu.wxss

.img-plus-style {
  height: 150rpx;
  width: 150rpx;
  position: absolute;
  bottom: 250rpx;
  right: 100rpx;
  z-index: 100;
}

.img-style {
  height: 150rpx;
  width: 150rpx;
  position: absolute;
  bottom: 250rpx;
  right: 100rpx;
  opacity: 0;
}


  • 13
    点赞
  • 74
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程序源码(含截图)圆形菜单微信小程
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值