【工具插件类教学】实现运行时2D物体交互的利器Runtime2DTransformInteractor
目录
编辑
1. 插件核心功能
1.1 基础变换操作
1.2 高级特性
2. 安装与配置
2.1 导入插件
2.2 配置控制器参数
2.3 为物体添加交互功能
3. 使用示例
3.1 基础操作演示
3.2 多选与批量操作
3.3 自定义光标与外观
4. 高级配置技巧
4.1 动态调整包围框控件尺寸
4.2 分层渲染控制
4.3 事件扩展
5. 常见问题解答
Q1:包围框未显示
Q2:光标未切换
Q3:缩放时宽高比未锁定
6. 结语
7.工具下载
1. 插件核心功能
1.1 基础变换操作
-
移动:点击物体碰撞体(Collider2D)并拖拽,即可自由移动物体。
-
缩放:
-
单轴缩放:拖拽包围框的边缘(Edge)可沿单个轴缩放。
-
双轴缩放:拖拽包围框的角落(Corner)可同时在两个轴上缩放。
-
保持宽高比:支持全局锁定宽高比,或通过快捷键临时锁定(如按住Shift键)。
-
-
旋转:拖拽旋转控件(Rotation Gizmo)可自由旋转物体。
1.2 高级特性
-
多选操作:支持同时选中多个物体进行统一移动(需启用
Allow Multi Selection)。 -
光标反馈:当鼠标悬停在交互区域(如角落、边缘、旋转控件)时,光标自动切换为预设图标。
-
动态尺寸调整:包围框的控件(角落、边缘、旋转控件)会根据摄像机缩放(
orthographicSize)自动调整屏幕显示尺寸。 -
自定义外观:可修改包围框的颜色、图标及排序层级,适配不同美术风格。
2. 安装与配置
2.1 导入插件
-
将插件包导入Unity项目(通过Asset Store或手动导入)。
-
添加控制器预制体:
在场景中拖入TransformInteractorController预制体(位于Package/Prefabs)。
该控制器全局管理所有交互逻辑,必须存在于场景中。
2.2 配置控制器参数
打开 TransformInteractorController 组件的参数面板,关键配置如下:
| 参数分类 | 关键参数 |
|---|---|
| 包围框外观 | Corner Color(角落颜色)、Line Color(边缘颜色)、Rotation Color(旋转控件颜色) |
| 交互行为 | Allow Multi Selection(启用多选)、Allow Rotation(启用旋转) |
| 光标设置 | Change Cursor(启用光标切换)、Move Cursor(移动光标图标) |
| 摄像机与缩放 | Main Camera(绑定正交摄像机)、Adjust Size To Zoom(动态调整控件尺寸) |
| 宽高比锁定 | Always Preserve Aspect Ratio(全局锁定)、Preserve Aspect Ratio On Key Hold(按键临时锁定) |
2.3 为物体添加交互功能
-
添加组件:为需要交互的2D物体添加
TransformInteractor脚本。 -
自动添加碰撞体:若物体没有
BoxCollider2D,插件会自动添加一个。调整碰撞体大小以匹配物体实际范围。 -
自定义包围框:通过修改
TransformInteractor的Collider Offset和Collider Size调整交互区域。
3. 使用示例
3.1 基础操作演示
-
移动物体:点击物体碰撞体并拖拽。
-
缩放物体:
-
拖拽角落进行双轴缩放。
-
拖拽边缘进行单轴缩放。
-
按住
Aspect Ratio Keys(如Shift键)临时锁定宽高比。
-
-
旋转物体:拖拽旋转控件(默认位于包围框顶部)。
3.2 多选与批量操作
-
启用多选:在控制器中勾选
Allow Multi Selection。 -
选择多个物体:按住
Multi Selection Keys(如Ctrl键)点击多个物体。 -
统一移动:拖拽任意选中物体,所有选中物体将同步移动。
3.3 自定义光标与外观
// 示例:通过代码动态修改光标图标(需提前导入纹理)
TransformInteractorController controller = FindObjectOfType<TransformInteractorController>();
controller.MoveCursor = YourCustomMoveCursorTexture;
controller.RotateCursor = YourCustomRotateCursorTexture;
4. 高级配置技巧
4.1 动态调整包围框控件尺寸
-
确保摄像机为 正交投影(Orthographic)。
-
在控制器中启用
Adjust Size To Zoom。 -
设置
Default Corner Width/Height等参数,控制控件的默认屏幕尺寸。
4.2 分层渲染控制
通过设置不同排序层级(Sorting Layer),避免控件与游戏物体重叠:
-
Corner Sorting Layer>Rotation Gizmo Sorting Layer>Line Sorting Layer
4.3 事件扩展
插件内置事件系统(需自行扩展):
TransformInteractor interactor = GetComponent<TransformInteractor>();
interactor.OnDragStart += () => { /* 拖拽开始逻辑 */ };
interactor.OnScale += (scale) => { /* 缩放中逻辑 */ };
5. 常见问题解答
Q1:包围框未显示
确认
TransformInteractorController预制体已添加到场景。检查物体的
TransformInteractor脚本是否启用。
Q2:光标未切换
-
在控制器中启用
Change Cursor。 -
确认
Default Cursor和特定操作光标已正确赋值。
Q3:缩放时宽高比未锁定
-
检查
Always Preserve Aspect Ratio或Preserve Aspect Ratio On Key Hold是否启用。 -
确认快捷键设置(
Aspect Ratio Keys)是否冲突。
6. 结语
Runtime 2D Transform Interactor 是一款功能强大且高度可定制的2D交互插件,尤其适合编辑器工具、关卡设计或需要精细物体操作的2D游戏。通过灵活的配置和直观的操作,开发者可以显著减少编码时间,专注于核心玩法开发。立即尝试这款插件,提升你的开发效率!
7.工具下载
https://download.csdn.net/download/qq_37310110/90394947
【注:此博文为工具生成,内容未经校对,注意甄别】
相关文章:
【工具插件类教学】实现运行时2D物体交互的利器Runtime2DTransformInteractor
目录 编辑 1. 插件核心功能 1.1 基础变换操作 1.2 高级特性 2. 安装与配置 2.1 导入插件 2.2 配置控制器参数 2.3 为物体添加交互功能 3. 使用示例 3.1 基础操作演示 3.2 多选与批量操作 3.3 自定义光标与外观 4. 高级配置技巧 4.1 动态调整包围框控件尺寸 4.…...
回调处理器
文章目录 什么是回调处理器回调处理器的工作流程回调处理器的使用自定义链组件中的回调 内置回调处理器自定义回调处理器 在编程领域中,回调是一个非常重要的概念。简而言之,回调是一种特殊的函数或方法,它可以被传递给另一个函数作为参数&am…...
Redis-03高级篇中-多级缓存:
说明: 分布式缓存和多级缓存的视频,与springcloud高级篇redis的一模一样。这里就不在重复学习了,如果后面用到关于redis的配置,直接到springcloud模块安装的redis中学习即可。 多级缓存 0.学习目标 1.什么是多级缓存 传统的缓…...
Spring Boot ShardingJDBC分库分表(草稿)
ShardingJDBC分库分表 1.Maven 引用 <dependency><groupId>org.apache.shardingsphere</groupId><artifactId>sharding-jdbc-spring-boot-starter</artifactId><version>4.1.1</version></dependency><dependency><…...
Jenkins 环境搭建---基于 Docker
前期准备 提前安装jdk、maven、nodeJs(如果需要的话) 创建 jenkins 环境目录,用来当做挂载卷 /data/jenkins/ 一:拉取 Jenkins 镜像 docker pull jenkins/jenkins:lts 二:设置 Jenkins挂载目录 mkdir -p ~/jen…...
如何在自定义组件中使用v-model实现双向绑定
在 Vue 2 中,v-model 是双向数据绑定的语法糖,它默认将 value 作为 prop 传入组件,并通过监听 input 事件来更新父组件的数据。若要在自定义组件中实现 v-model 的双向绑定,需遵循以下步骤: 1. 基本实现:va…...
Ubuntu 下 nginx-1.24.0 源码分析 - ngx_pool_t 类型
ngx_pool_t 定义在 src/core/ngx_core.h typedef struct ngx_pool_s ngx_pool_t; ngx_pool_s 定义在 src/core/ngx_palloc.h struct ngx_pool_s {ngx_pool_data_t d;size_t max;ngx_pool_t *current;ngx_chain_t *chain;ng…...
如何在 ubuntu 上使用 Clash 与 docker 开启代理拉起
如何在 ubuntu 上使用 Clash https://github.com/doreamon-design/clash/releases上面是clash 的地址 clash_2.0.24_linux_386.tar.gz 下载 386 的 如果你的电脑是inter tar -xzvf clash_2.0.24_linux_386.tar.gz 启动 ./clash 然后会在电脑上生成一个config的文件 /home/xxx/…...
linux tcpdump抓包
参数说明: -i 指定网卡 -w 指定保存文件 -s0 完整抓包 -G 指定间隔时长(秒) -C 指定每个文件大小(M) 用法1: 指定端口输出到指定文件 tcpdump -i em3 -w 182910.pcap 用法2: 指定端口每10分钟输出到不同文件 tcpdump -i em3 -s0 -G 600 -w %Y_%m%d_%H%M_%S.pcap 用法3: 指…...
PLSQL连接Oracle 19c报错ORA-28040
PLSQL连接Oracle 19c报错ORA-28040 原因解析解决办法原因解析 使用PLSQL Developer连接19c数据库报错: ORA-28040: No matching authentication protocol报错信息解析: [oracle@ora19c ~]$ oerr ora 2804028040, 0000, "No matching authentication protocol" /…...
汽车免拆诊断案例 | 2010 款路虎揽胜车空调偶尔出风异常
故障现象 一辆2010款路虎揽胜车,搭载5.0 L发动机,累计行驶里程约为16万km。车主反映,接通空调开关后,有时出风忽大忽小,有时不出风,有时要等2 min左右才出风;有时两三天出现一次,…...
音视频入门基础:RTP专题(9)——FFmpeg接收RTP流的原理和内部实现
一、引言 由《音视频入门基础:RTP专题(2)——使用FFmpeg命令生成RTP流》可以知道,推流端通过下面FFmpeg命令可以将一个媒体文件转推RTP,生成RTP流: ffmpeg -re -stream_loop -1 -i input.mp4 -vcodec cop…...
Nginx 安装及配置教程(Windows)【安装】
文章目录 一、 Nginx 下载 1. 官网下载2. 其它渠道 二、 Nginx 安装三、 配置四、 验证五、 其它问题 1. 常用命令2. 跨域问题 软件 / 环境安装及配置目录 一、 Nginx 下载 1. 官网下载 安装地址:https://nginx.org/en/download.html 打开浏览器输入网址 htt…...
《跟李沐学 AI》AlexNet论文逐段精读学习心得 | PyTorch 深度学习实战
前一篇文章,使用 AlexNet 实现图片分类 | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 本篇文章内容来自于学习 9年后重读深度学习奠基作之一:AlexNet【下】【论文精读】】的心得。 《跟李沐…...
嵌入式0xDEADBEEF
在嵌入式系统中,0xDEADBEEF 是一个常见的“魔数”(magic number),通常用于调试和内存管理。它的含义和用途如下: 1. 调试用途 未初始化内存的标记:在调试时,0xDEADBEEF 常用于标记未初始化或已…...
B+树作为数据库索引结构的优势对比
MySQL作为数据库,它的功能就是做数据存储和数据查找;使用B树作为索引结构是为了实现高效的查找、插入和删除操作。 B树的查找、插入、删除的复杂度都为 O(log n),它是一个多叉树的结构,能兼顾各种操作的效率的数据结构。如果使用…...
自适应SQL计划管理(Adaptive SQL Plan Management)在Oracle 12c中的应用
在Oracle Database 12c Release 1 (12.1)版本中,引入了对SQL计划管理(SPM)功能的增强,特别是关于SQL计划基线的自动进化机制。这一改进允许数据库更加智能地管理和优化SQL查询的执行计划,确保即使数据分布发生变化&…...
什么是DeFi (去中心化金融)
DeFi (去中心化金融) 概述 💰 1. DeFi 基础概念 1.1 什么是 DeFi? DeFi 是建立在区块链上的金融服务生态系统,它: 无需中心化中介开放且透明无需许可即可参与代码即法律 1.2 DeFi 的优势 开放性:任何人都可以参与…...
计算机毕业设计Python农产品推荐系统 农产品爬虫 农产品可视化 农产品大数据(源码+LW文档+PPT+讲解)
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
LLM论文笔记 15: Transformers Can Achieve Length Generalization But Not Robustly
Arxiv日期:2024.2.14机构:Google DeepMind / University of Toronto 关键词 长度泛化位置编码数据格式 核心结论 1. 实验结论:十进制加法任务上的长度泛化最佳组合: FIRE位置编码 随机化位置编码 反向数据格式 索引提示&…...
Python|GIF 解析与构建(5):手搓截屏和帧率控制
目录 Python|GIF 解析与构建(5):手搓截屏和帧率控制 一、引言 二、技术实现:手搓截屏模块 2.1 核心原理 2.2 代码解析:ScreenshotData类 2.2.1 截图函数:capture_screen 三、技术实现&…...
React 第五十五节 Router 中 useAsyncError的使用详解
前言 useAsyncError 是 React Router v6.4 引入的一个钩子,用于处理异步操作(如数据加载)中的错误。下面我将详细解释其用途并提供代码示例。 一、useAsyncError 用途 处理异步错误:捕获在 loader 或 action 中发生的异步错误替…...
Lombok 的 @Data 注解失效,未生成 getter/setter 方法引发的HTTP 406 错误
HTTP 状态码 406 (Not Acceptable) 和 500 (Internal Server Error) 是两类完全不同的错误,它们的含义、原因和解决方法都有显著区别。以下是详细对比: 1. HTTP 406 (Not Acceptable) 含义: 客户端请求的内容类型与服务器支持的内容类型不匹…...
ES6从入门到精通:前言
ES6简介 ES6(ECMAScript 2015)是JavaScript语言的重大更新,引入了许多新特性,包括语法糖、新数据类型、模块化支持等,显著提升了开发效率和代码可维护性。 核心知识点概览 变量声明 let 和 const 取代 var…...
Prompt Tuning、P-Tuning、Prefix Tuning的区别
一、Prompt Tuning、P-Tuning、Prefix Tuning的区别 1. Prompt Tuning(提示调优) 核心思想:固定预训练模型参数,仅学习额外的连续提示向量(通常是嵌入层的一部分)。实现方式:在输入文本前添加可训练的连续向量(软提示),模型只更新这些提示参数。优势:参数量少(仅提…...
React Native 开发环境搭建(全平台详解)
React Native 开发环境搭建(全平台详解) 在开始使用 React Native 开发移动应用之前,正确设置开发环境是至关重要的一步。本文将为你提供一份全面的指南,涵盖 macOS 和 Windows 平台的配置步骤,如何在 Android 和 iOS…...
稳定币的深度剖析与展望
一、引言 在当今数字化浪潮席卷全球的时代,加密货币作为一种新兴的金融现象,正以前所未有的速度改变着我们对传统货币和金融体系的认知。然而,加密货币市场的高度波动性却成为了其广泛应用和普及的一大障碍。在这样的背景下,稳定…...
Typeerror: cannot read properties of undefined (reading ‘XXX‘)
最近需要在离线机器上运行软件,所以得把软件用docker打包起来,大部分功能都没问题,出了一个奇怪的事情。同样的代码,在本机上用vscode可以运行起来,但是打包之后在docker里出现了问题。使用的是dialog组件,…...
学校时钟系统,标准考场时钟系统,AI亮相2025高考,赛思时钟系统为教育公平筑起“精准防线”
2025年#高考 将在近日拉开帷幕,#AI 监考一度冲上热搜。当AI深度融入高考,#时间同步 不再是辅助功能,而是决定AI监考系统成败的“生命线”。 AI亮相2025高考,40种异常行为0.5秒精准识别 2025年高考即将拉开帷幕,江西、…...
USB Over IP专用硬件的5个特点
USB over IP技术通过将USB协议数据封装在标准TCP/IP网络数据包中,从根本上改变了USB连接。这允许客户端通过局域网或广域网远程访问和控制物理连接到服务器的USB设备(如专用硬件设备),从而消除了直接物理连接的需要。USB over IP的…...
