|
要做這個好友排行榜.必然要有好友的戰(zhàn)績比分,然后再做排序,最后將數(shù)據(jù)呈現(xiàn)在UI上 , 可以分為下面幾個步驟:
保存每個用戶的分數(shù)保存每個用戶的分數(shù),需要調(diào)用微信的云存儲API,將用戶的分數(shù)持久化的存起來 . // 保存用戶數(shù)據(jù),注意限制單條數(shù)據(jù)容量不得超過1024字節(jié), // 單個用戶數(shù)據(jù)總條數(shù)不得超過128條 wx.setUserCloudStroage(Object)復(fù)制代碼
//存儲最高分
var score = 100;
var kvScore = {"key":"score","value":score};
wx.setUserCloudStroage({"KVDataList":[kvScore]},"success":function(){
//
});復(fù)制代碼
獲取好友列表,并獲取好友的分數(shù)? 游戲中將玩家的分數(shù)保存起來以后,需要調(diào)用微信的云存儲API wx.getFirendCloudStorage, 獲取玩家的微信好友數(shù)據(jù),這樣就拿到了每個好友的最高分. 值得一提的是,微信的這個接口在內(nèi)部隱蔽的使用其微信的社交關(guān)系鏈 . 返回列表中的包含的 調(diào)用過wx.setUserCloudStroage 這個接口的用戶.
渲染排行榜對分數(shù)進行排序 , 得到一個排行榜
let sharedCanvas = wx.getSharedCanvas()
function drawRankList (data) {
data.forEach((item, index) => {
// ...
})
}
wx.getFriendCloudStorage({
success: res => {
let data = res.data
drawRankList(data)
}
})復(fù)制代碼
注意這個 sharedCanvas , 這是獨有的畫布 ,與小游戲中的畫布不是同一個東東.
使用sharedCanvas來自定義顯示玩家的用戶排行榜 重要說明
? 上述所涉及的微信接口 , 都只能在微信小游戲的 子域 使用 , 微信官網(wǎng)也稱之為開放數(shù)據(jù)域 , 其實應(yīng)該稱之為 封閉數(shù)據(jù)域 . |