原生微信小程序大转盘自定义配置以及动画实现

awards: [
            {
                id: "1678684429869957122",
                title: '一等奖',
                name: '纯金50G金元宝',
                icon: 'xxx'
            },
            {
                id: "1678684592919330818",
                title: '二等奖',
                name: '0.58现金红包',
                icon: 'xxx'
            },
            {
                id: "1678684695847550977",
                // title:'三等奖',
                title: '更多好礼',
                icon: 'xxx'
            },
            {
                id: "1678684847689744385",
                title: '四等奖',
                name: '华为运动手环',
                icon: 'xxx'
            },
            {
                id: "1678686592151109634",
                title: '五等奖',
                name: '1.18现金红包',
                icon: 'xxx'
            },
            {
                id: "1678686724460429314",
                title: '特等奖',
                name: '京东优惠券',
                icon: 'xxx'
            },
            {
                id: "1678686818400256002",
                title: '六等奖',
                name: '0.18现金红包',
                icon: 'xxx'
            }
        ],
        trunTime: 6000,
        animationData: {},
        chance: true,
        runDegs:0,
        awardsList:[]
drawTruntable() {
        var awardsConfig = this.data.awards,
            len = awardsConfig.length,
            awardsList = []
            // var turnNum = 1 / len
            var turnNum = 1 / awardsConfig.length * 360; // 文字旋转 turn 值 
        for (var i = 0; i < len; i++) {
            // 奖项列表
            awardsList.push({
                // turn: i * turnNum + 'turn',  // 文字旋转turn 值
                turn: (i * turnNum)  + 'deg',  // 文字旋转turn 值
                lineTurn: i * turnNum + turnNum / 2 + 'turn', // 线条旋转turn 值
                award: awardsConfig[i].name,  // 文字
                title: awardsConfig[i].title,
                icon: awardsConfig[i].icon
            });
        }
        this.setData({
            awardsList: awardsList
        });
       console.log(this.data.awardsList);
    },
    getLottery() {
        var awardsConfig = this.data.awardsList
        var runNum = 8
        let chance = this.data.chance
        const trunTime = this.data.trunTime
        var that = this
        var id ='1678686724460429314'
        var awardIndex = awardsConfig.findIndex(item => {
            if (item.id === id) {  
                return true
            }
        })
        
        // var awardIndex = Math.random() * awardsConfig.length >>> 0;
        console.log(awardIndex);
        // 获取奖品配置
        if (awardIndex < 2) chance = false

        // 旋转抽奖
        let runDegs = that.data.runDegs || 0
        console.log(that.data.runDegs, '++++');
        console.log(360 - runDegs % 360,'360 - runDegs % 360');
        console.log(360 * runNum - awardIndex * (360 / awardsConfig.length));
        runDegs = runDegs + (360 - runDegs % 360) + (360 * runNum - awardIndex * (360 / awardsConfig.length))
        var animationRun = wx.createAnimation({
            duration: trunTime,
            timingFunction: 'ease'
        })
        that.setData({
            runDegs
        })
        console.log(that.data.runDegs, '=======');
        that.animationRun = animationRun
        animationRun.rotate(that.data.runDegs).step()
        that.setData({
            animationData: animationRun.export(),
        })

        console.log(that.data.animationData);
        // 中奖提示
        setTimeout(function () {
            wx.showModal({
                title: '恭喜',
                content: '获得`' + (awardsConfig[awardIndex].name) + "`",
                showCancel: false
            })
        }, trunTime, that);
    },
<view class="wrapper">
  <view class="main">
    <view class="table-container">
      <view class="table-content" animation="{{animationData}}">
        <!-- <view class="table-line">
          <view class="table-litem" wx:for="{{awardsList}}" wx:key="unique" style="-webkit-transform: rotate({{item.lineTurn}});transform: rotate({{item.lineTurn}})"></view>
        </view> -->
        <view class="table-list">
          <view class="table-item" wx:for="{{awardsList}}" wx:key="unique">
            <view class="table-item-text" style="-webkit-transform: rotate({{item.turn}});transform: rotate({{item.turn}})">
              <view class="title">{{item.title || ''}}</view>
              <view class="award">{{item.award || ''}}</view>
              <image class="awardImg" src="{{item.icon || ''}}" />
            </view>
          </view>
        </view>
      </view>
      <view bindtap="getLottery" class="table-btn {{btnDisabled}}">开始</view>
    </view>
  </view>
</view>
page {
  height: 100%;
  width: 100%;
  margin: 0;
  padding: 0;
}

view {
  box-sizing: border-box;
}
/* 转盘 */
.table-container ul,
.table-container li {
  margin: 0;
  padding: 0;
  list-style: none;
}

.table-container {
  margin: 0 auto;
  margin-top: 20rpx;
  position: relative;
  width: 579rpx;
  height: 579rpx;
  border-radius: 50%;
  /*border: 2px solid #E44025;*/
  // box-shadow: 0 2px 3px #333,
  //   0 0 2px #000;
}

.table-content {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  display: block;
  width: 579rpx;
  height: 579rpx;
  background: url('/images/转盘带背景.png') no-repeat;
  background-size: 100% 100%;
}

/*选项*/
.table-list {
  position: absolute;
  left: 0;
  top: 0;
  width: inherit;
  height: inherit;
  z-index: 9;
}

.table-item {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  color: #e4370e;
  font-weight: bold;
  // text-shadow: 0 1px 1px rgba(255, 255, 255, .6);
}

.table-item-text {
  position: relative;
  display: block;
  padding-top: 70rpx;
  // padding-top: 20px;
  /* width: 50px; */
  margin: 0 auto;
  text-align: center;
  -webkit-transform-origin: 50% 300rpx;
  transform-origin: 50% 300rpx;
  // -webkit-transform-origin: 50% 50%;
  // transform-origin: 50% 50%;
  word-wrap: break-word;
  width: 200rpx;
}
.title{
  font-family: PingFang SC;
  font-weight: 600;
  font-size: 22rpx;
  /* 三等奖 */
  color: #D70D19;
}
.award{
  font-family: PingFang SC;
  font-weight: 400;
  font-size: 22rpx;
  /* 三等奖 */
  color: #333;
}
.awardImg{
  width: 72rpx;
  height: 56rpx;
}
/* 分隔线 */
.table-line {
  position: absolute;
  left: 0;
  top: 0;
  width: inherit;
  height: inherit;
  z-index: 99;
}

.table-litem {
  position: absolute;
  left: 150px;
  top: 0;
  width: 1px;
  height: 150px;
  background-color: rgba(228, 55, 14, .4);
  overflow: hidden;
  -webkit-transform-origin: 50% 150px;
  transform-origin: 50% 150px;
}


.table-btn {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  // left: 110px;
  // top: 110px;
  z-index: 400;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  color: #F4E9CC;
  background-color: #E44025;
  line-height: 80px;
  text-align: center;
  font-size: 20px;
  text-shadow: 0 -1px 1px rgba(0, 0, 0, .6);
  box-shadow: 0 3px 5px rgba(0, 0, 0, .6);
  text-decoration: none;
}

.table-btn::after {
  position: absolute;
  display: block;
  /* before和:after时必须设置其content属性,否则伪元素就不起作用 */
  content: ' ';
  left: 10px;
  top: -46px;
  width: 0;
  height: 0;
  overflow: hidden;
  border-width: 30px;
  border-style: solid;
  border-color: transparent;
  border-bottom-color: #E44025;
}

/* .table-btn.disabled{
    pointer-events: none;
    background: #B07A7B;
    color: #ccc;
}
.table-btn.disabled::after{
  border-bottom-color: #B07A7B;
} */


.gb-run {
  -webkit-transition: all 6s ease;
  transition: all 6s ease;
}

.canvas-container {
  background-color: white;
  margin: 2% 2%;
  border: green 1rpx solid;
  width: 95%;
  height: 80%;
  margin-bottom: 10%;
}

#myCanvas {
  /* float: 100%; */
  width: 100%;
  height: 100%;
}

需要的素材(必须是圆形的,否则转起来会很晃)

转盘带背景.png

最后成图

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

推荐阅读更多精彩内容