年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享

界面演示

图片[1]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog
图片[2]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog
图片[3]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog

在线体验

源码下载

源码安装

打开vscode,选择文件>打开文件夹

图片[4]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog

选择我们的项目lottery-web-admin

图片[5]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog

选择终端>新建终端

图片[6]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog

安装node依赖模块环境

yarn install

这里显示已经安装完成依赖了

图片[7]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog

然后,我们可以进行测试

yarn dev
图片[8]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog

然后访问localhost:9000,简直不能再炫酷了

图片[9]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog

如果都调试好了,您可以进行打包

yarn build

打包好了之后要去dist目录下去拷贝代码,然后上传到服务器

图片[10]-年会上用的抽奖系统 3D立体球体抽奖 炫酷到爆炸 源码分享-FancyPig's blog

代码修改

Mock中

参数值类型描述
userArray[Info]奖品类型,唯一标识,0 是默认特别奖的占位符,其它奖品不可使用
COMPANYstring公司名
prizesArray[Gift]奖品信息
luckyData{type:Array[Info]}中奖名单 type为奖品类型
leftUsersArray[Info]当前奖池可以抽取人员
excludeUserArray[Info]排除奖池人员述
atmosphereGroupCardString气氛组卡片
backgroundString背景图片
EACH_COUNTArray[Number]抽奖次序默认有个隐藏顺序
widthstring渲染抽奖墙宽度比例 最好按照原比例去做
heightstring渲染抽奖墙长度比例 最好按照原比例去做
bgVideostring可以放动态渲染图(mp4类型这种) 使用时会自动覆盖背景不用时请注释或者node该属性

Gift详情

/**
 * 奖品设置
 * type: 唯一标识,0是默认特别奖的占位符,其它奖品不可使用
 * count: 奖品数量
 * title: 奖品描述
 * text: 奖品标题
 * img: 图片地址
 * ROTATE_TIME:转的球速度越大越慢
 * circle:旋转圈数最好8*x倍数
 * enter: //抽奖进行时音乐
 * awards: //颁奖音乐
 */
   {
    type: 1,
    count: 1,
    text: "一等奖 ",
    title: "价值5999元",
    img: "./img/huawei.png",
    enter: "1st-lottery",//抽奖进行时音乐
    awards: "1st-BJ-BGM",//颁奖音乐
    ROTATE_TIME: 20000,
    circle: 8 * 6

  },

内置方法

插入抽奖前的方法

/**
 * @description: 不能说的秘密
 * @param {*} nowItem 当前奖品
 * @param {*} basicData 当前奖池人员
 * @return {*}
 * @Date: 2022-01-13 15:13:31
 */
function setSecret(nowItem,basicData) {
  if (nowItem.type != 4) {
    const excludeId = excludeUser.map(item => item[0])
    basicData.leftUsers = basicData.leftUsers.filter(human => !excludeId.includes(human[0]))
    // console.log(basicData.leftUsers);
  }
}

背景音乐说明

方法在index.js replaceMusic(‘enter-BGM’)进行场景音乐替换(默认格式为m4a)

参数描述
enter-BGM进场音乐
other-BJ-BGM抽奖颁奖音乐
other-lottery抽奖进行时音乐
1st-BJ-BGM抽奖颁奖音乐
1st-lottery抽奖进行时音乐
shenchou备用

动态壁纸和静态壁纸

新加入的动态属性会初始化时候判断是否设置了动态壁纸URL,这里推荐在线地址,本地路径请用相对路径去导入,如不适用动态壁纸请把属性设置为null

Store(缓存)

当页面刷新了怎么办,别担心这里做了页面数据缓存 所有数据都优先读取缓存中数据,当页面刷新时自动读取,如果没有缓存自动初始化话数据

页面逻辑

  • 抽奖=>对奖池人进行当前奖品抽奖,当再次进行抽奖时会保存上次抽奖结果到缓存中并更新luckUser和leftUser
  • 重新抽奖=>将当前抽中的人员扔回leftUser中(这里和原作者不同,原作者是直接删除了提出了刚才重抽之前人员),进行重新抽奖仍有可能抽中点重抽之前的人(当前轮)
  • 颁奖模式=>进行当前奖品的颁奖模式bgm
  • 重置=>无视一切条件进行页面重置(与原作不同)
  • 奖池每次重置都会被打乱池子顺序,优化随机算法

自行修改(需要自己二次开发)

  1. 卡片显示编号和名字(index.js)
  2. 选中颜色(index.css)
  3. 卡片背景 (index.css)
© 版权声明
THE END
喜欢就支持一下吧
点赞51赞赏 分享
评论 共1条

请登录后发表评论