第一次使用Egret开发微信小游戏经验总结(包括排行榜排序,每周一数据清零,超越好友等处理)

本文主要是介绍第一次使用Egret开发微信小游戏经验总结(包括排行榜排序,每周一数据清零,超越好友等处理),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转自:https://blog.csdn.net/xw1110280055/article/details/82469825

最近项目组立项了个小游戏,用Egret(白鹭)开发,本来游戏核心功能2天就完成了,后来准备接入微信好友排行榜的时候,用到了子域,加入分享给好友的时候,图片合成后分享给微信好友有时候不能显示出图片内容。现整理一下,避免大家踩坑。
好友排行榜微信只让我们在开放数据域(后文都简称为”子域”)里面操作(毕竟这是人家最重要最值钱的数据了,不会让我们拿来随便用的),小游戏做好后,想加入排行榜和超越好友等功能,白鹭官方也给出了详细的教程了。目前官网的demo排行榜是分页的,点击查看下一页数据,不能像scrollView那样滚动展示数据,不是我想要的,我看了下其他人做的,说可以用一个项目做游戏,一个项目专门放排行榜,放排行榜的项目直接导出到游戏项目的openDataContext文件夹下。我也试着操作了下,发现坑有点难踩,遇到了个wx.getFileSystemManager not function的错误,后面发现在5.2.2中,使用assetsmananger而不是res,解决方案。而且这样会多引入一次egret和game库,其实好像也就多几百KB而已。第一种方案;这里我着重说一下另外一个方案,就是目前官方demo那种,在js里面直接用canvas做出类似于scrollView那种滚动效果,其实就是监听下Y轴滑动距离,根据滑动距离来处理canvas的位置。
想要排行榜有数据,就先上传用户数据到微信后台,就是托管数据。我是在比赛结束的时候发送一个消息给子域,此消息带上用户分数。

   platform["openDataContext"].postMessage({command: 'updateMaxScore',myScore: _myScore});
    然后在子域的index.js里面监听并处理这个消息
  •  
else if (data.command == 'updateMaxScore') {if (myCurrentScore <= data.myScore) {setUserCloudStorage(data.myScore);}getFriendCloudInfo();
}
  •  
这个setUserCloudStorage加了个上传时间的操作,用于之后通过时间来处理周一数据清零的操作,后面会贴上完整代码。上传新分数后再通过getFriendCloudInfo拿新数据并过滤排序。在排行榜界面先创建一个离屏canvas
  •  
let bitmap_rank = platform["openDataContext"].createDisplayObject(null,this.stageW, rank_item_bg_Group.height, 0);
bitmap_rank.y = 80;
rank_item_bg_Group.addChild(bitmap_rank);
  •  
 效果如下图
  •  

这里写图片描述
rank_item_bg_Group就是图中绿色框部分,在这个上面添加canvas,方便位置调整。然后传消息给后台根据是否有shareTicket来显示是好友排行榜还是群排行榜。

        let delayTime = 0;if(game.myShareTicket != undefined && game.myShareTicket != ""){delayTime = 1000;}setTimeout((e)=> {platform["openDataContext"].postMessage({command: "open",shareTicket: game.myShareTicket});}, delayTime);

如果是打开群排行榜,则需要延时来处理群排行榜数据。子域对应消息处理如下:

    if (data.command == 'open') {//创建并初始化startIndex = 0;if (data.shareTicket && data.shareTicket != "") {getGroupCloudStorage(data.shareTicket);setTimeout((e) => {createScene();createMyScene();}, 500);} else {createScene();createMyScene();}} 

createScene创建的是除图上红色框之外的排行榜内容,createMyScene创建的是我的内容,就是红色框那块,其实可以合并到一起的,后期再整理一下。微信头像和图片一样做一下预加载,先拿到头像数据保存起来,再预加载。

function preloadAvatarUrl() {let preloaded = 0;let count = 0;for (let asset in avatarUrlList) {count++;const img = wx.createImage();img.onload = () => {preloaded++;if (preloaded == count) {// console.log("头像加载完成");hasLoadRes = true;}}// console.log("src:" + avatarUrlList[asset] + " asset:" + asset);img.src = avatarUrlList[asset];assetsAvatarUrl[asset] = img;}
}
  •  

这个是给排行榜排序,根据用户分数做降序处理。

//给排行榜排序(降序)
var compare = function (prop) {return function (obj1, obj2) {var val1 = obj1[prop];var val2 = obj2[prop];var int1 = val1[0]["value"];var int2 = val2[0]["value"];if (!isNaN(Number(int1)) && !isNaN(Number(int2))) {int1 = Number(int1);int2 = Number(int2);}if (int1 < int2) {return 1;} else if (int1 > int2) {return -1;} else {return 0;}}
}

这个是根据上传分数时带的时间戳判断分数是否是同一周,大致思路是首先新的天数要大于老的天数,周日的天数通过getDay()获取到时是0,转为7,方便处理,然后天数不同通过时间戳差值判断是否在一周内,如果天数相同则判断差值是否在一天内,防止这周一早上10点和下周一早上9点被判断成一周。

//判断是否是同一周
function isSameWeek(oldTime) {oldTime = parseInt(oldTime);var newTime = new Date().getTime();let oneDayTime = 60 * 60 * 24 * 1000;// console.log("now:" + newTime + " old:" + oldTime + " off:" + (newTime - oldTime) + " one:" + (oneDayTime * 7))let oldDate = new Date(oldTime);let newDate = new Date(newTime);let oldDay = oldDate.getDay();let newDay = newDate.getDay();if (newDay == 0) {newDay = 7;}if (oldDay == 0) {oldDay = 7;}let isSame = false;if (oldDay < newDay) {if ((newTime - oldTime) < oneDayTime * 7) {  // 时间相差小于7isSame = true;}} else if (oldDay == newDay) {if ((newTime - oldTime) < oneDayTime) {isSame = true;}}return isSame;
}

platform.js里面也改造了下

    createDisplayObject(type, width, height,offsetY) {sharedCanvas.width = width;sharedCanvas.height = height;const bitmapdata = new egret.BitmapData(sharedCanvas);bitmapdata.$deleteSource = false;const texture = new egret.Texture();texture._setBitmapData(bitmapdata);const bitmap = new egret.Bitmap(texture);bitmap.width = width;bitmap.height = height;bitmap.y = offsetY;if (egret.Capabilities.renderMode == "webgl") {const renderContext = egret.wxgame.WebGLRenderContext.getInstance();const context = renderContext.context;需要用到最新的微信版本调用其接口WebGLRenderingContext.wxBindCanvasTexture(number texture, Canvas canvas)如果没有该接口,会进行如下处理,保证画面渲染正确,但会占用内存。if (!context.wxBindCanvasTexture) {egret.startTick((timeStarmp) => {egret.WebGLUtils.deleteWebGLTexture(bitmapdata.webGLTexture);bitmapdata.webGLTexture = null;return false;}, this);}}return bitmap;}

排行榜好友我是只显示7个,根据Y轴滑动距离来判断显示哪7个数据就行,具体方法看后面代码,写的太多了,大家不一定有耐心看了,好久没写博客,有点乱,好像拆开写比较合适啊。

下面是index.js详细代码,贴了全部代码,发现显示不了那么多。就当附件传上来吧,附件找不到在哪里传,就先直接上传到资源里吧index.js顺便贴几张子域效果图。
这里写图片描述这里写图片描述

20180907补充:
子域的数据可以传给主域了,一个qq群里同学说的,验证了下,的确可以,现分享给大家。
在子域里获取到排行榜数据后,userDataList保存数据然后如下写法:

      let openContext = wx.getSharedCanvas().getContext("2d");openContext["canvas"]["userDataList"] = JSON.stringify(userDataList);

在主域里通过如下写法可以拿到子域保存的排行榜数据,这些就可以在主域直接用ScrollView了,哎,发现的有点晚了啊。

        let openContext = wx.getOpenDataContext();let friendDataList:any;if(openContext["canvas"]["userDataList"]){friendDataList = JSON.parse(openContext["canvas"]["userDataList"]);}console.log("openContext");console.log(openContext);console.log("friendDataList");console.log(friendDataList);

这里写图片描述

 

这篇关于第一次使用Egret开发微信小游戏经验总结(包括排行榜排序,每周一数据清零,超越好友等处理)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1110564

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

W外链微信推广短连接怎么做?

制作微信推广链接的难点分析 一、内容创作难度 制作微信推广链接时,首先需要创作有吸引力的内容。这不仅要求内容本身有趣、有价值,还要能够激起人们的分享欲望。对于许多企业和个人来说,尤其是那些缺乏创意和写作能力的人来说,这是制作微信推广链接的一大难点。 二、精准定位难度 微信用户群体庞大,不同用户的需求和兴趣各异。因此,制作推广链接时需要精准定位目标受众,以便更有效地吸引他们点击并分享链接

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo