广告
返回顶部
首页 > 资讯 > 精选 >怎么在微信小程序实现一个幸运转盘小游戏
  • 867
分享到

怎么在微信小程序实现一个幸运转盘小游戏

2023-06-14 11:06:13 867人浏览 独家记忆
摘要

这篇文章将为大家详细讲解有关怎么在微信小程序实现一个幸运转盘小游戏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。效果图小程序开发思路开发思路有三部分,第一部分是用CSS绘制转盘背景,第二部分是利用 wxs

这篇文章将为大家详细讲解有关怎么在微信小程序实现一个幸运转盘小游戏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

效果图

怎么在微信小程序实现一个幸运转盘小游戏

小程序开发思路

开发思路有三部分,第一部分是用CSS绘制转盘背景,第二部分是利用 wxs 语法实现响应式样式 ,第三部分是小程序内置动画api实现转盘的转动以及通过js转动随机性的实现。

本人主要介绍编写思路,下面就开始我的讲解。

如何画一个三角形

一开始,要写一个基础的 wxml 框架

<view class="turntable">  <view class="wrapper">    <view class="item" >  <view class="item-inner"><text>10分</text>  </view></view>  </view></view>

我画了两个大小相同的长方形,长和宽分别是300rpx和600rpx,利用 position css属性,让两个长方形合并在一起。

.turntable {  display: block;  width: 100%;  height: 600rpx;}.turntable .wrapper{  position: relative;  transfORM-origin: center;  width: 100%;  height: 600rpx;}

怎么在微信小程序实现一个幸运转盘小游戏

合并之后我需要将两个长方体分离出来,把红色长方体变成半圆形,蓝色长方体顺时摆动60度,红色长方体逆时摆动30度,为什么要这样转,因为蓝色本来随红色逆时摆动30度,而一个三角形内角为60度,为了形成这60度的夹角,我需要红色摆完之后再将蓝色顺时移动60度,也就这样形成60度夹角。

.turntable .wrapper .item {  position: absolute;  left: 50%;  width: 300rpx;  height: 600rpx;  border-radius: 0px 300rpx 300rpx 0;  transform-origin: left center;  transform: rotate(-30deg);}.turntable .wrapper .item .item-inner {  text-align: center;  width: 300rpx;  height: 600rpx;  transform: translateX(-300rpx) rotate(60deg);   transform-origin: right center;  border-radius: 300rpx 0 0 300rpx;  font-size: 32rpx;}

怎么在微信小程序实现一个幸运转盘小游戏

接下来关键一步在 item 处增加  overflow: hidden 属性,一个三角形就出来了,并调整字体的位置。

.turntable .wrapper .item {  position: absolute;  left: 50%;  width: 300rpx;  height: 600rpx;  border-radius: 0px 300rpx 300rpx 0;  overflow: hidden;  transform-origin: left center;}.turntable .wrapper .item .item-inner text {  display: block;  transform-origin: center;  transform: translateY(100rpx) translateX(43rpx) rotate(-30deg);}

怎么在微信小程序实现一个幸运转盘小游戏

一个三角形画出来后,将6个同等大小的三角形并让他们可以拼接在一起组合成一个圆盘,只需各自修改三角的旋转角度即可。

.turntable .wrapper .item:nth-child(1) {  transform: rotate(-30deg);}.turntable .wrapper .item:nth-child(2) {  transform: rotate(-90deg);}.turntable .wrapper .item:nth-child(3) {  transform: rotate(-150deg);}.turntable .wrapper .item:nth-child(4) {  transform: rotate(-210deg);}.turntable .wrapper .item:nth-child(5) {  transform: rotate(-270deg);}.turntable .wrapper .item:nth-child(6) {  transform: rotate(-330deg);}

实现响应式样式

为了更好的适应不同业务需求,我把转盘的样式变成响应式,就可以轻松根据用外部传入的 prize 数据的长度来设置不同的样式,我把这一步的判断,放在 wxs 模块那里。

<wxs module="computed">var rotate = function (index, length) {var inital = - (360 / length / 2)var averageRotate = 360 / lengthvar deg = inital - averageRotate * indexreturn 'transform: rotate(' + deg + 'deg);'}var inner = function (length) {var averageRotate = 360 / lengthreturn 'transform: translateX(-300rpx) rotate(' + averageRotate + 'deg);'}var text = function (length) {var distance = 0var rotate = 0switch (length) {case 6:distance = 43rotate = 30breakcase 8:distance = 72rotate = 30breakcase 4:distance = -20rotate = 40break}return 'transform: translateY(100rpx) translateX(' + distance + 'rpx) rotate(-45deg);'}module.exports = {rotate: rotate,inner: inner,text: text}</wxs>

动画系统和中奖系统

通过设定好的中奖率,以一个圆为360度来计算,得出一个0-360的中奖范围,将随机得来的数判断属于哪个区间值,用区间值 reward 来决定圆盘所需转动的角度。思路大概就是这样,下面开始讲解主要的思路。

圆盘要转的角度 = reward * 一个圆分成6块的平均值  + 3 * 360

首先要设置好6个奖品区的中奖率winning,该中奖率要相加起来为1,把初始化的数据组合成一个6位数的数组从组件外传入进组件内。

prize: [{        'name': '1分',        'winnning': 0.2,        'count': 1      },      {        'name': '谢谢参与',        'winnning': 0.5,        'count': 0      }, {        'name': '5分',        'winnning': 0.05,        'count': 5      }, {        'name': '7分',        'winnning': 0.05,        'count': 7      },       {        'name': '3分',        'winnning': 0.1,        'count': 3      },       {        'name': '4分',        'winnning': 0.1,        'count': 4      }    ],

以一个圆为360度来计算出0-360的中奖取值范围。

getRange(winning) {   let temp = []     winning.forEach((item, index) => {       if (index === 0) {         temp.push(item['winnning'] * 360)       } else {         temp.push(parseInt(temp.slice(-1)) + item['winnning'] * 360)       }      })      return temp    },

生成一个随机整数,当然这数要在0-360,不然超出360或小于0是没有意义的。

let random = Math.round(Math.random() * 360)

获得随机数之后,判断在哪个奖品范围内并把在对应的区间值赋予响应数reward 内。

for (let i in winningRange) {    let currentwinning = winningRange[i] // 当前取值       if (random < currentwinning) {          this.setData({            reward: i          })          break      } else {        if (i == 0) {           continue        }        if (random >= winningRange[i - 1] && random <= currentwinning) {           this.setData({              reward: i           })           break       }     }}

把点击开始的主函数放在onPoint()内,函数开始时需判断是否仍有抽奖机会以及防止在执行动画又点击函数执行动画,经过计算得来所需的角度通过微信小程序的动画api animation 来让圆盘实现转动,动画结束后把中奖信息通过自定义组件触发事件来让组件外监听到。

onPoint() {      // 平均值      const averageRotate = 360 / this.properties.prize.length      // 是否有抽奖机会      if (this.properties.chance === 0) {        this.triggerEvent('none')        return      }      // 防止转动时点击开始按钮      if (!this.data.onRotation) {        this.setData({          onRotation: true        })        this.getReward()        let deg = this.data.reward * averageRotate + 3 * 360  // 至少3圈以上        this.animate('.wrapper', [{            rotate: 0,            ease: 'ease-in-out'          },          {            rotate: deg,            ease: 'ease-in-out'          }        ], 5000, function () {          this.setData({            onRotation: false          })          // 发送自己的抽奖信息          this.triggerEvent('onResult', this.properties.prize[this.data.reward])        }.bind(this))      }    },

最后别忘了在每次执行动画前,都要先执行动画重置动作,才能保证动画下次转到正确的角度。当然我把其放在一个函数里面,以便组件外也可以使用该函数。

onClear(){   this.clearAnimation('.wrapper')

关于“怎么在微信小程序实现一个幸运转盘小游戏”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: 怎么在微信小程序实现一个幸运转盘小游戏

本文链接: https://www.lsjlt.com/news/270490.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在微信小程序实现一个幸运转盘小游戏
    这篇文章将为大家详细讲解有关怎么在微信小程序实现一个幸运转盘小游戏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。效果图小程序开发思路开发思路有三部分,第一部分是用css绘制转盘背景,第二部分是利用 wxs...
    99+
    2023-06-14
  • 如何在微信小程序实现一个幸运转盘小游戏
    本人主要介绍如何在微信小程序里面开发一个幸运转盘的小游戏,里面主要用到javascript和 css 语法,就可以轻松实现一个简单的幸运转盘(以6个奖品区为例)。 前言 本次教程需...
    99+
    2022-11-12
  • 微信小程序如何实现幸运大转盘功能
    这篇文章给大家分享的是有关微信小程序如何实现幸运大转盘功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。一、项目展示幸运大转盘是一个简单的抽奖小程序参与用户点击抽奖便可抽取轮盘的奖品二、抽奖页抽奖页是一个大轮盘和...
    99+
    2023-06-29
  • 微信小程序实现幸运大转盘功能的示例代码
    目录一、项目展示二、抽奖页三、领奖页一、项目展示 幸运大转盘是一个简单的抽奖小程序 参与用户点击抽奖便可抽取轮盘的奖品 二、抽奖页 抽奖页是一个大轮盘和活动规则 页面形式简单 主要...
    99+
    2022-11-13
  • 怎么用Javascript实现一个转盘小游戏
    本篇内容主要讲解“怎么用Javascript实现一个转盘小游戏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Javascript实现一个转盘小游戏”吧!前...
    99+
    2022-10-19
  • 微信小程序怎么实现抽奖大转盘
    这篇“微信小程序怎么实现抽奖大转盘”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“微信小程序怎么实现抽奖大转盘”文章吧。界面就...
    99+
    2023-06-26
  • 在微信小程序中跳转到另一个小程序(多种实现方式)
    今天在项目中刚好遇到一个到从当前小程序中跳转到另一个小程序,下面分享一下我总结的几个比较简单的跳转方式吧。 方式一: 1.配置要跳转的appid和小程序页面路径 wx.navigateToMiniProgram({ appId: '目...
    99+
    2023-08-16
    小程序 微信小程序
  • 如何实现一个微信小程序仪表盘组件
    小编给大家分享一下如何实现一个微信小程序仪表盘组件,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!前言最近开发了一个小程序动态仪表...
    99+
    2022-10-19
  • 怎么在微信小程序中实现一个导航功能
    本篇文章给大家分享的是有关怎么在微信小程序中实现一个导航功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。操作步骤申请腾讯地图key——地址小程序后台添加腾讯插件——开发文档小...
    99+
    2023-06-08
  • 怎么在微信小程序中实现一个Tab切换效果
    这篇文章给大家介绍怎么在微信小程序中实现一个Tab切换效果,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。使用步骤代码如下(示例):定义一个状态statusdata: {   st...
    99+
    2023-06-15
  • 怎么在微信小程序中实现一个视频弹幕效果
    本篇文章为大家展示了怎么在微信小程序中实现一个视频弹幕效果,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。wxml代码<!--pages/study/video/videoplay/videop...
    99+
    2023-06-14
  • 怎么在微信小程序中实现一个文字滚动功能
    怎么在微信小程序中实现一个文字滚动功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。具体内容如下wxml:<view>显示完后再显示:</vi...
    99+
    2023-06-14
  • 微信小程序中怎么实现一个搜索框组件
    今天就跟大家聊聊有关微信小程序中怎么实现一个搜索框组件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。search.wxml<view ...
    99+
    2022-10-19
  • 微信小程序中怎么实现一个计算器功能
    微信小程序中怎么实现一个计算器功能,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。目录结构第一次进到页面它的目录结构如下:需要注意的问题(1)添加的新页面文件,都...
    99+
    2023-06-20
  • 微信小程序怎么实现一个手写签名组件
    这期内容当中小编将会给大家带来有关微信小程序怎么实现一个手写签名组件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。背景:在做项目过程中,需要在微信小程序中实现手写签名组件。在网上找了微信小程序手写签名实现...
    99+
    2023-06-20
  • 微信小程序怎么实现返回上一页
    这篇文章主要介绍了微信小程序怎么实现返回上一页的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇微信小程序怎么实现返回上一页文章都会有所收获,下面我们一起来看看吧。一、方法罗列函数说明navigator保留当前页面...
    99+
    2023-07-02
  • 微信小程序怎么实现页面跳转传值
    小编给大家分享一下微信小程序怎么实现页面跳转传值,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!微信小程序 页面跳转传值实现代码微...
    99+
    2022-10-19
  • 微信小程序怎么实现旋转木马效果
    这篇文章主要介绍“微信小程序怎么实现旋转木马效果 ”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“微信小程序怎么实现旋转木马效果 ”文章能帮助大家解决问题。文章涉及技术点微信小程序原生Swiper控件...
    99+
    2023-06-26
  • 微信小程序怎么实现页面跳转功能
    这篇“微信小程序怎么实现页面跳转功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“微信小程序怎么实现页面跳转功能”文章吧。实...
    99+
    2023-07-05
  • 微信小程序中怎么实现一个picker多列选择器
    微信小程序中怎么实现一个picker多列选择器,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、效果图(多列)二、普通选择器:mode = selector、多列选择器:m...
    99+
    2023-06-20
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作