开发一个数字华容道的小游戏

2024-02-29 08:08

本文主要是介绍开发一个数字华容道的小游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目的

上周新一期的最强大脑出来了,虽然上季被称为最强黑幕,不过呢。我决定还是看看= =。它里面第一关是叫做数字华容道。说白了,就是和拼图差不多。一开始我准备下一个玩玩的。结果没搜到。所以决定写了一个。最后效果差不多是这样:
这里写图片描述

思路以及实现

首先,我们应该考虑如何去实现这个效果。细想一下,其实和之前的2048有点像,但是又不是完全一直。于是,便又折腾了一波。这次布局和内容项参考之前2048的,下面放上代码:

自定义一个frame layout,我们先绘制里面的数字:

 private void initial() {label = new TextView(getContext());label.setTextSize(32);label.setBackgroundColor(0x33ff0033);label.setTextColor(0x330D0D0D);label.setGravity(Gravity.CENTER);LayoutParams lp = new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT);lp.setMargins(10, 10, 0, 0);addView(label, lp);setNum(0);}public int getNum() {return num;}@SuppressLint("SetTextI18n")public void setNum(int num) {this.num = num;if (num <= 0) {label.setText("");} else {label.setText(num + "");}}

我们可以看到上面的数字在3x3中,我们显示1-8。不过通过代码我们可以知道,其实我们是去生成0-8,然后把0的那块内容设为空。

那么我们在想一下,是滑动移动还是点击移动。以现在体验的角度,滑动移动会更方便一点。所以我们需要监听它的滑动事件:

         setOnTouchListener(new View.OnTouchListener() {private float startX, startY, changeX, changeY;@SuppressLint("ClickableViewAccessibility")@Overridepublic boolean onTouch(View v, MotionEvent event) {switch (event.getAction()) {case MotionEvent.ACTION_DOWN:startX = event.getX();startY = event.getY();break;case MotionEvent.ACTION_UP:// 改变的X坐标=现在的-起始的changeX = event.getX() - startX;// 改变的Y坐标=现在的-起始的changeY = event.getY() - startY;// 若X的绝对值>Y的绝对值,则是左右移动,否则为上下移动,左上角坐标为(0,0)if (Math.abs(changeX) > Math.abs(changeY)) {if (changeX < -PADDING) {left();} else if (changeX > PADDING) {right();}} else {if (changeY < -PADDING) {up();} else if (changeY > PADDING) {down();}}break;default:}return true;}});

但是我们需要在滑动之前先生成所有的随机数。也就是1-N生成N个随机数。

        public int[] randomCommon(int max, int n) {if (n > (max + 1) || max < 0) {return null;}int[] result = new int[n];int count = 0;while (count < n) {int num = (int) (Math.random() * max) + 1;boolean flag = true;for (int j = 0; j < n; j++) {if (num == result[j]) {flag = false;break;}}if (flag) {result[count] = num;count++;}}return result;}

数字生成完成之后,我们需要把数据放入之前写的Card并且add到现在的GridLayout中。

        private void addCard(int cardWidth, int cardHeight) {Card card;int sum = 0;for (int x = 0; x < addNumber; x++) {for (int y = 0; y < addNumber; y++) {card = new Card(getContext());card.setNum(number[sum] - 1);addView(card, cardWidth, cardHeight);point[x][y] = card;sum++;}}}

数据生成了,内容也显示了,接下来我们需要做的就是对方向的逻辑处理。这边我放一个,其他的同理:

      for (int x = 0; x < addNumber; x++) {for (int y = 0; y < addNumber; y++) {if (x - 1 >= 0) {if (point[x - 1][y].getNum() == 0) {point[x - 1][y].setNum(point[x][y].getNum());point[x][y].setNum(0);isFinish();return;}}}}

如果有人看过之前的2048会发现这边的判断更简单一些,然后我们每次滑动结束,我们需要判断游戏是否结束。如果游戏结束就给它一个提示,是重新来过还是直接下一关:

       int number = 1;for (int x = 0; x < addNumber; x++) {for (int y = 0; y < addNumber; y++) {if (number == addNumber * addNumber) {MainActivity.getMainActivity().stop();new AlertDialog.Builder(getContext()).setTitle("游戏结束!").setMessage("您的时间是:" + MainActivity.getMainActivity().getTimer()).setPositiveButton("重来",new DialogInterface.OnClickListener() {public void onClick(DialogInterface dialog,int which) {MainActivity.getMainActivity().clear();start();}}).setNegativeButton("下一关",new DialogInterface.OnClickListener() {public void onClick(DialogInterface dialog,int which) {MainActivity.getMainActivity().clear();addNumber();}}).show();return;}if (point[x][y].getNum() == number) {number++;}}}

这样基本所有的逻辑就写完了。具体代码我已经上传到github中:https://github.com/sw950729/NumKlotski

最后

我也试着去玩一玩,里面我也写了计时,我记得我3x3最好成绩是42秒,4x4最好成绩是一分四十。大家可以试一下。你最好能玩到多少。里面我也做了上下限的判断,最低三阶,最高八阶。你们可以试试看能不能通关~

这篇关于开发一个数字华容道的小游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

这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

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

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

usaco 1.2 Name That Number(数字字母转化)

巧妙的利用code[b[0]-'A'] 将字符ABC...Z转换为数字 需要注意的是重新开一个数组 c [ ] 存储字符串 应人为的在末尾附上 ‘ \ 0 ’ 详见代码: /*ID: who jayLANG: C++TASK: namenum*/#include<stdio.h>#include<string.h>int main(){FILE *fin = fopen (

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

【区块链 + 人才服务】区块链集成开发平台 | FISCO BCOS应用案例

随着区块链技术的快速发展,越来越多的企业开始将其应用于实际业务中。然而,区块链技术的专业性使得其集成开发成为一项挑战。针对此,广东中创智慧科技有限公司基于国产开源联盟链 FISCO BCOS 推出了区块链集成开发平台。该平台基于区块链技术,提供一套全面的区块链开发工具和开发环境,支持开发者快速开发和部署区块链应用。此外,该平台还可以提供一套全面的区块链开发教程和文档,帮助开发者快速上手区块链开发。

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧