应用实战 | 别踩白块小游戏,邀请大家来PK挑战~

“踩白块会输”是一个简单的微信小程序游戏,灵感来自当年火热的别踩白块游戏,程序内分成三个模块:手残模式、经典模式和极速模式,分别对应由易到难的三种玩法,可以查看游戏排名。动画效果采用JS实现,小程序后端服务使用了MemFire Cloud,其中使用到的MemFire Cloud功能包括:

  • 云数据库:存储小程序数据表的信息。
  • 用户验证:小程序使用MemFire Cloud提供的用户认证的API接口,快速完成用户注册登录操作。
  • 即时API:创建数据表时会自动生成 API。

暂时无法在飞书文档外展示此内容

创建应用

目的:通过创建的一个MemFire Cloud应用来获得数据库、云存储等一系列资源,并将获得该应用专属的API访问链接和访问密钥,用户可以轻松的调用API接口与以上资源进行交互。

登录MemFire Cloud, 在“我的应用”页面创建一个新应用

在这里插入图片描述

创建数据表

点击进入应用详情页面,在“数据表”页面可视化建表。

1.创建gamer表

在数据表页面,点击“新建数据表”,创建gamer表。gamer表主要记录游戏玩家信息和各个游戏模式的最高分信息,表结构字段如下:

名称 类型 描述
id int8 主键,自增,唯一标识ID
user_name text 用户名(唯一)
created_at timetamptz 创建时间
get_started_highscore int8 手残模式最高分数(可空)
classic_highscore int8 经典模式最高分数(可空)
extreme_speed_highscore int8 极速模式最高分数(可空)

sql操作如下:

CREATE TABLE "public"."gamer" ( 
  "id" SERIAL,
  "created_at" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT '2022-09-16 15:23:36.89768+08'::timestamp with time zone ,
  "user_name" TEXT NOT NULL,
  "get_started_highscore" BIGINT NULL,
  "classic_highscore" BIGINT NULL,
  "extreme_speed_highscore" BIGINT NULL,
  CONSTRAINT "gamer_pkey" PRIMARY KEY ("id")
);

2.创建get_started表

在数据表页面,点击“新建数据表”,创建get_started表。get_started表主要记录手残模式的游戏记录数据,表结构字段如下:

名称 类型 描述
id int8 主键,自增,唯一标识ID
user_name text 用户名
created_at timeatamptz 创建时间
score int8 游戏分数

sql操作如下

CREATE TABLE "public"."get_started" ( 
  "id" SERIAL,
  "created_at" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT '2022-09-16 14:58:11.998301+08'::timestamp with time zone ,
  "user_name" TEXT NOT NULL,
  "score" BIGINT NOT NULL,
  CONSTRAINT "get_started_pkey" PRIMARY KEY ("id")
);

3.创建classic表

在数据表页面,点击“新建数据表”,创建classic表。classic表主要记录经典模式游戏的数据,表结构字段如下:

名称 类型 描述
id int8 主键,自增,唯一标识ID
user_name text 用户名
created_at timeatamptz 创建时间
score int8 游戏分数

sql操作如下

CREATE TABLE "public"."classic" ( 
  "id" SERIAL,
  "created_at" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT '2022-09-16 14:59:40.159136+08'::timestamp with time zone ,
  "user_name" TEXT NOT NULL,
  "score" BIGINT NOT NULL,
  CONSTRAINT "classic_pkey" PRIMARY KEY ("id")
);

4.创建extreme_speed表

在数据表页面,点击“新建数据表”,创建extreme_speed表,extreme_speed表主要记录极速模式游戏数据,表结构字段如下:

名称 类型 描述
id int8 主键,自增,唯一标识ID
user_name text 用户名
created_at timeatamptz 创建时间
score int8 游戏分数

sql操作如下

CREATE TABLE "public"."extreme_speed" ( 
  "id" SERIAL,
  "created_at" TIMESTAMP WITH TIME ZONE NOT NULL DEFAULT '2022-09-16 15:01:07.838302+08'::timestamp with time zone ,
  "user_name" TEXT NOT NULL,
  "score" BIGINT NOT NULL,
  CONSTRAINT "extreme_speed_pkey" PRIMARY KEY ("id")
);

注册小程序

以上是我们在MemFire Cloud上配置的全部步骤,接下来是在微信开发者工具上操作了。

如果您还未注册过小程序,请参考官方步骤注册小程序(只需要通过您的邮箱注册一个小程序获得一个appid,然后下载一个微信开发工具即可)

下载代码

模板代码:git@github.com:LucaRao/Don-t-step-on-the-white-demo.git

完整代码:https://github.com/LucaRao/Don-t-step-on-the-white.git

Node.js (>=14.x <=16.x) 。

开发环境配置

选择目录是下载好的小程序项目的目录,AppID为您在微信公众平台注册小程序获得的专属appid。
在这里插入图片描述

构建npm

在右侧详情里面的本地设置把“使用npm模块”和“不校验合法域名”勾上。

在这里插入图片描述

打开终端,在项目根目录下执行如下命令 。

npm init
npm install

在这里插入图片描述

接下来,下载小程序需要的MemFire Cloud的微信小程序SDK。

npm install supabase-wechat-stable

点击开发者工具中的菜单栏:工具 /构建 npm
在这里插入图片描述

这一步npm就构建完成了,我们需要的依赖也已经下载好了,根目录下会多出两个文件,如下图。

在这里插入图片描述

获取 API密钥

接下来需要创建一个可以访问应用程序数据的客户端,小程序使用了Supabase 微信小程序SDK包,使用他生态里提供的功能(登录、注册、增删改查等)去进行交互。创建一个可以访问微信小程序数据的客户端需要接口的地址(URL)和一个数据权限的令牌(ANON_KEY),我们需要去应用的概览里面去获取这两个参数然后配置到lib/supabase.ts里面去。

lib/supabase.js

import { createClient } from 'supabase-wechat-stable'
const url = ""
const key = ""

export const supabase = createClient(url, key)

回到MemFire Cloud首页,在应用/概括页面,获取服务地址以及token信息,只需要从总览中获取URL接口地址和anon的密钥。
在这里插入图片描述

Anon(公开)密钥是客户端API密钥。它允许“匿名访问”您的数据库,直到用户登录。登录后,密钥将切换到用户自己的登录令牌。这将为数据启用行级安全性。

注意:service_role密钥可以绕过任何安全策略完全访问您的数据。这些密钥必须保密,并且要在服务器环境中使用,绝不能在客户端或浏览器上使用。 在后续示例代码中,需要提供supabaseUrl和supabaseKey。

编译小程序

先进行小程序注册,注册完成后就可以畅玩游戏并保存游戏数据,查看比赛排名
在这里插入图片描述

相关推荐

  1. Python代码篇-必会(猜数字游戏)

    2024-04-29 00:16:03       37 阅读
  2. Unreal Engine游戏引擎入门指南

    2024-04-29 00:16:03       11 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-29 00:16:03       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-29 00:16:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-29 00:16:03       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-29 00:16:03       20 阅读

热门阅读

  1. 调用Oracle函数怎么把大于32k的json保存进数据库

    2024-04-29 00:16:03       10 阅读
  2. Docker 备忘清单(一)

    2024-04-29 00:16:03       13 阅读
  3. ts和js的区别

    2024-04-29 00:16:03       13 阅读
  4. 实验报告4-MyBatis与Spring的整合

    2024-04-29 00:16:03       12 阅读
  5. Fiddlers使用

    2024-04-29 00:16:03       13 阅读
  6. Android Native Hook: 原理、方案对比与具体实现

    2024-04-29 00:16:03       12 阅读
  7. 将mysql转为oracle

    2024-04-29 00:16:03       14 阅读
  8. LeetCode题练习与总结:组合-77

    2024-04-29 00:16:03       12 阅读
  9. new qemu QEMU_OPTION_d

    2024-04-29 00:16:03       14 阅读
  10. 笨蛋学C++【C++基础第八弹】

    2024-04-29 00:16:03       15 阅读