签到(CocosCreator)

简介: 签到(CocosCreator)
推荐阅读:

1.前沿

      签到模块几乎是每个游戏必不可少的模块,它存在的目的主要是为了让玩家坚持每天上线,给予这些玩家一定的奖励,从而保证游戏留存率。
      今天来给大家讲讲签到模块的实现,并提供一些优质的方法,实现某些功能。先说说我们的需求吧,需要显示整月每日的签到奖励信息,签到情况。为了美观,将其设计为上下滑动可查看当月整体情况。

2.UI界面

      1.添加一个ScrollView,命名为signScrollView,调整合适大小,设置ScrollView属性如下:
在这里插入图片描述
      主要注意取消勾选Horizantol(即取消水平滑动,允许垂直滑动,该功能可根据实际情况修改)
      2.同时调整ScrollView下的View大小,和ScrollView大小保持一直,表示显示窗口大小。
      3.为View下的content添加Layout组件,选择类型为GRID,并设置Padding的属性,即content下面的item距离content上下左右的间距,同事设置每个item之间的上下间距(Spaceing X),左右间距(Spaceing Y):在这里插入图片描述

3.签到按钮添加监听事件

self.findBtn("btn_sign", uiRoot.bottom, () => {
     //签到处理
     }
 })
AI 代码解读

4.服务器端数据处理

服务器端使用一个Int32位的数存储传输当月签到情况
// 用位操作表示签到情况(d=月中第几天;第d天是否签到=(signDay & (1<<(d-1))) == 1)
int32 signDay = 4;

        //data.signDay服务器数据(int32)
        var str = data.signDay.toString(2).split('');//将int32转换位二进制数字符串,进而保存位数组
        cc.log("逆序日期数组", str);
        var dayArr = str.reverse().join('').split('');//将该数组逆序排列
        cc.log("正序日期数组", dayArr );
        //上面的操作是为了调试输出的日志,可注释
        
        for (let i = 0; i < this.monthDays; i++) {
            if ((data.signDay & (1 << i)) == 1) {
                //已签到
            } else {
                //未签到
            }
        }
AI 代码解读

4.结束语

      使用一个int32位的数代替传统的签到数组,既能提高传输速率,也能降低内存的消耗,第一次使用该方法来实现数据的传输与保存,特意记录下来分享给大家。

目录
打赏
0
0
0
0
6
分享
相关文章
Android JNI 报错(signal 6 (SIGABRT), code -1 (SI_QUEUE), fault addr )
Android JNI 报错(signal 6 (SIGABRT), code -1 (SI_QUEUE), fault addr )
1712 1
【小程序】报错:no such file or directory, access ‘wxfile://usr/miniprogramLog/log2‘
【小程序】报错:no such file or directory, access ‘wxfile://usr/miniprogramLog/log2‘
2067 0
Java中对象几种类型的内存分配(JVM对象储存机制)
Java中对象几种类型的内存分配(JVM对象储存机制)
182 5
Java中对象几种类型的内存分配(JVM对象储存机制)
claude3.5官网入口 - Claude3.5 Sonnet国内使用教程
在这个信息爆炸的时代 💥,我们每天都被海量的数据和信息包围 🌊。如何高效地处理信息、获取知识、提升效率,成为了现代人面临的巨大挑战 💪
【cocos 2d微信小游戏开发教程】基础使用笔记分享(一)
【cocos 2d微信小游戏开发教程】基础使用笔记分享(一)
340 0
cocos 2.4*项目实战笔记及源码分享 —— 飞机大战小游戏
cocos 2.4*项目实战笔记及源码分享 —— 飞机大战小游戏
310 0
深入理解CSS过渡效果(Transition):提升网页动画体验
深入理解CSS过渡效果(Transition):提升网页动画体验
493 1
MATLAB | 插值算法 | 一维interpn插值法 | 附数据和出图代码 | 直接上手
MATLAB | 插值算法 | 一维interpn插值法 | 附数据和出图代码 | 直接上手
663 0
CocosCreator 面试题(八)Cocos Creator 中如何做资源管理
CocosCreator 面试题(八)Cocos Creator 中如何做资源管理
885 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问