别踩白块游戏小程序

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

  • 云数据库:存储小程序数据表的信息。

  • 用户验证:小程序使用MemFire Cloud提供的用户认证的API接口,快速完成用户注册登录操作。

  • 即时API:创建数据表时会自动生成 API。

img

创建应用

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

登录https://cloud.MemFiredb.com/auth/login, 在“我的应用”页面创建一个新应用

img

创建数据表

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

1.创建gamer表#

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

名称类型描述
idint8主键,自增,唯一标识ID
user_nametext用户名(唯一)
created_attimetamptz创建时间
get_started_highscoreint8手残模式最高分数(可空)
classic_highscoreint8经典模式最高分数(可空)
extreme_speed_highscoreint8极速模式最高分数(可空)

建表页面配置:

img

sql操作如下:

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

2.创建get_started表#

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

名称类型描述
idint8主键,自增,唯一标识ID
user_nametext用户名
created_attimeatamptz创建时间
scoreint8游戏分数

建表页面配置:

img

sql操作如下

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

3.创建classic表#

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

名称类型描述
idint8主键,自增,唯一标识ID
user_nametext用户名
created_attimeatamptz创建时间
scoreint8游戏分数

建表页面配置:

img

sql操作如下

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

4.创建extreme_speed表#

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

名称类型描述
idint8主键,自增,唯一标识ID
user_nametext用户名
created_attimeatamptz创建时间
scoreint8游戏分数

建表页面配置:

img

sql操作如下

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

注册小程序

以上是我们在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。

img

构建npm#

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

img

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

1npm init
2npm install

img

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

1npm install supabase-wechat-stable

点击开发者工具中的菜单栏:工具 /构建 npm

img

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

img

获取 API密钥#

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

lib/supabase.js

1import { createClient } from 'supabase-wechat-stable'
2const url = ""
3const key = ""
4
5export const supabase = createClient(url, key)

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

img

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

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

编译小程序

先进行小程序注册,注册完成后就可以畅玩游戏并保存游戏数据,查看比赛排名

img

请扫码体验

img