如何拖拽图片放到指定的格子里

news2025/1/11 12:55:08
本文首发于微信公众号: 小蚂蚁教你做游戏。欢迎关注领取更多学习做游戏的原创教程资料,每天学点儿游戏开发知识。

嗨!大家好,我是小蚂蚁。

今天来分享一个如何在游戏中拖拽一个图片,然后把它放到指定的格子里,效果如下图:

这个基础的操作在很多的游戏中都有应用,例如棋类游戏,拖拽消除合成类游戏,或者是在背包装备栏等地方。总之,只要有这种格子类的布局,并且又需要拖拽放置操作,那么这个功能就会被需要。

这个功能实现起来并不复杂,之前已经写过很多与其相关的教程了。太阳底下无新事,实现的原理还是那么的一样,只不过展示方式稍微有点儿变化而已。

首先,我们要去绘制一个 3x3的网格布局。

如图,当前的网格布局刚好位于游戏屏幕的正中间,在微信小游戏制作工具中屏幕的正中间刚好是 (0,0) 的位置(在不同的游戏开发工具中坐标系的中心位置会有所不同,有的是以屏幕的左下角或者左上角为中心),现在已经知道了单元格的边长,以及行数列数,有了这几个数据,能够计算出左下角红色圆点在坐标系中的位置坐标(x0,y0)。

有了起点位置,我们就可以根据行号列号计算出整个网格中每个格子的坐标位置,如下图所示。

以上,就是绘制一个网格布局的理论基础了,让我们来到小游戏制作工具中,先把 3x3 的网格布局绘制出来。

首先,我们准备两个素材,“背景方块”用于显示格子,“五角星”扮演的是可拖拽放置的精灵。

接着,创建几个变量。

我们要创建的是一个每个格子大小为 200x200 的 3 x 3 的网格布局,所以这里“单元格边长”设置为 200,“行数”和“列数”设置为 3,“起点位置X/Y”表示的是网格布局左下角的起点,“全局行号/列号”用于记录当前创建的方块的行列号。另外这里我们为“背景方块”创建了两个局部变量“行号”和“列号”,目的是让每一个“背景方块”都能记录自己的行列号。

来看一下创建 3x3 网格布局的积木逻辑。

预览一下,就能看到一个 3x3 的方块布局了。

这里注意一下,虽然我们在全局变量中设置的单元格边长为 200,但是设置的背景方块图片的大小是 150x150。

这样设置背景方块之间会留有间隙,否则的话会完全贴合在一起。至于背景方块图片的大小是多少,图片是什么,对于游戏的逻辑没有任何的影响,甚至你把所有的背景方块隐藏了也没有关系,因为游戏中的位置坐标是通过计算算出来的,这个背景方块图片只是用于展示而已。

接着,我们来实现星星的拖拽和放置。

先来看一下理论知识。

如图,是行列号和坐标位置互相换算的公式。它们的作用是什么呢?比如说,我们拖拽一颗星星在游戏中移动,只要能够知道当前星星的坐标位置,我们就能够知道这个星星在网格布局中位于哪一行哪一列,反之,如果知道了星星在网格布局中的行列号,也能够计算出它当前在游戏屏幕上的坐标位置。

有些东西光靠眼睛看可能很难理解,尤其是一些数学计算。我通常习惯于拿出纸和笔,然后写写画画,进行推导计算,这是个非常不错的方式,推荐你也试一试。

理论知识搞懂了之后,实现起来其实就很简单了,首先给星星准备几个局部变量。

“行号”和“列号”用于记录星星当前所在的行列号,“被按下”这个变量用于记录当前星星是否被按住了。

来看一下星星的积木逻辑。

逻辑中最要的就是坐标位置和行列号的换算,先根据坐标位置计算出行列号,然后又根据行列号计算出坐标位置。这里可能有些难以理解,最终设置的都是坐标位置,为什么要算过来又算过去这么麻烦呢?

看一下上面的动图,我拖拽星星的时候并不是在方块中间放手,而是在方块的边缘放手,此时,星星好像是知道了我要把它放在哪里一样,自动的跑到那个格子的中间了。

这个就是算过来又算过去的作用,玩家拖拽放手的时候,当前的图片可能并不在格子的中间,此时我们就需要根据坐标位置计算出行列号,然后再根据行列号,把图片放置在格子的中间位置。

在星星逻辑的最后,使用全局变量记录了当前的行列号,并且给所有的“背景方块”,发送了一个“刷新背景方块”的通知。

最后,来看一下“背景方块”是如何处理这个通知的。

“背景方块”比对一下自己的行列号是否等于当前全局的行列号(星星的所在位置的行列号),是的话就把当前的背景块变成黄色,否则的话就变成白色。

这样,一个在指定网格布局内拖拽放置的功能就做好了。是不是觉得似曾相识呢?那是因为这背后的原理我们在 1010系列教程中讲过,在消除游戏系列教程中讲过,在泡泡龙系列教程中讲过,在俄罗斯方块系列教程中讲过......以后还会讲,我就不信你弄不明白。

不论外表如何变化,内部的原理依旧始终如一,还是那么几个计算公式,还是那么类似的实现方法。

有些知识彻底搞明白一次之后,就能够做到一通百通了,这类知识值得你花时间好好研究一番。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

网络编程(十)——基于UDP协议的套接字

TCP和UDP协议传输对比 TCP协议传输数据可靠,TCP传输数据后,如果收到接收方回应消息,则会在本机缓存中删除已发送消息;如果没有收到接收方回应消息,则会利用缓存继续发送消息。UDP协议传输数据相对来说不可靠&#xff…

学生看书用白炽灯和led灯哪个好?学生led护眼灯排行榜

我们都知道学生的晶状体是比较敏感的,不得不承认一个实际问题,LED灯已经普遍到日常生活中,不管是教室、企业、书房,使用LED灯居多,主要是因为它的电流稳定、光线柔和、光效效率高,所以LED灯的灯光没有紫外线…

Qt OpenGL(07)递归细分四面体法绘制球体

文章目录Qt OpenGL通过递归细分逼近球面思路下面就是绘制的代码:Widget.cpp顶点着色器片段着色器Qt OpenGL通过递归细分逼近球面 在OpenGL中绘制球面,不是太简单的事情。因为球面和圆都不是OpenGL所支持的图元,因此我们将通过一种称为递归细分…

飞宇科技在创业板IPO终止:长江证券撤回保荐,吴玉飞为实控人

2023年1月10日,深圳证券交易所披露的信息显示,江苏飞宇医药科技股份有限公司(下称“飞宇科技”)的保荐机构(长江证券)提交了撤回飞宇科技首次公开发行股票并在创业板上市申请的申请因此,深圳证券…

BOM(二): 元素偏移量offset 、元素可视区client 、元素滚动 scroll、动画

PC端网页特效元素偏移量offset元素可视区client元素滚动 scroll 系列动画元素偏移量offset 1.offset概述 offset 系列相关属性可以动态的得到该元素的位置(偏移)、大小等。 获得元素距离带有定位父元素的位置获得元素自身的大小(宽度高度&…

Python 字典(Dictionary)操作详解

这篇文章主要介绍了Python 字典(Dictionary)的详细操作方法,需要的朋友可以参考下。 Python字典是另一种可变容器模型,且可存储任意类型对象,如字符串、数字、元组等其他容器模型。 一、创建字典 字典由键和对应值成对组成。字典也被称作关…

微信小程序云开发之新闻博客社区项目debug后的项目代码

大家好,我是csdn的博主:lqj_本人 这是我的个人博客主页:lqj_本人的博客_CSDN博客-微信小程序,html特效,vue2基础领域博主 本次文章主要时为我最近在哔哩哔哩上的新发布的视频做一个映射! 哔哩哔哩欢迎关注:小淼前端 哔…

【Python从入门到进阶】3、运行python代码

接上篇《2、Python环境的安装》 上一篇我们学习了如何下载安装Python编程环境,以及如何使用pip管理Python包。本篇我们来学习如何使用终端和执行文件运行python代码。 一、终端运行 我们可以在命令行终端进入python解释程序,直接输入python代码&#x…

Spring Cloud OpenFeign @SpringQueryMap注解

概述 我们在使用GetMapping方法是,对于多个参数都是通过RequestParam参数一个一个接取的,多个参数时会比较麻烦,能像RequestBody那样接取PostMapping的参数么?答案是可以的。 SpringQueryMap介绍 SpringQueryMap 注解是 spring…

关于数据管理、数据治理和数据资产,你搞得清楚吗?

全球数字化的趋势愈演愈烈,我国信息化规模日渐增大,我们也每天都在接收大量的数据,要想深度挖掘数据的价值,首先从搞清楚数据的概念入手。今天我们就来聊一聊数据管理、数据治理和数据资产的概念和它们之间的相互关系。 数据管理…

从低代码来看,何谓客户体验自动化

在当今竞争激烈的大环境下,拥有出色的产品或服务并不意味着100%成功,反而是客户在购买流程中的体验变得比以往任何时候都更加重要。 随着企业业务的发展,提供个性化的客户体验变得愈加困难,许多企业因无法提供令人满意的客户体验而…

JavaScript 与 C++ 的差异

在正式开始向各位前端开发者介绍 C 语言之前,我们先讨论一下 C 语言与 JavaScript 语言的差异(为了约束讨论的范围,这里就不提 HTML 和 CSS 了)。 C 语言于 1979 年由贝尔实验室的 Bjarne Stroustrup(本贾尼斯特劳斯特…

【web安全】——HTTP请求头注入

作者名:Demo不是emo主页面链接: 主页传送门创作初心: 舞台再大,你不上台,永远是观众,没人会关心你努不努力,摔的痛不痛,他们只会看你最后站在什么位置,然后羡慕或鄙夷座右…

uni-app开发常用点

前言 应该会不定时更新,主要记录自己在uni-app开发过程中经常用到的东西。 组件库推荐: 1、https://v1.uviewui.com/ 我们老项目用到是这个的1.x版本,新版本没用过 2、https://vant-contrib.gitee.io/vant/v2/#/zh-CN/ 3、https://uniapp.d…

智能在线客服系统源码 国际版多语言多商户智能机器人源码

一套智能在线客服系统源码 多商户网页客服系统源码 支持二十种国际语言 带机器人自动回复。 框架:Thinkphp5workerman, 环境:nginxphp7.3mysql5.6 支持H5公众号APP小程序 私信了解更多源码内容! 系统功能特点: 1、…

k8s创建数据库

参考配置1 [rootk8s-master1 ~]# cat deployment.yaml apiVersion: apps/v1 kind: Deployment metadata:labels:app: mysql #为该Deployment设置key为app,value为mysql的标签name: mysqlnamespace: test spec:replicas: 1 #副本数量selector: #标签选择器&#xf…

深挖你拥有的东西的背后的价值到底是什么,价值转换模型分析。

深挖你拥有的东西的背后的价值到底是什么。 我们先把它转换成为观众观看这条视频的动机,甚至是观众关注账号的动机。 例如你能帮助别人赚钱,你能帮助别人变美。你提供的价值是成长的价值,你提供的价值是精神追求的价值,是生活理念…

【ROS】—— ROS常用组件—rosbag与rqt工具箱(十二)

文章目录前言1. rosbag1.1 rosbag使用_命令行2. rosbag使用_编码2.1 C实现2.1.1 写bag2.1.2 读bag2.2 python实现2.2.1 写bag2.2.2 读bag3. rqt工具箱3.1 rqt安装启动与基本使用3.2 rqt常用插件:rqt_graph3.3 rqt常用插件:rqt_console3.4 rqt常用插件:rqt_plot3.5 rqt常用插件:…

python算法与数据结构2-栈、队列、排序算法

目录1、栈1.1 栈的介绍1.2 栈的代码实现2、队列2.1 队列的介绍2.2 队列的代码实现3、双端队列4、数据结构与算法_排序算法4.1 排序算法的稳定性4.2 冒泡排序4.3 选择排序4.4 插入排序4.5 快速排序1、栈 1.1 栈的介绍 栈:运算受限的线性表,其限制是仅允…

黑盒测试用例设计 - 功能图法

目录功能图法原理介绍功能图法步骤案例:以QQ登录界面为例功能图法原理介绍 功能图方法其实是一种灰盒测试(因其兼有黑盒和白盒测试)用例设计方法;通常情况一个程序的功能说明通常由动态说明和静态说明组成,动态说明描…