Unity实现棋盘方格

本文参考:p1_哔哩哔哩_bilibili 

一、精要提炼

1、Button自带的白色底图是圆角的,Image组件自带的白色底图是方角的。

2、2D中Instantiate指定的位置为屏幕坐标系的位置,左下角为(0,0)

3、求某个组件的位置:xx.transform.position,xx为GameObject对象

4、求某个组件的width:xx.getComponent<RectTransform>().rect.width

5、设置某个组件的大小:xx.getComponent<RectTransform>().sizeDelta = new Vector2(yy, zz);

二、通过预设体创建第一个方格

效果如图:

1、设置Game屏幕分辨率为2000*3200,大致相当于一般收集的分辨率

2、创建Canvas, 命名为BoardCanvas,其参数配置如下:

3、在Canvas下创建一个Panel,命名为BoardPanel,其大小自动为Scratch填充整个Canvas

4、在Panel下创建Image,命名为Background,其参数为:

大小:1700*1700

5、在Panel下再创建一个Button作为棋盘的方格,命名为BlockButton,其下有Text和Image组件。

Button的大小:200*200

Button自带白色底图是圆角的,我们希望Button的白色底图是方角的,需要需要再添加如上所示的Image组件,其自带的白色底图是方格的。

6、在Assets下创建Prefab目录,将BlockButton放置其中。我们希望通过代码生成一个个的方格。

7、创建一个Empty物体命名为GameManager

8、创建一个C#脚本命名为BoardGameManager,并挂载到GameManager下:

public class BoardGameManager : MonoBehaviour
{[SerializeField]private GameObject blockButton;[SerializeField]private GameObject panel;private void Awake(){Instantiate(blockButton, new Vector3(0,0,0), Quaternion.identity, panel.transform);}
}

然后配置两个GameObject的信息如下:

执行代码后效果如下:

方格出现在Canvas的左下角,而不是我们想要的Panel的中间位置。

这是因为Instantiate中执行的(0,0,0)是屏幕坐标系的位置,位于屏幕的左下角,如果需要转化为Canvas中的中间位置,则需要加上canvas的坐标位置。代码修改如下:

public class BoardGameManager : MonoBehaviour
{[SerializeField]private GameObject blockButton;[SerializeField]private GameObject panel;[SerializeField]private GameObject boardCanvas;private void Awake(){GameObject button = Instantiate(blockButton, new Vector3(0,0,0), Quaternion.identity, panel.transform);button.transform.position += boardCanvas.transform.position;}
}

三、创建任意个数的方格

已知Panel中心点的局部位置为(0,0),即最外层正中心的位置。

方格分别标记为(m,n),此为序号信息,非坐标值信息。第一个为(0,0),第二个为(0,1),依次进行标记。如下图所示:

已知最外层正方形的边长为len1,空隙的长度为len2,方格的个数为count。

根据正中心的坐标值,可以求得最左上角的坐标值,进而求得每个方格中心点的坐标值。首先count为单数/双数分别推导公式,然后就会发现count单数/双数共用同一个公式。此处省略计算过程,只在代码中给出最终的结果公式。

BoardGameManager.cs完整的代码如下:

public class BoardGameManager : MonoBehaviour
{[SerializeField] private GameObject blockButton;[SerializeField] private GameObject background;[SerializeField] private GameObject panel;[SerializeField] private GameObject boardCanvas;public int count;private void Awake(){float totalLen = background.GetComponent<RectTransform>().rect.width;float gapLen = 10;if(count == 0){count = 8;}renderBoard(totalLen, gapLen, count);}/*** totalLen: background总长度* gapLen: 方格间空隙长度* count: 方格个数*/private void renderBoard(float totalLen, float gapLen, int count){float buttonLen = 1f * (totalLen - count * gapLen - gapLen) / count;for (int i = 0; i < count; i++){for (int j = 0; j < count; j++) {float poxX = 1f / 2 * (2 * i + 1 - count) * (totalLen - gapLen) / count;float poxY = 1f / 2 * (2 * j + 1 - count) * (totalLen - gapLen) / count;    Debug.Log(poxX + " " + poxY);GameObject button = Instantiate(blockButton, new Vector3(poxX, poxY, 0), Quaternion.identity, panel.transform);button.transform.position += boardCanvas.transform.position;button.GetComponent<RectTransform>().sizeDelta = new Vector2 (buttonLen, buttonLen);}}}
}

四、点击方格显示信息

首先,创建BoardButton的C#脚本,将button的属性信息存放在该类中。

public class BoardButton : MonoBehaviour
{private int posX;private int posY;public void setPos(int posX, int posY) { this.posX = posX;       this.posY = posY;}public void onClickButton(){Debug.Log(this.posX + ", " + this.posY);    }
}

然后,修改BoardGameManager.cs代码,增加记录pos的信息:

public class BoardGameManager : MonoBehaviour
{[SerializeField] private GameObject blockButton;[SerializeField] private GameObject background;[SerializeField] private GameObject panel;[SerializeField] private GameObject boardCanvas;public int count;private void Awake(){float totalLen = background.GetComponent<RectTransform>().rect.width;float gapLen = 10;if(count == 0){count = 8;}renderBoard(totalLen, gapLen, count);}/*** totalLen: background总长度* gapLen: 方格间空隙长度* count: 方格个数*/private void renderBoard(float totalLen, float gapLen, int count){float buttonLen = 1f * (totalLen - count * gapLen - gapLen) / count;for (int i = 0; i < count; i++){for (int j = 0; j < count; j++) {float poxX = 1f / 2 * (2 * i + 1 - count) * (totalLen - gapLen) / count;float poxY = 1f / 2 * (2 * j + 1 - count) * (totalLen - gapLen) / count;    Debug.Log(poxX + " " + poxY);GameObject button = Instantiate(blockButton, new Vector3(poxX, poxY, 0), Quaternion.identity, panel.transform);button.transform.position += boardCanvas.transform.position;button.GetComponent<RectTransform>().sizeDelta = new Vector2 (buttonLen, buttonLen);button.GetComponent<BoardButton>().setPos(i, j);}}}
}

最后,在BoardButton组件中配置OnClick事件函数:

此时运行程序,点击任何一个方格都会打印位置信息。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/409131.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据结构4】树的实例-模拟文件系统、二叉树的遍历(先序遍历、中序遍历、后序遍历、层次遍历)

1 树和二叉树 2 树的实例-模拟文件系统 3 二叉树 3.1 二叉树的遍历 二叉树的先序遍历 二叉树的中序遍历 二叉树的后序遍历 二叉树的层次遍历 1 树 树是一种数据结构 比如:目录结构 树是一种可以递归定义的数据结构树是由n个节点组成的集合:如果n0&#xff0c;那这是一棵空树;如…

[C++]一、C++基础编程

G:\Cpp\2023版C教程 C语言程序设计 第一部分 基础篇 一、什么是C 1.1 C 简介 C 是一门非常经典的高级编程语言。顾名思义&#xff0c;C可以看做是C语言的增强版&#xff0c;在C的基础上扩展了更多的功能&#xff1b;最主要的扩展&#xff0c;就是面向对象和泛型编程。 因…

buuctf [MRCTF2020]hello_world_go

前言 学习笔记 这题签到&#xff01; 64IDA打开。 查找字符串发现什么都没有。。。 没事 搜索main()【不知道go语言有没有&#xff0c;先搜索再说】 随便点开一个。 有flag格式&#xff0c;提交看看呗。 成了&#xff0c;签到。 flag{hello_world_gogogo} 题外话&#xff0c;…

Day18_Netty

文章目录 NettyIO 模型Java有哪些数据类型零拷贝深拷贝和浅拷贝的区别是什么?BIO、NIO、AIO的区别是什么?Netty 是什么?Netty 基于 NIO,那为啥不直接用 NIO 呢? / 为什么要用 Netty?Netty 应用场景了解么?那些开源项目用到了 Netty?Netty的核心组件是什么?请解释Netty…

Golang | Leetcode Golang题解之第371题两整数之和

题目&#xff1a; 题解&#xff1a; func getSum(a, b int) int {for b ! 0 {carry : uint(a&b) << 1a ^ bb int(carry)}return a }

汇编知识MOV,MRS,MSR,PUSH和POP指令

处理器做得最多的事情就是在处理器内部来回的进行数据传递 1) 将数据从一个寄存器传递到另一个寄存器中 2) 将数据从一个寄存器传递到特殊寄存器&#xff0c;例如CPSR,SPSR寄存器 3) 将立即数传递到寄存器。 数据传输常用的三个指令&#xff1a;MOV,MRS,MSR指令 常用的…

清华计算几何-线段求交与BO算法

单轴线段求交 给定单边轴下, N定线段&#xff0c;检查出相交的线段. 解法一: 暴力求解 遍历所有线段对&#xff0c;进行相交判断, 算法复杂度为O(n2) 解法二: LR扫描 把每条线段的头尾认定为L和R。对所有点进行排序&#xff0c;如果每两个点满足LL或者RR&#xff0c;则对应…

嵌入式UI开发-lvgl+wsl2+vscode系列:11、SSD202移植运行评估demo程序

一、前言 接下来我们根据开发板的LVGL指南移植lvgl的demo程序到开发板上&#xff0c;以及将一个评估的项目移植到开发板上&#xff0c;你将会发现移植lvgl到ssd2xx的板子上似乎很简单&#xff0c;但通过评估程序你将更加方便了解lvgl是否可以满足你的开发需求&#xff0c;除了…

使用了LSTM的数据预测

记录一下&#xff0c;这个是在national university of singapore,黄教授给我们布置的任务&#xff0c;做了一个北京的已知十年的打印量&#xff0c;预测100天的打印机大作业&#xff0c;我们使用了lstm模型&#xff0c;就是两层神经网络&#xff0c;同时dropout的加入为了防止过…

k8s跨节点后pod无法访问

场景 k8s在node1节点部署nginx后&#xff0c; 除node1外&#xff0c;主节点以及node2节点都无法正常访问nginx 并且主节点以及node2节点都无法ping通node1节点上的pod 网络插件为calico 并且也没有相关路由信息 解决方案 启动tunl0接口&#xff0c;因为calico需要使用tunl0网…

【解析几何笔记】8.向量的投影与内积

8. 向量的投影与内积 复习前面的知识&#xff1a;&#xff0c;若BCE三点共线&#xff0c;则 A E ⃗ ( 1 − s ) A B ⃗ s A C ⃗ , ( B , C , E ) μ ⇒ s μ 1 μ , 1 − s 1 1 μ \vec{AE}(1-s)\vec{AB}s\vec{AC},(B,C,E)\mu\Rightarrow s\frac{\mu}{1\mu},1-s\frac…

【学习笔记】时间序列模型(ARIMA)

文章目录 前言一、时间序列时间序列数据 二、ARIMA 模型大纲模型前提平稳性检验 差分整合移动平均自回归模型 ARIMA(p,q,d)自回归模型 (AR( p ))移动平均模型 (MA( q ))自回归移动平均模型(ARMA(p,q))差分自回归移动平均模型 ARIMA(p,d,q) 确定 p&#xff0c;q结果分析和模型检…

EVE-NG安装部署使用

EVE-NG安装部署使用 一、EVE的虚拟化安装1、下载EVE-NG(社区版)2、导入虚拟机-配置-登录二、EVE中设备的连接sercureCRT连接wireshark连接一、EVE的虚拟化安装 1、下载EVE-NG(社区版) 官网下载地址(科学上网): https://www.eve-ng.net/index.php/download/ 中文网下载…

运用Archimate为 智慧文旅搭建 数字化架构体系【系统架构】

ArchiMate是一种用于企业架构建模的开放、独立且详细的语言&#xff0c;它提供了一套丰富的概念和关系来描述、分析和可视化企业架构的不同领域。以下是ArchiMate建模的一些关键功能&#xff1a; 多视图建模&#xff1a;ArchiMate定义了23个示例视图&#xff0c;分为四类&#…

VMware-Ubuntu共享文件找不到

正常的流程我们实现设置共享目录 然后安装vmware-tool工具 我们先看一下vmware-tool的获取方式&#xff0c;系统安装好了以后&#xff0c;关闭系统将虚拟机设置改成图中配置&#xff0c;然后重启 鼠标右键会看到重新安装vmware-tool不再是灰色&#xff0c;点击重新安装 以1…

OpenCV几何图像变换(5)旋转和缩放计算函数getRotationMatrix2D()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 计算二维旋转的仿射矩阵。 该函数计算以下矩阵&#xff1a; [ α β ( 1 − α ) ⋅ center.x − β ⋅ center.y − β α β ⋅ center.x ( …

【TB作品】MSP430F149单片机,数字时钟万年历程序,滚动显示特效

一、 万年历 任务要求&#xff1a; 制作一个万年历&#xff0c;具有显示时间、日期、温度、湿度、闹钟功能。 1、OLED显示屏上显示日期和时钟&#xff08;显示到秒&#xff0c;时间可走动&#xff09;&#xff1b;&#xff08;20分&#xff09; 2、通过开发板上的温度传感器采集…

8月25日笔记

IOX的使用 iox是一款功能强大的端口转发&内网代理工具&#xff0c;该工具的功能类似于lcx和ew&#xff0c;但是iox的功能和性能都更加强大。 实际上&#xff0c;lcx和ew都是非常优秀的工具&#xff0c;但还是有地方可以提升的。在一开始使用这些工具的一段时间里&#xff…

前端常见**MS题 [3]

css部分 1、简单说明一下盒模型 CSS盒模型定义了盒的每个部分包含&#xff1a; margin, border, padding, content 。根据盒子大小的计算方式不同盒模型分成了两种&#xff0c;标准盒模型和怪异盒模型。 标准模型&#xff0c;给盒设置 width 和 height&#xff0c;实际设置的是…

C语言 | Leetcode C语言题解之第373题查找和最小的K对数字

题目&#xff1a; 题解&#xff1a; #define MIN(a, b) ((a) > (b) ? (b) : (a))int** kSmallestPairs(int* nums1, int nums1Size, int* nums2, int nums2Size, int k, int* returnSize, int** returnColumnSizes) {if (nums1Size 0 || nums2Size 0 || k < 0) {*ret…