目录

微信小程序仿QQ头像轮播效果

1、效果图

2、效果流程分析

1、第1个头像大小从1到0缩小的同时,第2个头像左移

2、上面动画结束后,延迟50ms,第3个头像从0到1放大

3、把头像列表顺序前移一位,并重置轮播状态,以此达到一个循环。然后继续第一个步骤

3、源码

组件使用

xml 复制代码
<AvatarsBanner avatars="{{avatars}}" />

index.wxml

xml 复制代码
<view
  class="avatarList"
  style="width:{{itemWidth*3-overlapWidth*2}}rpx;"
>
  <!-- 备注:微信小程序经测试,即使不渲染的元素也要添加到节点上,否则第3个的放大动画不会展示 -->
  <image
    src="{{item}}"
    animation="{{index===0?firstAnimation:(index===1?secondAnimation:(index===2?lastAnimation:''))}}"
    wx:for="{{avatars}}"
    wx:key="index"
    style="left: {{(itemWidth-overlapWidth)*index}}rpx; z-index: {{avatars.length-index}};width:{{itemWidth}}rpx;height:{{itemWidth}}rpx;"
    class="avatarImage {{index>2 && 'hidden'}}"
  />
</view>

index.js

js 复制代码
const animalTime = 200; // 动画时间
const intervalTime = 1000; // 定时器频率

Component({
  properties: {
    // 头像列表
    avatars: {
      type: Array,
      value: [],
      observer(newVale) {
        this.interval && clearInterval(this.interval);
        this.startAnimation();
      },
    },
    style: {
      type: String,
      value: '',
    },
    // 图片宽度:rpx
    itemWidth: {
      type: Number,
      value: 36,
    },
    // 重叠部分宽度:rpx
    overlapWidth: {
      type: Number,
      value: 10,
    },
  },
  data: {},
  methods: {
    startAnimation() {
      const { avatars } = this.data;
      const { itemWidth, overlapWidth } = this.properties;
      if (avatars.length < 3) {
        return;
      }
      // 创建animation对象
      this.firstAnimation = wx.createAnimation();
      this.secondAnimation = wx.createAnimation();
      this.lastAnimation = wx.createAnimation();

      this.interval = setInterval(() => {
        // num1缩放动画
        this.firstAnimation.scale(0).step({ duration: animalTime });
        this.setData({
          firstAnimation: this.firstAnimation.export(),
        });

        // num2、num3平移动画(除以2是rpx转px)
        const offsetX = (overlapWidth - itemWidth)/2;
        this.secondAnimation.translate(offsetX, 0).step({ duration: animalTime });
        this.lastAnimation.translate(offsetX, 0).step({ duration: animalTime });
        this.setData({
          secondAnimation: this.secondAnimation.export(),
          lastAnimation: this.lastAnimation.export(),
        });

        // num3放大动画(animalTime + 50:表示前面两个动画结束,并且setData数据更新)
        setTimeout(() => {
          this.lastAnimation.scale(1).step({ duration: animalTime });
          this.setData({
            lastAnimation: this.lastAnimation.export(),
          });
        }, animalTime + 50);

        // 还原动画 (等待缩小动画完成后再切换头像)
        setTimeout(() => {
          this.firstAnimation.scale(1).step({
            duration: 0,
          });
          this.secondAnimation.translate(0, 0).step({
            duration: 0,
          });
          this.lastAnimation.translate(0, 0).scale(0).step({
            duration: 0,
          });
          this.setData({
            avatars: avatars.slice(1).concat(avatars[0]),
            lastAnimation: this.lastAnimation.export(),
            firstAnimation: this.firstAnimation.export(),
            secondAnimation: this.secondAnimation.export(),
          });
        }, animalTime);
      }, intervalTime);
    },
  },
});

index.wxss

css 复制代码
.avatarList {
  display: flex;
  flex-direction: row;
  position: relative;
  height: 100%;
}

.avatarImage {
  position: absolute;
  border: 1rpx solid #ffffff;
  border-radius: 50%;

  /* 占位图 */
  background-image: url('https://xm-1301527776.cos.ap-shanghai.myqcloud.com/images/miniprogram/channel/Post/ic_default_header.png');
  background-repeat: no-repeat;
  background-position: center;
  background-color: #f6f6f6;
  background-size: cover;
}

.hidden {
  display: none;
}
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
跨时代科技5 小时前
洗车小程序系统前端uniapp 后台thinkphp
小程序
依辰6 小时前
小程序SAAS产品定制化需求解决方案
前端·javascript·微信小程序
fakaifa8 小时前
【最新版】沃德代驾源码全开源+前端uniapp
前端·小程序·uni-app·开源·php·沃德代驾·代驾小程序
18538162800余。12 小时前
NFC 碰一碰实现视频源码,网页与小程序协同
小程序
换日线°1 天前
微信小程序拖拽排序有效果图
微信小程序
码起来呗1 天前
基于微信小程序的走失儿童帮助系统-项目分享
微信小程序·小程序
大樊子1 天前
微信小程序路由跳转实现详解
微信小程序·小程序
不知名工程师小茶1 天前
校园二手交易平台的小程序
小程序
@泽栖2 天前
下载HBuilder X,使用uniapp编写微信小程序
微信小程序·小程序·uni-app
程序员王天2 天前
Uniapp 自定义TabBar + 动态菜单实现教程(Vuex状态管理详解)
微信小程序·uni-app