白鹭引擎开发微信小游戏: API 调用教程文档

如何在 Egret 中调用小游戏 API
在 Egret 中是可以直接调用小游戏的 API 的,这篇文档简要介绍如何在 Egret 中使用小游戏的 API。
新增 platform.ts 文件
 
在 src 下新增 platform.ts,代码如下

1.    /** 
2.    * 平台数据接口。
3.    * 由于每款游戏通常需要发布到多个平台上,所以提取出一个统一的接口用于开发者获取平台数据信息
4.    * 推荐开发者通过这种方式封装平台逻辑,以保证整体结构的稳定
5.    * 由于不同平台的接口形式各有不同,白鹭推荐开发者将所有接口封装为基于 Promise 的异步形式
6.    */
7.    declare interface Platform {
8.    
9.        getUserInfo(): Promise<any>;
10.    
11.        login(): Promise<any>
12.    
13.    }
14.    
15.    class DebugPlatform implements Platform {
16.        async getUserInfo() {
17.            return { nickName: "username" }
18.        }
19.        async login() {
20.    
21.        }
22.    }
23.    
24.    
25.    if (!window.platform) {
26.        window.platform = new DebugPlatform();
27.    }
28.    
29.    
30.    
31.    declare let platform: Platform;
32.    
33.    declare interface Window {
34.    
35.        platform: Platform
36.    }

这样就可以在 Egret 项目中使用 platform 里的方法了。但是如果我们当前的项目想要发布成 H5 游戏的话也不会报错,保证整个项目的兼容性。
新增 platform.js 文件


通过文末的 小游戏 API 文档,我们可以方便的查看使用小游戏 API。
 
我们 platform.js 代码编写如下

1.    /**
2.    * 请在白鹭引擎的Main.ts中调用 platform.login() 方法调用至此处。
3.    */
4.    
5.    class WxgamePlatform {
6.    
7.        name = 'wxgame'
8.    
9.        login() {
10.            return new Promise((resolve, reject) => {
11.                wx.login({
12.                    success: (res) => {
13.                        resolve(res)
14.                    }
15.                })
16.            })
17.        }
18.    
19.        getUserInfo() {
20.            return new Promise((resolve, reject) => {
21.                wx.getUserInfo({
22.                    withCredentials: true,
23.                    success: function (res) {
24.                        var userInfo = res.userInfo
25.                        var nickName = userInfo.nickName
26.                        var avatarUrl = userInfo.avatarUrl
27.                        var gender = userInfo.gender //性别 0:未知、1:男、2:女
28.                        var province = userInfo.province
29.                        var city = userInfo.city
30.                        var country = userInfo.country
31.                        resolve(userInfo);
32.                    }
33.                })
34.            })
35.        }
36.    }
37.    
38.    
39.    window.platform = new WxgamePlatform();

上述代码使用了小游戏的登陆 API,只需要在 Egret 项目中调用 platform.login() 方法即可。

引入 platform.js
但是在真正运行之前还需要将 platform.js 文件引入进去
 
调用小游戏的 API
 
最后只需要在你需要的地方添加方法就可了,搞定!
 
运行发现没有效果,因为我刚才已经登陆过了,所以选择清除登录状态。
 
然后运行,搞定!
小结
因为上述过程 5.1.2 版本都已经集成,项目默认会有一个登陆方法的示例,大家可以按照示例使用其它的小游戏 API,为了保证最好的体验我们元旦回来后再进行更新,感谢大家一直以来的支持。
小游戏 API 调用注意事项
因为小游戏 API 运行需要小游戏环境,所以在 H5 上是无法直接预览的,所以你需要在「微信开发者工具」中预览效果。
 
更多 API 请查看:小游戏 API 文档

转载于:https://my.oschina.net/u/3695009/blog/1604694

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值