Unity基础知识:场景编辑与对象管理

发布时间: 2024-01-13 02:57:14 阅读量: 64 订阅数: 48
# 1. Unity引擎简介 ## 1.1 Unity引擎概述 Unity引擎是一款广泛应用于游戏开发、虚拟现实、增强现实和模拟等领域的跨平台开发工具。它具有强大的功能和易于使用的界面,能够帮助开发者快速创建高质量的交互式应用程序。 Unity引擎支持多种平台,包括Windows、Mac、Linux以及主流的移动平台,如Android和iOS。同时,它也支持各种图形API,包括DirectX、OpenGL和Vulkan,使开发者能够充分发挥硬件的性能优势。 ## 1.2 Unity界面介绍 Unity界面主要由以下几个部分组成: - **场景视图**:用于编辑和预览场景中的对象以及场景的布局。 - **游戏视图**:用于运行和播放场景,以实时查看游戏的表现效果。 - **项目面板**:用于管理项目中的资源文件,如场景、脚本、纹理等。 - **检视面板**:用于查看和编辑选中对象的属性和组件。 - **层级面板**:以树状结构显示场景中的所有对象,并允许对对象进行组织和层级管理。 - **工具栏**:提供快速访问常用功能和工具的按钮。 ## 1.3 创建新项目和场景 在Unity中,我们可以通过以下步骤创建新的项目和场景: 1. 打开Unity编辑器,选择"New Project"创建一个新项目。 2. 设置项目的名称和保存路径,并选择所需的模板,如3D、2D、AR等。 3. 创建项目后,可以在"Project"面板中右键点击空白区域,选择"Create"来创建新的场景。 4. 设置场景的名称,并双击打开场景进行编辑。 在创建场景后,我们就可以使用Unity的各种编辑工具和功能来构建我们所需的虚拟场景和模型,以及实现各种互动和动画效果。 以上就是关于Unity引擎简介的章节内容。在接下来的章节中,我们将更深入地探讨场景编辑与对象管理的相关主题。 # 2. 场景编辑基础 ### 2.1 场景视图和游戏视图 在Unity中,场景视图和游戏视图是我们编辑和预览场景的重要工具。 在场景视图中,我们可以看到场景中的所有对象的视觉呈现。我们可以在场景视图中选择、移动、旋转和缩放对象,以及设置其属性和组件。 而游戏视图则是我们在播放模式下,预览游戏运行的视图。在游戏视图中,我们可以触发游戏中的交互事件、测试游戏的功能和逻辑。 ### 2.2 场景布局与面板使用 Unity的编辑器界面非常灵活,可以根据我们的需求进行自定义布局。 默认情况下,Unity的编辑器界面包括场景视图、游戏视图、层级视图、项目视图、检查器视图和控制台视图。这些视图可以分别调整大小和位置,以适应我们的工作流程。 层级视图显示了场景中所有对象的层级关系。通过层级视图,我们可以方便地选择对象、管理对象的父子关系以及设置对象的属性和组件。 项目视图则用于管理我们项目中的资源文件。我们可以在项目视图中创建、导入、删除和组织我们的资源文件,如纹理、模型、材质等。 检查器视图是我们设置和编辑对象属性的地方。通过检查器视图,我们可以设置对象的名称、位置、大小、旋转角度、材质等信息。同时,我们还可以为对象添加组件和调整组件的属性。 最后,控制台视图用于显示Unity的日志和警告信息。当我们遇到问题或者需要调试时,控制台视图将成为我们排查错误和获取信息的重要工具。 ### 2.3 摄像机设置与场景调整 摄像机是场景中非常重要的元素之一。它决定了我们在游戏中所能看到的视角和范围。 在Unity中,我们可以通过选择摄像机对象,并在检查器视图中设置摄像机的各种属性来调整摄像机的行为。例如,我们可以设置摄像机的位置、旋转角度、视野范围、背景色等。 此外,我们还可以通过改变场景的环境光照、阴影、音效等来进一步调整场景的效果和氛围。 总结: 本章介绍了Unity的场景编辑基础知识,包括场景视图和游戏视图的使用方法,以及如何调整场景的布局和面板。并且还介绍了摄像机的设置和场景的调整方法。熟练掌握这些基础知识,可以帮助我们更好地进行场景编辑和调整,为游戏的开发打下坚实的基础。 # 3. 对象的创建与管理 在Unity中,对象是构建场景的基本单元。本章将介绍如何在Unity中创建和管理对象。 ### 3.1 使用基本原语创建对象 在Unity中,我们可以使用基本原语(如立方体、球体、平面等)来创建对象。 下面是使用C#脚本创建一个立方体对象的示例代码: ```csharp using UnityEngine; public class CubeCreator : MonoBehaviour { void Start() { GameObject cube = GameObject.CreatePrimitive(PrimitiveType.Cube); cube.transform.position = new Vector3(0, 0, 0); } } ``` 解析: 首先,我们需要导入Unity的命名空间`UnityEngine`。 然后,创建一个名为`CubeCreator`的脚本,并继承自`MonoBehaviour`。 在`Start`方法中,我们使用`GameObject.CreatePrimitive`方法来创建一个立方体对象,并将其赋值给`cube`变量。 接着,我们使用`transform.position`属性来设置立方体对象的位置为`(0, 0, 0)`。 ### 3.2 导入和管理3D模型 除了使用基本原语创建对象,我们还可以导入和管理现有的3D模型。 下面是使用C#脚本导入一个3D模型文件的示例代码: ```csharp using UnityEngine; public class ModelImporter : MonoBehaviour { public string modelFilePath; // 3D模型文件路径 void Start() { GameObject model = Instantiate(Resources.Load<GameObject>(modelFilePath)); model.transform.position = new Vector3(0, 0, 0); } } ``` 解析: 首先,我们需要导入Unity的命名空间`UnityEngine`。 然后,创建一个名为`ModelImporter`的脚本,并继承自`MonoBehaviour`。 在`ModelImporter`脚本中,我们声明了一个公共字符串变量`modelFilePath`,用于存储3D模型文件的路径。 在`Start`方法中,我们使用`Resources.Load<GameObject>`方法来加载指定路径下的3D模型文件,并使用`Instantiate`方法在场景中创建该模型的实例。 最后,我们使用`transform.position`属性来设置模型对象的位置为`(0, 0, 0)`。 ### 3.3 对象的Transform属性与变换 在Unity中,每个对象都具有一个`Transform`组件,该组件包含了对象的位置、旋转和缩放等信息。 下面是使用C#脚本来演示对象的变换操作: ```csharp using UnityEngine; public class ObjectTransform : MonoBehaviour { void Start() { // 获取对象的Transform组件 Transform objTransform = GetComponent<Transform>(); // 移动对象 objTransform.position = new Vector3(2, 0, 0); // 旋转对象 objTransform.rotation = Quaternion.Euler(0, 45, 0); // 缩放对象 objTransform.localScale = new Vector3(2, 2, 2); } } ``` 解析: 首先,我们需要导入Unity的命名空间`UnityEngine`。 然后,创建一个名为`ObjectTransform`的脚本,并继承自`MonoBehaviour`。 在`Start`方法中,我们使用`GetComponent<Transform>`方法来获取当前对象的`Transform`组件,并将其赋值给`objTransform`变量。 接着,我们使用`position`属性来移动对象的位置到`(2, 0, 0)`。 然后,我们使用`rotation`属性来旋转对象,这里使用`Quaternion.Euler`方法将欧拉角表示的旋转转换为四元数。 最后,我们使用`localScale`属性来缩放对象,这里将对象的缩放设置为`(2, 2, 2)`。 通过对对象的`Transform`属性进行适当的操作,我们可以实现对象的移动、旋转和缩放等效果。 本章介绍了对象的创建与管理的基础知识,包括使用基本原语和导入3D模型创建对象,以及通过对象的`Transform`属性实现对象的变换。在下一章节中,我们将学习对象组织与层级管理的相关内容。 > 代码仅作示例,具体的脚本实现可能因项目需求而有所不同,请根据实际情况进行调整。 # 4. 对象组织与层级管理 在Unity中,对象的组织和层级管理是非常重要的,它可以帮助我们更好地管理场景中的各种对象,提高开发效率和代码可读性。本章将详细介绍对象的层级关系、父子关系、标签与层级管理、以及对象的查找与选择技巧。 #### 4.1 对象的层级关系与父子关系 在Unity中,对象可以通过父子关系进行组织和管理。将一个对象设置为另一个对象的子对象后,父对象的变换操作会影响到所有子对象,这对于构建复杂的场景和对象结构非常有用。 示例代码(C#): ```c# // 在代码中设置对象的父子关系 public class ObjectHierarchyExample : MonoBehaviour { public GameObject parentObject; public GameObject childObject; void Start() { // 将childObject设为parentObject的子对象 childObject.transform.parent = parentObject.transform; } } ``` #### 4.2 使用标签与层级管理对象 通过为对象添加标签和层级,我们可以更方便地对对象进行分类和管理。例如,可以通过标签区分游戏中的不同类型的玩家角色,通过层级管理实现特定对象的渲染优化等。 示例代码(C#): ```c# // 在代码中设置对象的标签和层级 public class ObjectTagAndLayerExample : MonoBehaviour { void Start() { // 设置对象的标签 gameObject.tag = "Player"; // 设置对象的层级 gameObject.layer = LayerMask.NameToLayer("Interactive"); } } ``` #### 4.3 对象的查找与选择技巧 Unity提供了丰富的API,可以帮助我们在场景中快速查找和选择对象。这对于实现对象之间的交互和操作非常有帮助。 示例代码(C#): ```c# // 在代码中查找和选择对象 public class ObjectSelectionExample : MonoBehaviour { void Start() { // 通过标签查找对象 GameObject player = GameObject.FindGameObjectWithTag("Player"); // 通过名称查找对象 GameObject enemy = GameObject.Find("Enemy"); // 通过类型查找对象 Component[] scripts = GetComponentsInChildren(typeof(ScriptType)); } } ``` 通过以上介绍,我们了解了Unity中对象的组织与层级管理的基本操作和技巧。在实际开发中,合理利用这些功能可以极大地提高项目的可维护性和扩展性。 # 5. 物体的运动与交互 在Unity中,物体的运动和交互是游戏开发中非常重要的一部分,通过使用物理引擎和用户交互技术,可以使游戏变得更加生动和有趣。本章将介绍在Unity中实现物体的基本运动、碰撞检测以及用户交互的方法。 #### 5.1 刚体与物理引擎 在Unity中,物体的运动是由物理引擎来进行模拟的,而刚体(Rigidbody)组件则是实现物体运动的关键。通过给物体添加刚体组件,可以使其受到物理引擎的作用,实现重力效果、碰撞反应等。以下是一个简单的示例代码,演示了如何使物体受到重力影响并响应碰撞事件: ```c# using UnityEngine; public class RigidbodyExample : MonoBehaviour { Rigidbody rb; void Start() { rb = GetComponent<Rigidbody>(); rb.AddForce(Vector3.up * 10f, ForceMode.Impulse); } void OnCollisionEnter(Collision collision) { if (collision.gameObject.tag == "Obstacle") { rb.velocity = Vector3.zero; rb.angularVelocity = Vector3.zero; } } } ``` 上述代码中,我们首先获取物体的刚体组件,并在 Start() 方法中给物体施加向上的力,然后在 OnCollisionEnter() 方法中判断碰撞对象的标签,如果是障碍物,则使物体停止运动。 #### 5.2 简单运动与碰撞检测 除了使用刚体组件实现物体的运动外,我们也可以通过修改物体的 Transform 属性来实现简单的运动效果,同时借助碰撞检测实现物体之间的交互。以下是一个示例代码,实现了物体的平移运动和碰撞检测: ```c# using UnityEngine; public class SimpleMovement : MonoBehaviour { public float speed = 5f; void Update() { float horizontalInput = Input.GetAxis("Horizontal"); float verticalInput = Input.GetAxis("Vertical"); Vector3 movement = new Vector3(horizontalInput, 0, verticalInput) * speed * Time.deltaTime; transform.Translate(movement); } void OnCollisionEnter(Collision collision) { if (collision.gameObject.tag == "Obstacle") { // 在碰撞时执行的操作 } } } ``` 在上述代码中,我们通过获取输入设备的信号来控制物体的移动,然后在碰撞发生时执行相应的操作。 #### 5.3 用户交互与触发器应用 除了物体之间的碰撞交互,用户输入也是游戏中常见的交互方式。通过监听玩家的输入,在适当的时机触发相应的事件,可以使游戏更加具有交互性。以下是一个简单的示例代码,演示了如何在玩家按下空格键时使物体跳跃: ```c# using UnityEngine; public class PlayerJump : MonoBehaviour { public float jumpForce = 10f; void Update() { if (Input.GetKeyDown(KeyCode.Space)) { Jump(); } } void Jump() { GetComponent<Rigidbody>().AddForce(Vector3.up * jumpForce, ForceMode.Impulse); } } ``` 在上述代码中,我们通过监听玩家输入的空格键来触发跳跃事件,使物体受到向上的冲量,实现了在玩家触发事件时的物体交互。 通过以上示例,我们可以看到在Unity中实现物体的运动与交互是非常简单的,可以通过物理引擎、碰撞检测以及用户输入等方式来实现丰富多彩的游戏效果。 以上就是关于物体的运动与交互的内容介绍,希望对你有所帮助。 # 6. 场景的保存与导出 Unity中的场景保存与导出是开发过程中非常重要的一环,它涉及到项目的持久化和分享。本章将详细介绍如何进行场景的保存、加载、打包和导出,以及一些场景的优化和性能调整技巧。 #### 6.1 场景的保存与加载 在Unity中,可以通过简单的操作来保存当前编辑的场景。在菜单栏中选择 "File -> Save Scene" 即可保存当前场景。而加载已有的场景则是通过选择 "File -> Open Scene" 来实现。 示例代码: ```java // 保存当前场景 EditorSceneManager.SaveScene(EditorSceneManager.GetActiveScene()); // 加载指定场景 EditorSceneManager.LoadScene("YourSceneName.unity"); ``` **代码说明:** 上面的示例代码演示了在Unity中如何通过编程方式保存当前场景和加载指定的场景。 #### 6.2 场景的打包与导出 在完成场景编辑后,通常需要将场景打包为可执行文件或者其他形式进行导出。在Unity中,可以通过选择 "File -> Build Settings" 来配置需要打包的场景,并选择相应的平台进行导出。 示例代码: ```java // 设置需要打包的场景 EditorBuildSettingsScene[] scenes = new EditorBuildSettingsScene[] { new EditorBuildSettingsScene("Assets/Scenes/Scene1.unity", true), new EditorBuildSettingsScene("Assets/Scenes/Scene2.unity", true) }; EditorBuildSettings.scenes = scenes; // 导出为Windows平台应用 BuildPipeline.BuildPlayer(EditorBuildSettings.scenes, "YourBuildPath/YourGame.exe", BuildTarget.StandaloneWindows, BuildOptions.ShowBuiltPlayer); ``` **代码说明:** 上面的示例代码展示了如何在Unity中通过编程方式设置需要打包的场景,并将其导出为Windows平台的可执行文件。 #### 6.3 场景优化与性能调整 在开发过程中,对场景进行优化以提升性能是必不可少的。可以通过合理设置场景的LOD(Level of Detail)、使用批处理和静态合并等技术来优化场景。 示例代码: ```java // 设置LOD LODGroup lodGroup = GetComponent<LODGroup>(); LOD[] lods = new LOD[] { new LOD(0.5f, new Renderer[]{ renderer1 }), new LOD(0.2f, new Renderer[]{ renderer2 }), // 更多LOD设置 }; lodGroup.SetLODs(lods); // 批处理 StaticBatchingUtility.Combine(gameObject); // 静态合并 GameObjectUtility.SetStaticEditorFlags(mergedGameObject, StaticEditorFlags.ContributeGI | StaticEditorFlags.OccludeeStatic | StaticEditorFlags.ReflectionProbeStatic); ``` **代码说明:** 上面的示例代码演示了在Unity中如何通过编程方式设置LOD、进行批处理和静态合并来优化场景。 以上就是关于场景的保存与导出以及场景优化与性能调整的内容,希望对你有所帮助。
corwn 最低0.47元/天 解锁专栏
买1年送3月
点击查看下一篇
profit 百万级 高质量VIP文章无限畅学
profit 千万级 优质资源任意下载
profit C知道 免费提问 ( 生成式Al产品 )

相关推荐

sun海涛

游戏开发工程师
曾在多家知名大厂工作,拥有超过15年的丰富工作经验。主导了多个大型游戏与音视频项目的开发工作;职业生涯早期,曾在一家知名游戏开发公司担任音视频工程师,参与了多款热门游戏的开发工作。负责游戏音频引擎的设计与开发,以及游戏视频渲染技术的优化和实现。后又转向一家专注于游戏机硬件和软件研发的公司,担任音视频技术负责人。领导团队完成了多个重要的音视频项目,包括游戏机音频引擎的升级优化、视频编解码器的集成开发等。
专栏简介
本专栏以"unity框架设计之基础架构"为主题,涵盖了Unity引擎各个方面的知识与技术。文章内容包括了游戏开发入门指南、场景编辑与对象管理、图形渲染技术与效果、物理模拟探秘、动画系统解析、网络编程基础、音频设计、移动平台适配、虚拟现实实践、Shader编程、混合现实探秘、项目大型化架构设计、优化与性能调优实战、游戏测试之道、数据驱动设计以及高级GUI技术。无论你是游戏开发的新手还是有经验的开发者,都可以在本专栏中找到对应自己需求的知识点。在这里,你将深入了解Unity框架的设计与架构,掌握各种游戏开发所需的技能。无论你对游戏开发的哪个方面感兴趣,本专栏都会为你提供最有价值的指导和教程,让你成为一名更优秀的Unity游戏开发者。
最低0.47元/天 解锁专栏
买1年送3月
百万级 高质量VIP文章无限畅学
千万级 优质资源任意下载
C知道 免费提问 ( 生成式Al产品 )

最新推荐

【误差度量方法比较】:均方误差与其他误差度量的全面比较

![均方误差(Mean Squared Error, MSE)](https://img-blog.csdnimg.cn/420ca17a31a2496e9a9e4f15bd326619.png) # 1. 误差度量方法的基本概念 误差度量是评估模型预测准确性的关键手段。在数据科学与机器学习领域中,我们常常需要借助不同的指标来衡量预测值与真实值之间的差异大小,而误差度量方法就是用于量化这种差异的技术。理解误差度量的基本概念对于选择合适的评估模型至关重要。本章将介绍误差度量方法的基础知识,包括误差类型、度量原则和它们在不同场景下的适用性。 ## 1.1 误差度量的重要性 在数据分析和模型训

优化之道:时间序列预测中的时间复杂度与模型调优技巧

![优化之道:时间序列预测中的时间复杂度与模型调优技巧](https://pablocianes.com/static/7fe65d23a75a27bf5fc95ce529c28791/3f97c/big-o-notation.png) # 1. 时间序列预测概述 在进行数据分析和预测时,时间序列预测作为一种重要的技术,广泛应用于经济、气象、工业控制、生物信息等领域。时间序列预测是通过分析历史时间点上的数据,以推断未来的数据走向。这种预测方法在决策支持系统中占据着不可替代的地位,因为通过它能够揭示数据随时间变化的规律性,为科学决策提供依据。 时间序列预测的准确性受到多种因素的影响,例如数据

跨平台推荐系统:实现多设备数据协同的解决方案

![跨平台推荐系统:实现多设备数据协同的解决方案](http://www.renguang.com.cn/plugin/ueditor/net/upload/2020-06-29/083c3806-74d6-42da-a1ab-f941b5e66473.png) # 1. 跨平台推荐系统概述 ## 1.1 推荐系统的演变与发展 推荐系统的发展是随着互联网内容的爆炸性增长和用户个性化需求的提升而不断演进的。最初,推荐系统主要基于规则来实现,而后随着数据量的增加和技术的进步,推荐系统转向以数据驱动为主,使用复杂的算法模型来分析用户行为并预测偏好。如今,跨平台推荐系统正逐渐成为研究和应用的热点,旨

NLP数据增强神技:提高模型鲁棒性的六大绝招

![NLP数据增强神技:提高模型鲁棒性的六大绝招](https://b2633864.smushcdn.com/2633864/wp-content/uploads/2022/07/word2vec-featured-1024x575.png?lossy=2&strip=1&webp=1) # 1. NLP数据增强的必要性 自然语言处理(NLP)是一个高度依赖数据的领域,高质量的数据是训练高效模型的基础。由于真实世界的语言数据往往是有限且不均匀分布的,数据增强就成为了提升模型鲁棒性的重要手段。在这一章中,我们将探讨NLP数据增强的必要性,以及它如何帮助我们克服数据稀疏性和偏差等问题,进一步推

噪声抑制技术:提升语音识别准确性的核心方法

![语音识别(Speech Recognition)](https://www.aldec.com/images/content/blog/091113_img_02_950.jpg) # 1. 噪声抑制技术概述 ## 1.1 噪声抑制技术的必要性 在日常生活中,噪声无处不在,它通常会干扰到我们对语音信号的清晰接收。尤其是在语音识别、通信以及音频录制等领域,噪声问题尤为突出。噪声抑制技术能够显著提高语音信号的清晰度和可懂度,它对提升用户体验和优化语音相关系统性能发挥着至关重要的作用。 ## 1.2 噪声抑制技术的发展历程 从早期的模拟滤波器到如今的数字信号处理技术,噪声抑制技术经历了长

【推荐系统评估指南】:ROC曲线在个性化推荐中的重要性分析

# 1. 个性化推荐系统概述 在当今信息泛滥的时代,个性化推荐系统已成为解决信息过载问题的重要工具。个性化推荐系统基于用户的过去行为、喜好、社交网络以及情境上下文等信息,向用户推荐他们可能感兴趣的商品或内容。推荐系统不但提升了用户的满意度和平台的用户体验,也为商家带来了更高的经济效益。这一章节将对个性化推荐系统的设计原理、主要类型以及核心算法进行概览介绍,为后续章节的深入讨论打下基础。接下来,我们将探讨评估指标在推荐系统中的重要性,以及如何通过这些指标衡量推荐效果的好坏。 # 2. 评估指标的重要性 ### 2.1 评估指标的分类 #### 2.1.1 点击率(Click-Throug

实战技巧:如何使用MAE作为模型评估标准

![实战技巧:如何使用MAE作为模型评估标准](https://img-blog.csdnimg.cn/img_convert/6960831115d18cbc39436f3a26d65fa9.png) # 1. 模型评估标准MAE概述 在机器学习与数据分析的实践中,模型的评估标准是确保模型质量和可靠性的关键。MAE(Mean Absolute Error,平均绝对误差)作为一种常用的评估指标,其核心在于衡量模型预测值与真实值之间差异的绝对值的平均数。相比其他指标,MAE因其直观、易于理解和计算的特点,在不同的应用场景中广受欢迎。在本章中,我们将对MAE的基本概念进行介绍,并探讨其在模型评估

F1-Score在机器学习中的优化策略:从理论到实战的快速指南

![F1-Score在机器学习中的优化策略:从理论到实战的快速指南](https://img-blog.csdnimg.cn/20190211193632766.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3JlYWxseXI=,size_16,color_FFFFFF,t_70) # 1. F1-Score在机器学习中的重要性 F1-Score是机器学习领域中非常重要的评估指标之一,尤其是在分类任务中。作为准确率(Precisio

AUC值与成本敏感学习:平衡误分类成本的实用技巧

![AUC值与成本敏感学习:平衡误分类成本的实用技巧](https://img-blog.csdnimg.cn/img_convert/280755e7901105dbe65708d245f1b523.png) # 1. AUC值与成本敏感学习概述 在当今IT行业和数据分析中,评估模型的性能至关重要。AUC值(Area Under the Curve)是衡量分类模型预测能力的一个标准指标,特别是在不平衡数据集中。与此同时,成本敏感学习(Cost-Sensitive Learning)作为机器学习的一个分支,旨在减少模型预测中的成本偏差。本章将介绍AUC值的基本概念,解释为什么在成本敏感学习中

图像融合技术实战:从理论到应用的全面教程

![计算机视觉(Computer Vision)](https://img-blog.csdnimg.cn/dff421fb0b574c288cec6cf0ea9a7a2c.png) # 1. 图像融合技术概述 随着信息技术的快速发展,图像融合技术已成为计算机视觉、遥感、医学成像等多个领域关注的焦点。**图像融合**,简单来说,就是将来自不同传感器或同一传感器在不同时间、不同条件下的图像数据,经过处理后得到一个新的综合信息。其核心目标是实现信息的有效集成,优化图像的视觉效果,增强图像信息的解释能力或改善特定任务的性能。 从应用层面来看,图像融合技术主要分为三类:**像素级**融合,直接对图