From 7fe89be50dd5f1da324009c378d19bb360e147c4 Mon Sep 17 00:00:00 2001
From: afeijia <ifeijia@qq.com>
Date: Fri, 15 Dec 2023 13:29:59 +0800
Subject: [PATCH] =?UTF-8?q?=E6=9C=BA=E5=99=A8=E4=BA=BA=E5=AE=9A=E4=BD=8D?=
 =?UTF-8?q?=20=E4=BB=BB=E5=8A=A1=E4=B8=8B=E5=8F=91=20=E5=B7=A1=E6=A3=80?=
 =?UTF-8?q?=E7=BB=93=E6=9E=9C?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit

---
 GQ_URP/GQ/Assets/ATemp.meta                   |    8 +
 GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat      |  126 ++
 GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat.meta |    8 +
 GQ_URP/GQ/Assets/Scenes/Temp.meta             |    8 +
 GQ_URP/GQ/Assets/Scenes/Temp/New Scene.unity  | 1225 +++++++++++++++++
 .../Assets/Scenes/Temp/New Scene.unity.meta   |    7 +
 GQ_URP/GQ/Assets/Scripts/WJ/Robot.meta        |    8 +
 .../Assets/Scripts/WJ/Robot/InterfaceTest.cs  |   90 ++
 .../Scripts/WJ/Robot/InterfaceTest.cs.meta    |   11 +
 .../Scripts/WJ/Robot/RobotDataManager.cs      |  636 +++++++++
 .../Scripts/WJ/Robot/RobotDataManager.cs.meta |   11 +
 .../Scripts/WJ/Robot/RobotMapCreater.cs       |   18 +
 .../Scripts/WJ/Robot/RobotMapCreater.cs.meta  |   11 +
 .../GQ/Assets/Scripts/WJ/Robot/RobotObject.cs |   95 ++
 .../Scripts/WJ/Robot/RobotObject.cs.meta      |   11 +
 GQ_URP/GQ/Assets/Scripts/WJ/Utilities.meta    |    8 +
 .../GQ/Assets/Scripts/WJ/Utilities/Classes.cs | 1022 ++++++++++++++
 .../Scripts/WJ/Utilities/Classes.cs.meta      |   11 +
 .../Scripts/WJ/Utilities/InterfaceManager.cs  |  273 ++++
 .../WJ/Utilities/InterfaceManager.cs.meta     |   11 +
 GQ_URP/GQ/Assets/StreamingAssets/robot.txt    |    5 +
 .../GQ/Assets/StreamingAssets/robot.txt.meta  |    7 +
 22 files changed, 3610 insertions(+)
 create mode 100644 GQ_URP/GQ/Assets/ATemp.meta
 create mode 100644 GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat
 create mode 100644 GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat.meta
 create mode 100644 GQ_URP/GQ/Assets/Scenes/Temp.meta
 create mode 100644 GQ_URP/GQ/Assets/Scenes/Temp/New Scene.unity
 create mode 100644 GQ_URP/GQ/Assets/Scenes/Temp/New Scene.unity.meta
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Robot.meta
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Robot/InterfaceTest.cs
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Robot/InterfaceTest.cs.meta
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotDataManager.cs
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotDataManager.cs.meta
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotMapCreater.cs
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotMapCreater.cs.meta
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotObject.cs
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotObject.cs.meta
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Utilities.meta
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Utilities/Classes.cs
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Utilities/Classes.cs.meta
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Utilities/InterfaceManager.cs
 create mode 100644 GQ_URP/GQ/Assets/Scripts/WJ/Utilities/InterfaceManager.cs.meta
 create mode 100644 GQ_URP/GQ/Assets/StreamingAssets/robot.txt
 create mode 100644 GQ_URP/GQ/Assets/StreamingAssets/robot.txt.meta

diff --git a/GQ_URP/GQ/Assets/ATemp.meta b/GQ_URP/GQ/Assets/ATemp.meta
new file mode 100644
index 000000000..ff92b309a
--- /dev/null
+++ b/GQ_URP/GQ/Assets/ATemp.meta
@@ -0,0 +1,8 @@
+fileFormatVersion: 2
+guid: 741582b0d3c129649a26e0b61e028e00
+folderAsset: yes
+DefaultImporter:
+  externalObjects: {}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat b/GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat
new file mode 100644
index 000000000..98a4e694b
--- /dev/null
+++ b/GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat
@@ -0,0 +1,126 @@
+%YAML 1.1
+%TAG !u! tag:unity3d.com,2011:
+--- !u!114 &-1224730893789095258
+MonoBehaviour:
+  m_ObjectHideFlags: 11
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 0}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: d0353a89b1f911e48b9e16bdc9f2e058, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  version: 5
+--- !u!21 &2100000
+Material:
+  serializedVersion: 8
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_Name: DisplayOrigin
+  m_Shader: {fileID: 4800000, guid: 933532a4fcc9baf4fa0491de14d08ed7, type: 3}
+  m_ValidKeywords: []
+  m_InvalidKeywords: []
+  m_LightmapFlags: 4
+  m_EnableInstancingVariants: 0
+  m_DoubleSidedGI: 0
+  m_CustomRenderQueue: -1
+  stringTagMap:
+    RenderType: Opaque
+  disabledShaderPasses: []
+  m_SavedProperties:
+    serializedVersion: 3
+    m_TexEnvs:
+    - _BaseMap:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _BumpMap:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _DetailAlbedoMap:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _DetailMask:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _DetailNormalMap:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _EmissionMap:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _MainTex:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _MetallicGlossMap:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _OcclusionMap:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _ParallaxMap:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - _SpecGlossMap:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - unity_Lightmaps:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - unity_LightmapsInd:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    - unity_ShadowMasks:
+        m_Texture: {fileID: 0}
+        m_Scale: {x: 1, y: 1}
+        m_Offset: {x: 0, y: 0}
+    m_Ints: []
+    m_Floats:
+    - _AlphaClip: 0
+    - _Blend: 0
+    - _BumpScale: 1
+    - _ClearCoatMask: 0
+    - _ClearCoatSmoothness: 0
+    - _Cull: 2
+    - _Cutoff: 0.5
+    - _DetailAlbedoMapScale: 1
+    - _DetailNormalMapScale: 1
+    - _DstBlend: 0
+    - _EnvironmentReflections: 1
+    - _GlossMapScale: 0
+    - _Glossiness: 0
+    - _GlossyReflections: 0
+    - _Metallic: 0
+    - _OcclusionStrength: 1
+    - _Parallax: 0.005
+    - _QueueOffset: 0
+    - _ReceiveShadows: 1
+    - _Smoothness: 0.5
+    - _SmoothnessTextureChannel: 0
+    - _SpecularHighlights: 1
+    - _SrcBlend: 1
+    - _Surface: 0
+    - _WorkflowMode: 1
+    - _ZWrite: 1
+    m_Colors:
+    - _BaseColor: {r: 0, g: 0, b: 1, a: 1}
+    - _Color: {r: 0, g: 0, b: 1, a: 1}
+    - _EmissionColor: {r: 0, g: 0, b: 0, a: 1}
+    - _SpecColor: {r: 0.19999996, g: 0.19999996, b: 0.19999996, a: 1}
+  m_BuildTextureStacks: []
diff --git a/GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat.meta b/GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat.meta
new file mode 100644
index 000000000..e5a8421a0
--- /dev/null
+++ b/GQ_URP/GQ/Assets/ATemp/DisplayOrigin.mat.meta
@@ -0,0 +1,8 @@
+fileFormatVersion: 2
+guid: 19bb1aa084d3a2c44aeb2f85fe619887
+NativeFormatImporter:
+  externalObjects: {}
+  mainObjectFileID: 2100000
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scenes/Temp.meta b/GQ_URP/GQ/Assets/Scenes/Temp.meta
new file mode 100644
index 000000000..22ff93960
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scenes/Temp.meta
@@ -0,0 +1,8 @@
+fileFormatVersion: 2
+guid: f245e35bc6812714daa96301797a61ce
+folderAsset: yes
+DefaultImporter:
+  externalObjects: {}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scenes/Temp/New Scene.unity b/GQ_URP/GQ/Assets/Scenes/Temp/New Scene.unity
new file mode 100644
index 000000000..e8ca3e999
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scenes/Temp/New Scene.unity	
@@ -0,0 +1,1225 @@
+%YAML 1.1
+%TAG !u! tag:unity3d.com,2011:
+--- !u!29 &1
+OcclusionCullingSettings:
+  m_ObjectHideFlags: 0
+  serializedVersion: 2
+  m_OcclusionBakeSettings:
+    smallestOccluder: 5
+    smallestHole: 0.25
+    backfaceThreshold: 100
+  m_SceneGUID: 00000000000000000000000000000000
+  m_OcclusionCullingData: {fileID: 0}
+--- !u!104 &2
+RenderSettings:
+  m_ObjectHideFlags: 0
+  serializedVersion: 9
+  m_Fog: 0
+  m_FogColor: {r: 0.5, g: 0.5, b: 0.5, a: 1}
+  m_FogMode: 3
+  m_FogDensity: 0.01
+  m_LinearFogStart: 0
+  m_LinearFogEnd: 300
+  m_AmbientSkyColor: {r: 0.212, g: 0.227, b: 0.259, a: 1}
+  m_AmbientEquatorColor: {r: 0.114, g: 0.125, b: 0.133, a: 1}
+  m_AmbientGroundColor: {r: 0.047, g: 0.043, b: 0.035, a: 1}
+  m_AmbientIntensity: 1
+  m_AmbientMode: 0
+  m_SubtractiveShadowColor: {r: 0.42, g: 0.478, b: 0.627, a: 1}
+  m_SkyboxMaterial: {fileID: 10304, guid: 0000000000000000f000000000000000, type: 0}
+  m_HaloStrength: 0.5
+  m_FlareStrength: 1
+  m_FlareFadeSpeed: 3
+  m_HaloTexture: {fileID: 0}
+  m_SpotCookie: {fileID: 10001, guid: 0000000000000000e000000000000000, type: 0}
+  m_DefaultReflectionMode: 0
+  m_DefaultReflectionResolution: 128
+  m_ReflectionBounces: 1
+  m_ReflectionIntensity: 1
+  m_CustomReflection: {fileID: 0}
+  m_Sun: {fileID: 0}
+  m_IndirectSpecularColor: {r: 0.18028378, g: 0.22571412, b: 0.30692285, a: 1}
+  m_UseRadianceAmbientProbe: 0
+--- !u!157 &3
+LightmapSettings:
+  m_ObjectHideFlags: 0
+  serializedVersion: 12
+  m_GIWorkflowMode: 1
+  m_GISettings:
+    serializedVersion: 2
+    m_BounceScale: 1
+    m_IndirectOutputScale: 1
+    m_AlbedoBoost: 1
+    m_EnvironmentLightingMode: 0
+    m_EnableBakedLightmaps: 1
+    m_EnableRealtimeLightmaps: 0
+  m_LightmapEditorSettings:
+    serializedVersion: 12
+    m_Resolution: 2
+    m_BakeResolution: 40
+    m_AtlasSize: 1024
+    m_AO: 0
+    m_AOMaxDistance: 1
+    m_CompAOExponent: 1
+    m_CompAOExponentDirect: 0
+    m_ExtractAmbientOcclusion: 0
+    m_Padding: 2
+    m_LightmapParameters: {fileID: 0}
+    m_LightmapsBakeMode: 1
+    m_TextureCompression: 1
+    m_FinalGather: 0
+    m_FinalGatherFiltering: 1
+    m_FinalGatherRayCount: 256
+    m_ReflectionCompression: 2
+    m_MixedBakeMode: 2
+    m_BakeBackend: 1
+    m_PVRSampling: 1
+    m_PVRDirectSampleCount: 32
+    m_PVRSampleCount: 512
+    m_PVRBounces: 2
+    m_PVREnvironmentSampleCount: 256
+    m_PVREnvironmentReferencePointCount: 2048
+    m_PVRFilteringMode: 1
+    m_PVRDenoiserTypeDirect: 1
+    m_PVRDenoiserTypeIndirect: 1
+    m_PVRDenoiserTypeAO: 1
+    m_PVRFilterTypeDirect: 0
+    m_PVRFilterTypeIndirect: 0
+    m_PVRFilterTypeAO: 0
+    m_PVREnvironmentMIS: 1
+    m_PVRCulling: 1
+    m_PVRFilteringGaussRadiusDirect: 1
+    m_PVRFilteringGaussRadiusIndirect: 5
+    m_PVRFilteringGaussRadiusAO: 2
+    m_PVRFilteringAtrousPositionSigmaDirect: 0.5
+    m_PVRFilteringAtrousPositionSigmaIndirect: 2
+    m_PVRFilteringAtrousPositionSigmaAO: 1
+    m_ExportTrainingData: 0
+    m_TrainingDataDestination: TrainingData
+    m_LightProbeSampleCountMultiplier: 4
+  m_LightingDataAsset: {fileID: 0}
+  m_LightingSettings: {fileID: 0}
+--- !u!196 &4
+NavMeshSettings:
+  serializedVersion: 2
+  m_ObjectHideFlags: 0
+  m_BuildSettings:
+    serializedVersion: 2
+    agentTypeID: 0
+    agentRadius: 0.5
+    agentHeight: 2
+    agentSlope: 45
+    agentClimb: 0.4
+    ledgeDropHeight: 0
+    maxJumpAcrossDistance: 0
+    minRegionArea: 2
+    manualCellSize: 0
+    cellSize: 0.16666667
+    manualTileSize: 0
+    tileSize: 256
+    accuratePlacement: 0
+    maxJobWorkers: 0
+    preserveTilesOutsideBounds: 0
+    debug:
+      m_Flags: 0
+  m_NavMeshData: {fileID: 0}
+--- !u!1 &100928288
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 100928290}
+  - component: {fileID: 100928289}
+  - component: {fileID: 100928291}
+  m_Layer: 0
+  m_Name: Directional Light
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!108 &100928289
+Light:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 100928288}
+  m_Enabled: 1
+  serializedVersion: 10
+  m_Type: 1
+  m_Shape: 0
+  m_Color: {r: 1, g: 0.95686275, b: 0.8392157, a: 1}
+  m_Intensity: 1
+  m_Range: 10
+  m_SpotAngle: 30
+  m_InnerSpotAngle: 21.80208
+  m_CookieSize: 10
+  m_Shadows:
+    m_Type: 2
+    m_Resolution: -1
+    m_CustomResolution: -1
+    m_Strength: 1
+    m_Bias: 0.05
+    m_NormalBias: 0.4
+    m_NearPlane: 0.2
+    m_CullingMatrixOverride:
+      e00: 1
+      e01: 0
+      e02: 0
+      e03: 0
+      e10: 0
+      e11: 1
+      e12: 0
+      e13: 0
+      e20: 0
+      e21: 0
+      e22: 1
+      e23: 0
+      e30: 0
+      e31: 0
+      e32: 0
+      e33: 1
+    m_UseCullingMatrixOverride: 0
+  m_Cookie: {fileID: 0}
+  m_DrawHalo: 0
+  m_Flare: {fileID: 0}
+  m_RenderMode: 0
+  m_CullingMask:
+    serializedVersion: 2
+    m_Bits: 4294967295
+  m_RenderingLayerMask: 1
+  m_Lightmapping: 4
+  m_LightShadowCasterMode: 0
+  m_AreaSize: {x: 1, y: 1}
+  m_BounceIntensity: 1
+  m_ColorTemperature: 6570
+  m_UseColorTemperature: 0
+  m_BoundingSphereOverride: {x: 0, y: 0, z: 0, w: 0}
+  m_UseBoundingSphereOverride: 0
+  m_UseViewFrustumForShadowCasterCull: 1
+  m_ShadowRadius: 0
+  m_ShadowAngle: 0
+--- !u!4 &100928290
+Transform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 100928288}
+  m_LocalRotation: {x: 0.40821788, y: -0.23456968, z: 0.10938163, w: 0.8754261}
+  m_LocalPosition: {x: 0, y: 3, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children: []
+  m_Father: {fileID: 0}
+  m_RootOrder: 1
+  m_LocalEulerAnglesHint: {x: 50, y: -30, z: 0}
+--- !u!114 &100928291
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 100928288}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: 474bcb49853aa07438625e644c072ee6, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  m_Version: 1
+  m_UsePipelineSettings: 1
+  m_AdditionalLightsShadowResolutionTier: 2
+  m_LightLayerMask: 1
+  m_CustomShadowLayers: 0
+  m_ShadowLayerMask: 1
+  m_LightCookieSize: {x: 1, y: 1}
+  m_LightCookieOffset: {x: 0, y: 0}
+--- !u!1 &363971834
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 363971835}
+  - component: {fileID: 363971838}
+  - component: {fileID: 363971837}
+  - component: {fileID: 363971836}
+  m_Layer: 0
+  m_Name: Robot
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!224 &363971835
+RectTransform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 363971834}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: 0, y: 0, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children: []
+  m_Father: {fileID: 543541846}
+  m_RootOrder: 0
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+  m_AnchorMin: {x: 0, y: 0}
+  m_AnchorMax: {x: 0, y: 0}
+  m_AnchoredPosition: {x: 30, y: 30}
+  m_SizeDelta: {x: 30, y: 30}
+  m_Pivot: {x: 0.5, y: 0.5}
+--- !u!114 &363971836
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 363971834}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: 204b2add5d8a2794fa97ca8d1756f6ab, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  rect_transform: {fileID: 0}
+  origin_x: 0
+  origin_y: 0
+  pixel_width: 0
+  pixel_height: 0
+  resolution: 0
+  display_x: 0
+  display_y: 0
+--- !u!114 &363971837
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 363971834}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: fe87c0e1cc204ed48ad3b37840f39efc, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  m_Material: {fileID: 0}
+  m_Color: {r: 1, g: 1, b: 1, a: 1}
+  m_RaycastTarget: 1
+  m_RaycastPadding: {x: 0, y: 0, z: 0, w: 0}
+  m_Maskable: 1
+  m_OnCullStateChanged:
+    m_PersistentCalls:
+      m_Calls: []
+  m_Sprite: {fileID: 0}
+  m_Type: 0
+  m_PreserveAspect: 0
+  m_FillCenter: 1
+  m_FillMethod: 4
+  m_FillAmount: 1
+  m_FillClockwise: 1
+  m_FillOrigin: 0
+  m_UseSpriteMesh: 0
+  m_PixelsPerUnitMultiplier: 1
+--- !u!222 &363971838
+CanvasRenderer:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 363971834}
+  m_CullTransparentMesh: 1
+--- !u!1 &543541845
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 543541846}
+  - component: {fileID: 543541848}
+  - component: {fileID: 543541847}
+  m_Layer: 0
+  m_Name: Map
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!224 &543541846
+RectTransform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 543541845}
+  m_LocalRotation: {x: -0, y: -0, z: -0, w: 1}
+  m_LocalPosition: {x: 0, y: 0, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children:
+  - {fileID: 363971835}
+  m_Father: {fileID: 1499972057}
+  m_RootOrder: 1
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+  m_AnchorMin: {x: 0, y: 1}
+  m_AnchorMax: {x: 0, y: 1}
+  m_AnchoredPosition: {x: 67.72998, y: -139.58997}
+  m_SizeDelta: {x: 780.4545, y: 325.9091}
+  m_Pivot: {x: 0, y: 1}
+--- !u!114 &543541847
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 543541845}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: fe87c0e1cc204ed48ad3b37840f39efc, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  m_Material: {fileID: 0}
+  m_Color: {r: 1, g: 1, b: 1, a: 1}
+  m_RaycastTarget: 0
+  m_RaycastPadding: {x: 0, y: 0, z: 0, w: 0}
+  m_Maskable: 1
+  m_OnCullStateChanged:
+    m_PersistentCalls:
+      m_Calls: []
+  m_Sprite: {fileID: 21300000, guid: 67729fca5a703644f849fe158f392600, type: 3}
+  m_Type: 0
+  m_PreserveAspect: 0
+  m_FillCenter: 1
+  m_FillMethod: 4
+  m_FillAmount: 1
+  m_FillClockwise: 1
+  m_FillOrigin: 0
+  m_UseSpriteMesh: 0
+  m_PixelsPerUnitMultiplier: 1
+--- !u!222 &543541848
+CanvasRenderer:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 543541845}
+  m_CullTransparentMesh: 1
+--- !u!1 &960733264
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 960733265}
+  - component: {fileID: 960733267}
+  - component: {fileID: 960733266}
+  m_Layer: 5
+  m_Name: Image
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!224 &960733265
+RectTransform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 960733264}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: 0, y: 0, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children: []
+  m_Father: {fileID: 1499972057}
+  m_RootOrder: 0
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+  m_AnchorMin: {x: 0.5, y: 0.5}
+  m_AnchorMax: {x: 0.5, y: 0.5}
+  m_AnchoredPosition: {x: -421, y: -201.33334}
+  m_SizeDelta: {x: 100, y: 100}
+  m_Pivot: {x: 0.5, y: 0.5}
+--- !u!114 &960733266
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 960733264}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: fe87c0e1cc204ed48ad3b37840f39efc, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  m_Material: {fileID: 0}
+  m_Color: {r: 1, g: 1, b: 1, a: 1}
+  m_RaycastTarget: 1
+  m_RaycastPadding: {x: 0, y: 0, z: 0, w: 0}
+  m_Maskable: 1
+  m_OnCullStateChanged:
+    m_PersistentCalls:
+      m_Calls: []
+  m_Sprite: {fileID: 0}
+  m_Type: 0
+  m_PreserveAspect: 0
+  m_FillCenter: 1
+  m_FillMethod: 4
+  m_FillAmount: 1
+  m_FillClockwise: 1
+  m_FillOrigin: 0
+  m_UseSpriteMesh: 0
+  m_PixelsPerUnitMultiplier: 1
+--- !u!222 &960733267
+CanvasRenderer:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 960733264}
+  m_CullTransparentMesh: 1
+--- !u!1 &1101054774
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 1101054778}
+  - component: {fileID: 1101054777}
+  - component: {fileID: 1101054776}
+  - component: {fileID: 1101054775}
+  m_Layer: 0
+  m_Name: Map
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!64 &1101054775
+MeshCollider:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1101054774}
+  m_Material: {fileID: 0}
+  m_IsTrigger: 0
+  m_Enabled: 1
+  serializedVersion: 4
+  m_Convex: 0
+  m_CookingOptions: 30
+  m_Mesh: {fileID: 10209, guid: 0000000000000000e000000000000000, type: 0}
+--- !u!23 &1101054776
+MeshRenderer:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1101054774}
+  m_Enabled: 1
+  m_CastShadows: 1
+  m_ReceiveShadows: 1
+  m_DynamicOccludee: 1
+  m_StaticShadowCaster: 0
+  m_MotionVectors: 1
+  m_LightProbeUsage: 1
+  m_ReflectionProbeUsage: 1
+  m_RayTracingMode: 2
+  m_RayTraceProcedural: 0
+  m_RenderingLayerMask: 1
+  m_RendererPriority: 0
+  m_Materials:
+  - {fileID: 2100000, guid: 31321ba15b8f8eb4c954353edc038b1d, type: 2}
+  m_StaticBatchInfo:
+    firstSubMesh: 0
+    subMeshCount: 0
+  m_StaticBatchRoot: {fileID: 0}
+  m_ProbeAnchor: {fileID: 0}
+  m_LightProbeVolumeOverride: {fileID: 0}
+  m_ScaleInLightmap: 1
+  m_ReceiveGI: 1
+  m_PreserveUVs: 0
+  m_IgnoreNormalsForChartDetection: 0
+  m_ImportantGI: 0
+  m_StitchLightmapSeams: 1
+  m_SelectedEditorRenderState: 3
+  m_MinimumChartSize: 4
+  m_AutoUVMaxDistance: 0.5
+  m_AutoUVMaxAngle: 89
+  m_LightmapParameters: {fileID: 0}
+  m_SortingLayerID: 0
+  m_SortingLayer: 0
+  m_SortingOrder: 0
+  m_AdditionalVertexStreams: {fileID: 0}
+--- !u!33 &1101054777
+MeshFilter:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1101054774}
+  m_Mesh: {fileID: 10209, guid: 0000000000000000e000000000000000, type: 0}
+--- !u!4 &1101054778
+Transform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1101054774}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: -500, y: 0, z: 500}
+  m_LocalScale: {x: 100, y: 100, z: 100}
+  m_ConstrainProportionsScale: 1
+  m_Children: []
+  m_Father: {fileID: 1357320836}
+  m_RootOrder: 0
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!1 &1257654157
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 1257654160}
+  - component: {fileID: 1257654159}
+  - component: {fileID: 1257654158}
+  - component: {fileID: 1257654161}
+  m_Layer: 0
+  m_Name: Main Camera
+  m_TagString: MainCamera
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!81 &1257654158
+AudioListener:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1257654157}
+  m_Enabled: 1
+--- !u!20 &1257654159
+Camera:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1257654157}
+  m_Enabled: 1
+  serializedVersion: 2
+  m_ClearFlags: 1
+  m_BackGroundColor: {r: 0.19215687, g: 0.3019608, b: 0.4745098, a: 0}
+  m_projectionMatrixMode: 1
+  m_GateFitMode: 2
+  m_FOVAxisMode: 0
+  m_SensorSize: {x: 36, y: 24}
+  m_LensShift: {x: 0, y: 0}
+  m_FocalLength: 50
+  m_NormalizedViewPortRect:
+    serializedVersion: 2
+    x: 0
+    y: 0
+    width: 1
+    height: 1
+  near clip plane: 0.3
+  far clip plane: 1000
+  field of view: 60
+  orthographic: 0
+  orthographic size: 5
+  m_Depth: -1
+  m_CullingMask:
+    serializedVersion: 2
+    m_Bits: 4294967295
+  m_RenderingPath: -1
+  m_TargetTexture: {fileID: 0}
+  m_TargetDisplay: 0
+  m_TargetEye: 3
+  m_HDR: 1
+  m_AllowMSAA: 1
+  m_AllowDynamicResolution: 0
+  m_ForceIntoRT: 0
+  m_OcclusionCulling: 1
+  m_StereoConvergence: 10
+  m_StereoSeparation: 0.022
+--- !u!4 &1257654160
+Transform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1257654157}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: 0, y: 1, z: -10}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children: []
+  m_Father: {fileID: 0}
+  m_RootOrder: 0
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!114 &1257654161
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1257654157}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: a79441f348de89743a2939f4d699eac1, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  m_RenderShadows: 1
+  m_RequiresDepthTextureOption: 2
+  m_RequiresOpaqueTextureOption: 2
+  m_CameraType: 0
+  m_Cameras: []
+  m_RendererIndex: -1
+  m_VolumeLayerMask:
+    serializedVersion: 2
+    m_Bits: 1
+  m_VolumeTrigger: {fileID: 0}
+  m_VolumeFrameworkUpdateModeOption: 2
+  m_RenderPostProcessing: 0
+  m_Antialiasing: 0
+  m_AntialiasingQuality: 2
+  m_StopNaN: 0
+  m_Dithering: 0
+  m_ClearDepth: 1
+  m_AllowXRRendering: 1
+  m_RequiresDepthTexture: 0
+  m_RequiresColorTexture: 0
+  m_Version: 2
+--- !u!1 &1286005539
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 1286005540}
+  - component: {fileID: 1286005543}
+  - component: {fileID: 1286005542}
+  - component: {fileID: 1286005541}
+  m_Layer: 0
+  m_Name: DisplayOri(0,0)
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!4 &1286005540
+Transform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1286005539}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: 0, y: 0, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children: []
+  m_Father: {fileID: 1357320836}
+  m_RootOrder: 1
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!135 &1286005541
+SphereCollider:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1286005539}
+  m_Material: {fileID: 0}
+  m_IsTrigger: 0
+  m_Enabled: 1
+  serializedVersion: 2
+  m_Radius: 0.5
+  m_Center: {x: 0, y: 0, z: 0}
+--- !u!23 &1286005542
+MeshRenderer:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1286005539}
+  m_Enabled: 1
+  m_CastShadows: 1
+  m_ReceiveShadows: 1
+  m_DynamicOccludee: 1
+  m_StaticShadowCaster: 0
+  m_MotionVectors: 1
+  m_LightProbeUsage: 1
+  m_ReflectionProbeUsage: 1
+  m_RayTracingMode: 2
+  m_RayTraceProcedural: 0
+  m_RenderingLayerMask: 1
+  m_RendererPriority: 0
+  m_Materials:
+  - {fileID: 2100000, guid: 19bb1aa084d3a2c44aeb2f85fe619887, type: 2}
+  m_StaticBatchInfo:
+    firstSubMesh: 0
+    subMeshCount: 0
+  m_StaticBatchRoot: {fileID: 0}
+  m_ProbeAnchor: {fileID: 0}
+  m_LightProbeVolumeOverride: {fileID: 0}
+  m_ScaleInLightmap: 1
+  m_ReceiveGI: 1
+  m_PreserveUVs: 0
+  m_IgnoreNormalsForChartDetection: 0
+  m_ImportantGI: 0
+  m_StitchLightmapSeams: 1
+  m_SelectedEditorRenderState: 3
+  m_MinimumChartSize: 4
+  m_AutoUVMaxDistance: 0.5
+  m_AutoUVMaxAngle: 89
+  m_LightmapParameters: {fileID: 0}
+  m_SortingLayerID: 0
+  m_SortingLayer: 0
+  m_SortingOrder: 0
+  m_AdditionalVertexStreams: {fileID: 0}
+--- !u!33 &1286005543
+MeshFilter:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1286005539}
+  m_Mesh: {fileID: 10207, guid: 0000000000000000e000000000000000, type: 0}
+--- !u!1 &1294847474
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 1294847478}
+  - component: {fileID: 1294847477}
+  - component: {fileID: 1294847476}
+  - component: {fileID: 1294847475}
+  m_Layer: 0
+  m_Name: Robot
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!136 &1294847475
+CapsuleCollider:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1294847474}
+  m_Material: {fileID: 0}
+  m_IsTrigger: 0
+  m_Enabled: 1
+  m_Radius: 0.5
+  m_Height: 2
+  m_Direction: 1
+  m_Center: {x: 0, y: 0, z: 0}
+--- !u!23 &1294847476
+MeshRenderer:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1294847474}
+  m_Enabled: 1
+  m_CastShadows: 1
+  m_ReceiveShadows: 1
+  m_DynamicOccludee: 1
+  m_StaticShadowCaster: 0
+  m_MotionVectors: 1
+  m_LightProbeUsage: 1
+  m_ReflectionProbeUsage: 1
+  m_RayTracingMode: 2
+  m_RayTraceProcedural: 0
+  m_RenderingLayerMask: 1
+  m_RendererPriority: 0
+  m_Materials:
+  - {fileID: 2100000, guid: 31321ba15b8f8eb4c954353edc038b1d, type: 2}
+  m_StaticBatchInfo:
+    firstSubMesh: 0
+    subMeshCount: 0
+  m_StaticBatchRoot: {fileID: 0}
+  m_ProbeAnchor: {fileID: 0}
+  m_LightProbeVolumeOverride: {fileID: 0}
+  m_ScaleInLightmap: 1
+  m_ReceiveGI: 1
+  m_PreserveUVs: 0
+  m_IgnoreNormalsForChartDetection: 0
+  m_ImportantGI: 0
+  m_StitchLightmapSeams: 1
+  m_SelectedEditorRenderState: 3
+  m_MinimumChartSize: 4
+  m_AutoUVMaxDistance: 0.5
+  m_AutoUVMaxAngle: 89
+  m_LightmapParameters: {fileID: 0}
+  m_SortingLayerID: 0
+  m_SortingLayer: 0
+  m_SortingOrder: 0
+  m_AdditionalVertexStreams: {fileID: 0}
+--- !u!33 &1294847477
+MeshFilter:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1294847474}
+  m_Mesh: {fileID: 10208, guid: 0000000000000000e000000000000000, type: 0}
+--- !u!4 &1294847478
+Transform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1294847474}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: 0, y: 0, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children: []
+  m_Father: {fileID: 1357320836}
+  m_RootOrder: 2
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!1 &1316883623
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 1316883625}
+  - component: {fileID: 1316883624}
+  m_Layer: 0
+  m_Name: RobotManager
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!114 &1316883624
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1316883623}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: ba1987dfd90a1ed48a09c0e1bff9ab1a, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  rtCode: 0
+  RobotObject: {fileID: 363971836}
+  _pno: xj01
+--- !u!4 &1316883625
+Transform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1316883623}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: -6.917255, y: -11.471002, z: 11.9653}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children: []
+  m_Father: {fileID: 0}
+  m_RootOrder: 4
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!1 &1357320835
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 1357320836}
+  m_Layer: 0
+  m_Name: DisplayOrigin
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 0
+--- !u!4 &1357320836
+Transform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1357320835}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: 0, y: 0, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children:
+  - {fileID: 1101054778}
+  - {fileID: 1286005540}
+  - {fileID: 1294847478}
+  m_Father: {fileID: 0}
+  m_RootOrder: 3
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!1 &1499972053
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 1499972057}
+  - component: {fileID: 1499972056}
+  - component: {fileID: 1499972055}
+  - component: {fileID: 1499972054}
+  m_Layer: 5
+  m_Name: Canvas
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!114 &1499972054
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1499972053}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: dc42784cf147c0c48a680349fa168899, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  m_IgnoreReversedGraphics: 1
+  m_BlockingObjects: 0
+  m_BlockingMask:
+    serializedVersion: 2
+    m_Bits: 4294967295
+--- !u!114 &1499972055
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1499972053}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: 0cd44c1031e13a943bb63640046fad76, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  m_UiScaleMode: 0
+  m_ReferencePixelsPerUnit: 100
+  m_ScaleFactor: 1
+  m_ReferenceResolution: {x: 800, y: 600}
+  m_ScreenMatchMode: 0
+  m_MatchWidthOrHeight: 0
+  m_PhysicalUnit: 3
+  m_FallbackScreenDPI: 96
+  m_DefaultSpriteDPI: 96
+  m_DynamicPixelsPerUnit: 1
+  m_PresetInfoIsWorld: 0
+--- !u!223 &1499972056
+Canvas:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1499972053}
+  m_Enabled: 1
+  serializedVersion: 3
+  m_RenderMode: 0
+  m_Camera: {fileID: 0}
+  m_PlaneDistance: 100
+  m_PixelPerfect: 0
+  m_ReceivesEvents: 1
+  m_OverrideSorting: 0
+  m_OverridePixelPerfect: 0
+  m_SortingBucketNormalizedSize: 0
+  m_AdditionalShaderChannelsFlag: 0
+  m_SortingLayerID: 0
+  m_SortingOrder: 0
+  m_TargetDisplay: 0
+--- !u!224 &1499972057
+RectTransform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1499972053}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: 0, y: 0, z: 0}
+  m_LocalScale: {x: 0, y: 0, z: 0}
+  m_ConstrainProportionsScale: 0
+  m_Children:
+  - {fileID: 960733265}
+  - {fileID: 543541846}
+  m_Father: {fileID: 0}
+  m_RootOrder: 5
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+  m_AnchorMin: {x: 0, y: 0}
+  m_AnchorMax: {x: 0, y: 0}
+  m_AnchoredPosition: {x: 0, y: 0}
+  m_SizeDelta: {x: 0, y: 0}
+  m_Pivot: {x: 0, y: 0}
+--- !u!1 &1806016788
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 1806016790}
+  - component: {fileID: 1806016789}
+  - component: {fileID: 1806016791}
+  m_Layer: 0
+  m_Name: GameObject
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 0
+--- !u!114 &1806016789
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1806016788}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: 46320192a3399f14697958a6325ecb2a, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  url: '{\n  \"base_url\": \"https://10.7.6.50:8080\",\n  \"battery\": 0,\n  \"current_mapname\":
+    \"/home/cruiser/ros_ws/install/share/cruiser_navigation/maps/CWDT010@20231122_111258\",\n 
+    \"current_pose\": {\n    \"id\": \"e5691290-8b71-48db-991d-c6b503def8b4\",\n   
+    \"theta\": 1.7360243797302246,\n    \"x\": 5.016031742095947,\n    \"y\": -2.2412776947021484\n 
+    },\n  \"mode\": \"navigation\",\n  \"name\": null,\n  \"robotId\": \"56ce6c39b8144d91ac3767e757933955\",\n 
+    \"status\": null,\n  \"system_status\": \"Healthy;\",\n  \"system_status_code\":
+    0\n}'
+  query:
+  - ip
+  query_value:
+  - 117.136.12.79
+  post_json: 
+  _data: 
+  image: {fileID: 960733266}
+--- !u!4 &1806016790
+Transform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1806016788}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: 8.56917, y: 1.2629471, z: -6.928535}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children: []
+  m_Father: {fileID: 0}
+  m_RootOrder: 2
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
+--- !u!114 &1806016791
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 1806016788}
+  m_Enabled: 0
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: ba1987dfd90a1ed48a09c0e1bff9ab1a, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  rtCode: 0
+  RobotObject: {fileID: 0}
+  _pno: 
+--- !u!1 &2134203866
+GameObject:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  serializedVersion: 6
+  m_Component:
+  - component: {fileID: 2134203869}
+  - component: {fileID: 2134203868}
+  - component: {fileID: 2134203867}
+  m_Layer: 0
+  m_Name: EventSystem
+  m_TagString: Untagged
+  m_Icon: {fileID: 0}
+  m_NavMeshLayer: 0
+  m_StaticEditorFlags: 0
+  m_IsActive: 1
+--- !u!114 &2134203867
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 2134203866}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: 4f231c4fb786f3946a6b90b886c48677, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  m_HorizontalAxis: Horizontal
+  m_VerticalAxis: Vertical
+  m_SubmitButton: Submit
+  m_CancelButton: Cancel
+  m_InputActionsPerSecond: 10
+  m_RepeatDelay: 0.5
+  m_ForceModuleActive: 0
+--- !u!114 &2134203868
+MonoBehaviour:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 2134203866}
+  m_Enabled: 1
+  m_EditorHideFlags: 0
+  m_Script: {fileID: 11500000, guid: 76c392e42b5098c458856cdf6ecaaaa1, type: 3}
+  m_Name: 
+  m_EditorClassIdentifier: 
+  m_FirstSelected: {fileID: 0}
+  m_sendNavigationEvents: 1
+  m_DragThreshold: 10
+--- !u!4 &2134203869
+Transform:
+  m_ObjectHideFlags: 0
+  m_CorrespondingSourceObject: {fileID: 0}
+  m_PrefabInstance: {fileID: 0}
+  m_PrefabAsset: {fileID: 0}
+  m_GameObject: {fileID: 2134203866}
+  m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
+  m_LocalPosition: {x: 0, y: 0, z: 0}
+  m_LocalScale: {x: 1, y: 1, z: 1}
+  m_ConstrainProportionsScale: 0
+  m_Children: []
+  m_Father: {fileID: 0}
+  m_RootOrder: 6
+  m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
diff --git a/GQ_URP/GQ/Assets/Scenes/Temp/New Scene.unity.meta b/GQ_URP/GQ/Assets/Scenes/Temp/New Scene.unity.meta
new file mode 100644
index 000000000..fcd74e305
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scenes/Temp/New Scene.unity.meta	
@@ -0,0 +1,7 @@
+fileFormatVersion: 2
+guid: 156aed9dc474aca42be120d5129fdba2
+DefaultImporter:
+  externalObjects: {}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Robot.meta b/GQ_URP/GQ/Assets/Scripts/WJ/Robot.meta
new file mode 100644
index 000000000..52ed8eac8
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Robot.meta
@@ -0,0 +1,8 @@
+fileFormatVersion: 2
+guid: 8a23579ccee4cda48980583d99f8e07d
+folderAsset: yes
+DefaultImporter:
+  externalObjects: {}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Robot/InterfaceTest.cs b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/InterfaceTest.cs
new file mode 100644
index 000000000..8c5d354d5
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/InterfaceTest.cs
@@ -0,0 +1,90 @@
+using System.Collections;
+using System.Collections.Generic;
+using System.IO;
+using UnityEngine;
+using Newtonsoft.Json.Linq;
+using static InterfaceManager;
+using System;
+
+public class InterfaceTest : MonoBehaviour
+{
+    public string url;
+    public string[] query;
+    public string[] query_value;
+
+    public string post_json;
+    // Start is called before the first frame update
+    void Start()
+    {
+        //Debug.Log("{\n  \"base_url\": \"https://10.7.6.50:8080\",\n  \"battery\": 0,\n  \"current_mapname\": \"/home/cruiser/ros_ws/install/share/cruiser_navigation/maps/CWDT010@20231122_111258\",\n  \"current_pose\": {\n    \"id\": \"e5691290-8b71-48db-991d-c6b503def8b4\",\n    \"theta\": 1.7360243797302246,\n    \"x\": 5.016031742095947,\n    \"y\": -2.2412776947021484\n  },\n  \"mode\": \"navigation\",\n  \"name\": null,\n  \"robotId\": \"56ce6c39b8144d91ac3767e757933955\",\n  \"status\": null,\n  \"system_status\": \"Healthy;\",\n  \"system_status_code\": 0\n}");
+    }
+
+    // Update is called once per frame
+    void Update()
+    {
+        if (Input.GetKeyUp(KeyCode.G))
+        {
+            //����
+            //if (query != null && query_value != null)
+            //{
+            //    var dic = new Dictionary<string, string>();
+            //    for (int i = 0; i < query.Length; i++)
+            //    {
+            //        if (query_value.Length > i)
+            //        {
+            //            dic.Add(query[i], query_value[i]);
+            //        }
+            //    }
+            //    StartCoroutine(GetRequest(url, null, dic, (_data) =>
+            //    {
+            //        Debug.Log(_data);
+            //    }));
+            //}
+
+            if (query != null && query_value != null)
+            {
+                var dic = new Dictionary<string, string>();
+                for (int i = 0; i < query.Length; i++)
+                {
+                    if (query_value.Length > i)
+                    {
+                        dic.Add(query[i], query_value[i]);
+                    }
+                }
+                StartCoroutine(GetRequest(url, new Dictionary<string, string>() { { "Authorization", "none" } }, dic, (_error, _data) =>
+                {
+                    Debug.Log(_data);
+                }));
+            }
+
+
+
+        }
+
+        if (Input.GetKeyUp(KeyCode.P))
+        {
+            StartCoroutine(PostRequest(url, post_json, new Dictionary<string, string>() { { "Authorization", "none" } }, (_error, _data) =>
+            {
+                Debug.Log(_data);
+            }));
+        }
+
+
+        if (Input.GetKeyUp(KeyCode.Q))
+        {
+            Tex();
+        }
+    }
+
+    public string _data;
+    public UnityEngine.UI.Image image;
+    public void Tex()
+    {
+        byte[] bytes = Convert.FromBase64String(_data);
+        Texture2D text2D = new Texture2D(100, 100);
+        text2D.LoadImage(bytes);
+        Sprite sprite = Sprite.Create(text2D, new Rect(0, 0, text2D.width, text2D.height), new Vector2(0.5f, 0.5f));
+        //_callback?.Invoke(null, sprite);
+        image.sprite = sprite;
+    }
+}
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Robot/InterfaceTest.cs.meta b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/InterfaceTest.cs.meta
new file mode 100644
index 000000000..5d78faf20
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/InterfaceTest.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: 46320192a3399f14697958a6325ecb2a
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotDataManager.cs b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotDataManager.cs
new file mode 100644
index 000000000..008b54e0a
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotDataManager.cs
@@ -0,0 +1,636 @@
+using Newtonsoft.Json;
+using Newtonsoft.Json.Linq;
+using System.Collections;
+using System.Collections.Generic;
+using System.IO;
+using UnityEngine;
+using System.Net.WebSockets;
+using static InterfaceManager;
+using System.Threading;
+using System;
+using System.Text;
+using Unity.VisualScripting;
+
+public class RobotDataManager : MonoBehaviour
+{
+    [Header("��Ӧ�ɹ���")]
+    public string rtCode = "0";
+
+    #region ��ʼ������
+    /// <summary>
+    /// �Ƿ��ʼ������
+    /// </summary>
+    private bool init_data;
+    /// <summary>
+    /// �Ƿ��ѻ�ȡ���������б���
+    /// </summary>
+    private bool get_robot_list_done;
+    /// <summary>
+    /// �Ƿ��ѻ�ȡ�������б���
+    /// </summary>
+    private bool get_catrbin_list_done;
+    /// <summary>
+    /// �Ƿ��ѻ�ȡ�������˵�ͼ���ݡ�
+    /// </summary>
+    private bool get_robot_map_done;
+    /// <summary>
+    /// �Ƿ��ѻ�ȡ����������-Ѳ����б���ȡ�����������˵�ͼ���ݡ�
+    /// </summary>
+    private bool get_data_after_init_robot;
+    /// <summary>
+    /// ��������Ϣ���մ���
+    /// </summary>
+    private int get_info_times = 0;
+    #endregion
+
+    #region ��ʼ������
+
+    /// <summary>
+    /// ���������б������ݼ���
+    /// </summary>
+    public List<RobotClass> RobotList = new List<RobotClass>();
+    /// <summary>
+    /// �������б������ݼ���
+    /// </summary>
+    public List<CabinClass> CarbinList = new List<CabinClass>();
+    /// <summary>
+    /// ����������-Ѳ����б������ݼ���
+    /// </summary>
+    public List<RobotFixedPointins> RobotFixedPointsins = new List<RobotFixedPointins>();
+    /// <summary>
+    /// �������˵�ͼ������
+    /// </summary>
+    public RobotMap RobotMap = new RobotMap();
+    /// <summary>
+    /// �������������������
+    /// </summary>
+    public RobotTask RobotTask = new RobotTask();
+    /// <summary>
+    /// ��Ѳ�챨�����ݡ�
+    /// </summary>
+    public InsReport InsReport = new InsReport();
+
+    ///// <summary>
+    ///// ��������λ��״̬��Ϣ�����ݶ���
+    ///// </summary>
+    //public Queue<RobotPos> RobotPosQueue = new Queue<RobotPos>();
+    /// <summary>
+    /// ����������Ϣ��
+    /// </summary>
+    public Queue<RobotInfo[]> RobotInfosQueue = new Queue<RobotInfo[]>();
+
+    #endregion
+
+    #region ����
+
+    /// <summary>
+    /// �����˶���
+    /// </summary>
+    public RobotObject RobotObject;
+
+    #endregion
+
+    // Start is called before the first frame update
+    void Start()
+    {
+        ///��ȡ������Ϣ
+        StartCoroutine(GetRequest(Path.Combine(Application.streamingAssetsPath, "robot.txt"), null, null, (_error, _json) =>
+        {
+            if (_error != null)
+            {
+                Debug.Log("����������Ϣ������" + _error);
+                return;
+            }
+            JObject _j = JObject.Parse(_json);
+            http_ip_address = _j["http"].ToString();
+            ws_ip_address = _j["ws"].ToString();
+            http_ip_ma_address = _j["http_ma"].ToString();
+            isLive = true;
+        }));
+    }
+
+    public string _pno;
+    // Update is called once per frame
+    void Update()
+    {
+        Init();
+        if (Input.GetKeyUp(KeyCode.Y))
+        {
+            //UsageExample(_pno);
+            for (int i = 0; i < RobotFixedPointsins.Count; i++)
+            {
+                Debug.Log(RobotFixedPointsins[i].pointNo);
+            }
+        }
+        if (Input.GetKeyUp(KeyCode.J))
+        {
+            UsageExample(_pno);
+        }
+    }
+
+    /// <summary>
+    /// ��ҪStart�л�ȡ�������ڴ�ִ��
+    /// �ȴ�Start��ɱ����ļ���ȡ��ִ��
+    /// </summary>
+    public void Init()
+    {
+        if (!init_data && isLive)
+        {
+            init_data = true;
+            Debug.Log("��ʼ������");
+
+            //��ȡ�������б�
+            StartCoroutine(GetRequest(http_ip_address + get_robot_list, request_header, null, (_error, _data) =>
+            {
+                if (_error != null)
+                {
+                    Debug.Log("���󡾻������б�������" + _error);
+                    return;
+                }
+
+                var _response = JsonConvert.DeserializeObject<ResponseData>(_data);
+                Debug.Log(_response.rtMsg);
+                if (_response.rtCode.Equals(rtCode) && _response.rtData is JObject _jobject)
+                {
+                    if (_jobject != null)
+                    {
+                        RobotList = _jobject["list"].ToObject<List<RobotClass>>();
+
+                        //ʵ����ʵ�������
+                        RobotObject.RobotClass = RobotList[0];
+                    }
+                }
+                get_robot_list_done = true;
+            }));
+
+            //��ȡ�����б�
+            StartCoroutine(GetRequest(http_ip_address + get_cabin_list, request_header, new Dictionary<string, string>() { { "isExport", "false" }, { "pageSize", "200" } }, (_error, _data) =>
+            {
+                if (_error != null)
+                {
+                    Debug.Log("���󡾻����б�������" + _error);
+                    return;
+                }
+
+                var _response = JsonConvert.DeserializeObject<ResponseData>(_data);
+                Debug.Log(_response.rtMsg);
+                if (_response.rtCode.Equals(rtCode) && _response.rtData is JObject _jobject)
+                {
+                    if (_jobject != null)
+                    {
+                        CarbinList = _jobject["list"].ToObject<List<CabinClass>>();
+                    }
+                }
+                get_catrbin_list_done = true;
+            }));
+
+
+        }
+
+        if (get_robot_list_done && get_catrbin_list_done && !get_data_after_init_robot)
+        {
+            get_data_after_init_robot = true;
+
+            if (RobotList.Count < 1)
+            {
+                Debug.Log("�������б�С��1��");
+                return;
+            }
+
+            //��ȡ��������-Ѳ����б�
+            StartCoroutine(GetRequest(http_ip_address + get_robot_fixed_pointins, request_header, new Dictionary<string, string>() { { "roomId", RobotList[0].roomId }, { "pageSize", "200" } }, (_error, _data) =>
+            {
+                if (_error != null)
+                {
+                    Debug.Log("���󡾶�������-Ѳ����б�������" + _error);
+                    return;
+                }
+
+                var _response = JsonConvert.DeserializeObject<ResponseData>(_data);
+                Debug.Log(_response.rtMsg);
+                if (_response.rtCode.Equals(rtCode))
+                {
+                    RobotFixedPointsins = JsonConvert.DeserializeObject<List<RobotFixedPointins>>(_response.rtData.ToString());
+                }
+                get_catrbin_list_done = true;
+            }));
+
+            //��ȡ�����˵�ͼ����
+            StartCoroutine(GetRequest(http_ip_address + get_robot_map + RobotObject.RobotClass.robot_id + "/map", request_header, new Dictionary<string, string>() { { "robotId", RobotList[0].robot_id } }, (_error, _data) =>
+            {
+                if (_error != null)
+                {
+                    Debug.Log("���󡾻����˵�ͼ���ݡ�����" + _error);
+                    return;
+                }
+
+                var _response = JsonConvert.DeserializeObject<ResponseData>(_data);
+                Debug.Log(_response.rtMsg);
+                if (_response.rtCode.Equals(rtCode) && _response.rtData is JObject _jobject)
+                {
+                    if (_jobject != null)
+                    {
+                        RobotMap = _jobject.ToObject<RobotMap>();
+
+                        //ʵ����ʵ������˵ĵ�ͼ����
+                        RobotObject.RobotMap = RobotMap;
+                    }
+                }
+                get_robot_map_done = true;
+            }));
+
+            //websocket
+            WSRobotPos();
+            //WSRobotInfo();
+        }
+    }
+
+    #region WebSocket���ݽ���
+
+    private ClientWebSocket ws_robot_pos;
+
+    /// <summary>
+    /// ��������λ��״̬��Ϣ��
+    /// </summary>
+    private async void WSRobotPos()
+    {
+        try
+        {
+            ws_robot_pos = new ClientWebSocket();
+            CancellationToken ct = new CancellationToken();
+            var url = ws_ip_address + ws_robot_html5 + RobotObject.RobotClass.id;
+            Debug.Log(url);
+            Uri uri = new Uri(url);
+            await ws_robot_pos.ConnectAsync(uri, ct);
+
+            while (true)
+            {
+                Debug.Log("111");
+                var result = new byte[1024];
+                await ws_robot_pos.ReceiveAsync(new ArraySegment<byte>(result), new CancellationToken());
+                var str = Encoding.UTF8.GetString(result, 0, result.Length);
+                //��������
+                JObject _jobject = JObject.Parse(str);
+                if (_jobject != null && _jobject["msg"] != null)
+                {
+                    if (RobotObject != null)
+                    {
+                        RobotPos _robot_pos = JsonConvert.DeserializeObject<RobotPos>(_jobject["msg"].ToString());
+                        RobotObject.RobotPosQueue.Enqueue(_robot_pos);
+                    }
+                }
+            }
+        }
+        catch (Exception ex)
+        {
+            Debug.LogError(ex.ToString());
+        }
+    }
+
+    /// <summary>
+    /// ����������Ϣ��
+    /// </summary>
+    private async void WSRobotInfo()
+    {
+        ClientWebSocket ws = new ClientWebSocket();
+        CancellationToken ct = new CancellationToken();
+        Uri uri = new Uri(ws_ip_address + ws_robot_info);
+        await ws.ConnectAsync(uri, ct);
+
+        while (true)
+        {
+            if (get_info_times == 0) continue;
+
+            var result = new byte[1024];
+            await ws.ReceiveAsync(new ArraySegment<byte>(result), new CancellationToken());
+            var str = Encoding.UTF8.GetString(result, 0, result.Length);
+            //��������
+            RobotInfo[] _robot_info = JsonConvert.DeserializeObject<RobotInfo[]>(str.ToString());
+            RobotInfosQueue.Enqueue(_robot_info);
+
+            get_info_times++;
+        }
+    }
+    #endregion
+
+    #region ���ܵ�2���·�Ѳ������
+
+    /*
+     * ����������
+     * ���ܣ���������·�Ѳ������
+     * 1.����ȡ������������С��ȿ��������Ƿ�����Ѳ�죨û�в��·���
+     * 2.�����������·�����pointList�������С�pointNo ��Ϊ����Ѳ��㣬���������ճ�����
+     * 3.�·��󿴡���ȡ������������С��Ƿ�Ѳ�����
+     * 4.Ѳ����ɲ鿴����ѯѲ�챨�����ݡ�����pic���ֶε�ֵ�ӡ� thermal ����ʼ��֣���thermal��Ľ�ȡ���������͵���̨���б��档
+     */
+
+    /// <summary>
+    /// ���ܵ�2����ʾ��
+    /// </summary>
+    /// <param name="_point_no">����</param>
+    public void UsageExample(string _point_no)
+    {
+        //��ʼִ�е�һ������ѯ��ǰ�Ƿ�����Ѳ��
+        GetTaskQueue((_error, _no_task) =>
+        {
+            if (_error != null)
+            {
+                Debug.Log(_error);
+                return;
+            }
+
+            //�жϵ�ǰ�Ƿ�����Ѳ��
+            if (!_no_task)
+            {
+                //���׼���·�Ѳ������ʱ����Ѳ�죬��ִ�����²���
+                Debug.Log("��ǰ����Ѳ���У����Ժ����ԣ�");
+                //ToDo
+                //...
+                //return;
+            }
+
+            //��δ��Ѳ�죬ִ�еڶ������·�����
+            PostRobotTask(_point_no, (_error, _post_success) =>
+            {
+                //�ж��Ƿ��·��ɹ�
+                if (_error != null)
+                {
+                    Debug.Log(_error);
+                    return;
+                }
+                //�·��ɹ���ʼִ�е�������ѭ����ѯֱ����������
+                StartCoroutine(Cyclic_GetTaskQuery((_error) =>
+                 {
+                     if (_error != null)
+                     {
+                         Debug.Log(_error);
+                         return;
+                     }
+
+                     //���������ִ�е��IJ����鿴����ѯѲ�챨�����ݡ�����pic���ֶε�ֵ�ӡ� thermal ����ʼ��֣���thermal��Ľ�ȡ���������͵���̨���б���
+                     GetInsReport((_error, _success) =>
+                     {
+                         if (_error != null)
+                         {
+                             Debug.Log(_error);
+                             return;
+                         }
+
+                         Dictionary<string, List<string>> _pics = new Dictionary<string, List<string>>();
+
+                         for (int i = 0; i < InsReport.thermal.Count; i++)
+                         {
+                             var _ps = new List<string>();
+                             var pic1 = InsReport.thermal[i].pic1.Split("thermal")[1];
+                             var pic2 = InsReport.thermal[i].pic2.Split("thermal")[1];
+                             var pic3 = InsReport.thermal[i].pic3.Split("thermal")[1];
+                             var pic4 = InsReport.thermal[i].pic4.Split("thermal")[1];
+                             var pic5 = InsReport.thermal[i].pic5.Split("thermal")[1];
+                             var pic6 = InsReport.thermal[i].pic6.Split("thermal")[1];
+                             var pic7 = InsReport.thermal[i].pic7.Split("thermal")[1];
+
+                             _ps.Add(pic1);
+                             _ps.Add(pic2);
+                             _ps.Add(pic3);
+                             _ps.Add(pic4);
+                             _ps.Add(pic5);
+                             _ps.Add(pic6);
+                             _ps.Add(pic7);
+
+                             _pics.Add(InsReport.thermal[i].id, _ps);
+                         }
+                         //ToDo
+                         //�������õ����ݷ��͸���̨
+                         //...
+                         Debug.Log("ͼƬ·��������ɣ�");
+                     });
+                 }));
+            });
+        });
+    }
+
+    /// <summary>
+    /// ��ȡ�����������ж�
+    /// </summary>
+    /// <param name="_callback">����1���쳣��Ϣ������2��true->��ǰδ��Ѳ��</param>
+    public void GetTaskQueue(Action<string, bool> _callback = null)
+    {
+        Debug.Log("��ѯ��ǰѲ��״̬��...");
+        //ע��ӿڵ�ַ�����һ��Ϊ������id�����ڸ���ҵ���޸Ļ�����id
+        StartCoroutine(GetRequest(http_ip_address + get_task_queue + RobotObject.RobotClass.robot_id, request_header, null, (_error, _data) =>
+        {
+            if (_error != null)
+            {
+                _callback?.Invoke(_error, false);
+                return;
+            }
+
+            var _response = JsonConvert.DeserializeObject<ResponseData>(_data);
+            if (_response.rtCode.Equals(rtCode) && _response.rtData is JObject _jobject)
+            {
+                Debug.Log(_response.rtMsg);
+                if (_jobject != null)
+                {
+                    RobotTask = _jobject.ToObject<RobotTask>();
+
+                    //ʵ����ʵ������˵��������ݣ�ע�������id�Ƿ�ƥ��
+                    RobotObject.RobotTask = RobotTask;
+
+                    //�ж�ÿ�� RobotTask.data[].Task_type�Ƿ�Ϊfixed
+                    //...���û�з���True����ʾδ��Ѳ�죬���򷵻�False
+                    _callback?.Invoke(null, RobotTask.data == null || RobotTask.data.Count == 0);
+                }
+            }
+            else
+            {
+                _callback?.Invoke(_response.rtMsg, false);
+            }
+        }));
+    }
+
+    /// <summary>
+    /// �����������·�
+    /// </summary>
+    public void PostRobotTask(string _point_no, Action<string, bool> _callback = null)
+    {
+        string _json_data = "{\r\n  \"robotIp\": \"192.168.8.198\",\r\n  \"pointList\": [\r\n    {\r\n      \"pointNo\": \"" + _point_no + "\",\r\n      \"04\": \"0\",\r\n      \"06\": \"0\",\r\n      \"01\": \"1\",\r\n      \"cabinType\": \"1\",\r\n      \"03\": \"0\",\r\n      \"05\": \"0\"\r\n    }\r\n  ]\r\n}";
+
+        StartCoroutine(PostRequest(http_ip_address + post_robot_fixed_point, _json_data, request_header, (_error, _data) =>
+        {
+            if (_error != null)
+            {
+                Debug.Log(_error);
+                _callback?.Invoke(_error, false);
+                return;
+            }
+
+            var _response = JsonConvert.DeserializeObject<ResponseData>(_data);
+            Debug.Log(_response.rtMsg);
+            if (_response.rtCode.Equals(rtCode))//����ֵƥ���ʾ�·��ɹ�
+            {
+                //�·��ɹ���ѭ��ִ�л�ȡ������������У�ֱ���������Ϊ�պ����ִ�к�������
+                _callback?.Invoke(null, true);
+            }
+            else
+            {
+                _callback?.Invoke(_response.rtMsg, false);
+            }
+        }));
+    }
+
+    /// <summary>
+    /// ִ��ѭ����ѯ�ȴ�����
+    /// </summary>
+    /// <returns></returns>
+    public IEnumerator Cyclic_GetTaskQuery(Action<string> _callback = null)
+    {
+        int _call_time = 0;//����
+        int _response_time = 0;//���ش���
+        bool _finish = false;//����ѭ������
+        int _error_time = 0;
+        while (true)
+        {
+            if (_finish) break;
+
+            //ѭ����ѯ�쳣��������һ��ֵ��������ѯ������ѭ����������಻��Ҫ�Ŀ���
+            if (_error_time > 3)
+            {
+                _callback?.Invoke("��ѯ�쳣��");
+                break;
+            }
+
+            yield return new WaitForSeconds(3);
+
+            if (_call_time != _response_time) continue;
+
+            #region ����
+
+            if (_response_time == 3)
+            {
+                Debug.Log("���ԣ��ȴ���������");
+                _callback?.Invoke(null);
+                break;
+            }
+
+            #endregion
+
+            _call_time++;
+            Debug.Log("ִ�е�" + _call_time + "��ѭ��");
+            GetTaskQueue((_error, _no_task) =>
+            {
+                if (_error != null)
+                {
+                    _error_time++;
+                    _response_time++;
+                    Debug.Log("���󷵻ص�" + _response_time + "��");
+                    return;
+                }
+                if (_no_task)
+                {
+                    //��ǰ�����񣬽���ѭ������
+                    _finish = true;
+                    _callback?.Invoke(null);
+                }
+                else
+                {
+                    //��ǰ������δ����������ִ��ѭ�������ȴ��������
+                    _response_time++;
+                    Debug.Log("���󷵻ص�" + _response_time + "��");
+                }
+            });
+        }
+        yield return null;
+    }
+
+    /// <summary>
+    /// ��ȡѲ�챨������
+    /// </summary>
+    public void GetInsReport(Action<string, bool> _callback)
+    {
+        //�貹�������������������������е�Ins_Id,����ҵ��ɸѡ��������
+        StartCoroutine(GetRequest(http_ip_address + get_record_ins_report, request_header, new Dictionary<string, string>() { { "insId", RobotTask.data[0].Ins_Id } }, (_error, _data) =>
+        {
+            if (_error != null)
+            {
+                Debug.Log(_error);
+                _callback?.Invoke(_error, false);
+                return;
+            }
+
+            var _response = JsonConvert.DeserializeObject<ResponseData>(_data);
+            if (_response.rtCode.Equals(rtCode) && _response.rtData is JObject _jobject)
+            {
+                Debug.Log(_response.rtMsg);
+                if (_jobject != null)
+                {
+                    InsReport = _jobject.ToObject<InsReport>();
+
+                    _callback?.Invoke(null, true);
+                }
+            }
+            else
+            {
+                _callback?.Invoke(_response.rtMsg, false);
+            }
+        }));
+    }
+
+    #endregion
+
+    #region ���ܵ�3��Ѳ�����鿴
+
+    public void ViewInspectionResults(Action<string, List<Sprite>> _callback)
+    {
+        //ע�ⲹ��Tokenֵ
+        StartCoroutine(GetRequest(http_ip_ma_address + get_inspection, new Dictionary<string, string>() { { "X-Token", "" } }, null, (_error, _data) =>
+        {
+            if (_error != null)
+            {
+                Debug.Log(_error);
+                _callback?.Invoke(_error, null);
+                return;
+            }
+
+            ResponseData_ma response = JsonConvert.DeserializeObject<ResponseData_ma>(_data);
+            if (response.message.Equals("�����ɹ�") && response.data is JObject jobject)
+            {
+                if (response.data != null)
+                {
+                    var inspection_datas = jobject.ToObject<List<InspectionResult>>();
+
+                    var sprites = new List<Sprite>();
+                    for (int i = 0; i < inspection_datas.Count; i++)
+                    {
+                        //base64תͼƬ
+                        byte[] bytes = Convert.FromBase64String(_data);
+                        Texture2D text2D = new Texture2D(100, 100);
+                        text2D.LoadImage(bytes);
+                        Sprite sprite = Sprite.Create(text2D, new Rect(0, 0, text2D.width, text2D.height), new Vector2(0.5f, 0.5f));
+                        sprites.Add(sprite);
+                    }
+                    _callback?.Invoke(null, sprites);
+                }
+            }
+        }));
+    }
+
+    #endregion
+
+    private void OnDestroy()
+    {
+        CloseClientWebSocket();
+    }
+
+    /// <summary>
+    /// �ر�ClientWebSocket��
+    /// </summary>
+    public void CloseClientWebSocket()
+    {
+        //�ر�Socket
+        if (ws_robot_pos != null && ws_robot_pos.State == WebSocketState.Open)
+        {
+            var task = ws_robot_pos.CloseAsync(WebSocketCloseStatus.NormalClosure, string.Empty, CancellationToken.None);
+            task.Wait();
+        }
+    }
+}
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotDataManager.cs.meta b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotDataManager.cs.meta
new file mode 100644
index 000000000..0e7c6a5f6
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotDataManager.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: ba1987dfd90a1ed48a09c0e1bff9ab1a
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotMapCreater.cs b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotMapCreater.cs
new file mode 100644
index 000000000..d68fffc3f
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotMapCreater.cs
@@ -0,0 +1,18 @@
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+
+public class RobotMapCreater : MonoBehaviour
+{
+    // Start is called before the first frame update
+    void Start()
+    {
+        
+    }
+
+    // Update is called once per frame
+    void Update()
+    {
+        
+    }
+}
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotMapCreater.cs.meta b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotMapCreater.cs.meta
new file mode 100644
index 000000000..81b2797df
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotMapCreater.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: 6e1b4822f6974f843a826d8df9bc7d96
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotObject.cs b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotObject.cs
new file mode 100644
index 000000000..3a26be00d
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotObject.cs
@@ -0,0 +1,95 @@
+using BestHTTP.SecureProtocol.Org.BouncyCastle.Tsp;
+using System.Collections;
+using System.Collections.Generic;
+using UnityEngine;
+using DG.Tweening;
+using UnityEngine.UI;
+
+/// <summary>
+/// �����˶���
+/// </summary>
+public class RobotObject : MonoBehaviour
+{
+    public RectTransform rect_transform;
+    /*
+     bmp_x = origin.x
+     */
+    /// <summary>
+    /// ��������Ϣ
+    /// </summary>
+    public RobotClass RobotClass = null;
+    /// <summary>
+    /// �����˵�ͼ����
+    /// </summary>
+    public RobotMap RobotMap = null;
+    /// <summary>
+    /// ������λ��״̬��Ϣ
+    /// </summary>
+    public Queue<RobotPos> RobotPosQueue = new Queue<RobotPos>();
+    /// <summary>
+    /// �������������
+    /// </summary>
+    public RobotTask RobotTask = null;
+
+    /// <summary>
+    /// ��ǰִ�еĻ�����λ����Ϣ
+    /// </summary>
+    private RobotPos current_robot_pos = null;
+
+    //�̶�ֵ
+    public int origin_x;//=info.origin.x
+    public int origin_y;//=info.origin.y
+    public int pixel_width;//info.width
+    public int pixel_height;//info.height
+    public double resolution;//=info.resolution
+    //public double bmp_x;//=origin.x/resolution
+    //public double bmp_y;//=info.height-(origin.y/resolution)
+    //public float bmp_h;//=info.height
+    //public float bmp_w;//=info.width
+
+    //ʵʱֵ
+    //public double map_x;//=current_pos.x
+    //public double map_y;//=current_pos.y
+    public double display_x;//=(current_pos.x-origin.x)/resolution
+    public double display_y;//=(current_pos.y-origin.y)/resolution
+
+    private bool get;
+    // Start is called before the first frame update
+    void Start()
+    {
+        rect_transform = GetComponent<RectTransform>();
+    }
+
+    // Update is called once per frame
+    void Update()
+    {
+        if (RobotClass == null || RobotMap == null) return;
+        if (!get)
+        {
+            get = true;
+            origin_x = RobotMap.info.origin.x;
+            origin_y = RobotMap.info.origin.y;
+            pixel_width = RobotMap.info.width;
+            pixel_height = RobotMap.info.height;
+            resolution = RobotMap.info.resolution;
+        }
+
+        if (RobotPosQueue.Count > 0 && current_robot_pos == null)
+        {
+            current_robot_pos = RobotPosQueue.Peek();
+            //Debug.Log(Newtonsoft.Json.JsonConvert.SerializeObject(current_robot_pos));
+
+            display_x = (current_robot_pos.current_pose.x - origin_x) / resolution;
+            display_y = (current_robot_pos.current_pose.x - origin_y) / resolution;
+
+            display_x *= (rect_transform.sizeDelta.x / pixel_width);
+            display_y *= (rect_transform.sizeDelta.y / pixel_height);
+
+            rect_transform.DOAnchorPos(new Vector2((float)display_x, (float)display_y), 0.5f).OnComplete(() =>
+            {
+                RobotPosQueue.Dequeue();
+                current_robot_pos = null;
+            });
+        }
+    }
+}
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotObject.cs.meta b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotObject.cs.meta
new file mode 100644
index 000000000..7e9114031
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Robot/RobotObject.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: 204b2add5d8a2794fa97ca8d1756f6ab
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Utilities.meta b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities.meta
new file mode 100644
index 000000000..c31681c51
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities.meta
@@ -0,0 +1,8 @@
+fileFormatVersion: 2
+guid: c2b807ba48e50a44aa3ec0c213d3f0cd
+folderAsset: yes
+DefaultImporter:
+  externalObjects: {}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/Classes.cs b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/Classes.cs
new file mode 100644
index 000000000..4ccb58dc9
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/Classes.cs
@@ -0,0 +1,1022 @@
+
+using GQ;
+using System.Collections.Generic;
+using static UnityEngine.UI.Image;
+
+/// <summary>
+/// ��Ӧ����
+/// </summary>
+public class ResponseData
+{
+    public string rtCode { get; set; }
+    public string rtMsg { get; set; }
+    public object rtData { get; set; }
+}
+
+
+/// <summary>
+/// �����������
+/// </summary>
+public class RobotClass
+{
+    /// <summary>
+    /// ״̬����
+    /// </summary>
+    public string statusStr { get; set; }
+    /// <summary>
+    /// �������ͺ�id
+    /// </summary>
+    public int modelId { get; set; }
+    /// <summary>
+    /// ����������
+    /// </summary>
+    public string robotName { get; set; }
+    /// <summary>
+    /// ����ʱ��
+    /// </summary>
+    public string updateTime { get; set; }
+    /// <summary>
+    /// ��ע
+    /// </summary>
+    public string remark { get; set; }
+    /// <summary>
+    /// �ͺ�����
+    /// </summary>
+    public string modelType { get; set; }
+    /// <summary>
+    /// IP
+    /// </summary>
+    public string ipAddr { get; set; }
+    /// <summary>
+    /// ����id
+    /// </summary>
+    public string roomId { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public string roomName { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pileout_time { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string picUrl { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string robot_status { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string taskScheduStatus { get; set; }
+    /// <summary>
+    /// ������id
+    /// </summary>
+    public string robot_id { get; set; }
+    /// <summary>
+    /// ����������
+    /// </summary>
+    public string name { get; set; }
+    /// <summary>
+    /// ��������״̬
+    /// </summary>
+    public string onOffLineStatus { get; set; }
+    /// <summary>
+    /// �ͺ�����
+    /// </summary>
+    public string model { get; set; }
+    /// <summary>
+    /// ������id
+    /// </summary>
+    public string id { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string power { get; set; }
+    /// <summary>
+    /// ����״̬
+    /// </summary>
+    public string runStatus { get; set; }
+    /// <summary>
+    /// ������״̬
+    /// </summary>
+    public string status { get; set; }
+}
+
+/// <summary>
+/// ���������
+/// </summary>
+public class CabinClass
+{
+    /// <summary>
+    /// ����id
+    /// </summary>
+    public string id { get; set; }
+    /// <summary>
+    /// ����ID
+    /// </summary>
+    public string roomId { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string serialNo { get; set; }
+    /// <summary>
+    /// R72ʡ��/5.8G LTE/LoRa�豸��
+    /// </summary>
+    public string name { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string type { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string description { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string baseUrl { get; set; }
+    /// <summary>
+    /// Uλ
+    /// </summary>
+    public string unum { get; set; }
+    /// <summary>
+    /// ����
+    /// </summary>
+    public string widthHeight { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string createUid { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string status { get; set; }
+    /// <summary>
+    /// ����ʱ��
+    /// </summary>
+    public string createTime { get; set; }
+    /// <summary>
+    /// ����ʱ��
+    /// </summary>
+    public string updateTime { get; set; }
+    /// <summary>
+    /// ����
+    /// </summary>
+    public string width { get; set; }
+    /// <summary>
+    /// �߶�
+    /// </summary>
+    public string height { get; set; }
+    /// <summary>
+    /// ���
+    /// </summary>
+    public string deep { get; set; }
+    /// <summary>
+    /// �߿�ߴ�
+    /// </summary>
+    public string borderSize { get; set; }
+    /// <summary>
+    /// ����������
+    /// </summary>
+    public string typeCode { get; set; }
+    /// <summary>
+    /// ������������
+    /// </summary>
+    public string typeName { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public string roomName { get; set; }
+    /// <summary>
+    /// �豸����
+    /// </summary>
+    public int deviceNum { get; set; }
+}
+
+#region �����˵�ͼ����
+
+/// <summary>
+/// �����˵�ͼ��Ϣ
+/// </summary>
+public class RobotMapInfo
+{
+    /// <summary>
+    /// �߶�
+    /// </summary>
+    public int height { get; set; }
+    /// <summary>
+    /// �����ͼԭ��
+    /// </summary>
+    public RobotMapOrigin origin { get; set; }
+    /// <summary>
+    /// �ֱ���
+    /// </summary>
+    public double resolution { get; set; }
+    /// <summary>
+    /// ����
+    /// </summary>
+    public int width { get; set; }
+}
+
+/// <summary>
+/// �����˵�ͼ���������ͼԭ��
+/// </summary>
+public class RobotMapOrigin
+{
+    /// <summary>
+    /// 
+    /// </summary>
+    public string id { get; set; }
+    /// <summary>
+    /// �Ƕ�
+    /// </summary>
+    public int theta { get; set; }
+    /// <summary>
+    /// x����
+    /// </summary>
+    public int x { get; set; }
+    /// <summary>
+    /// y����
+    /// </summary>
+    public int y { get; set; }
+}
+
+/// <summary>
+/// �����˵�ͼ
+/// </summary>
+public class RobotMap
+{
+    /// <summary>
+    /// 
+    /// </summary>
+    public RobotMapInfo info { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string limit_speed_area { get; set; }
+    /// <summary>
+    /// ��ͼ����
+    /// </summary>
+    public string map_name { get; set; }
+    /// <summary>
+    /// ��ͼ����
+    /// </summary>
+    public string png_map { get; set; }
+    /// <summary>
+    /// ����������
+    /// </summary>
+    public List<RobotMapPoint> point { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string tracker { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string umap { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public List<RobotMapWall> wall { get; set; }
+}
+
+/// <summary>
+/// �����˵�ͼ��������������
+/// </summary>
+public class RobotMapPoint
+{
+    /// <summary>
+    /// ����
+    /// </summary>
+    public string description { get; set; }
+    /// <summary>
+    /// ��ʾx����
+    /// </summary>
+    public double display_x { get; set; }
+    /// <summary>
+    /// ��ʾy����
+    /// </summary>
+    public double display_y { get; set; }
+    /// <summary>
+    /// ��ͼx����
+    /// </summary>
+    public double map_x { get; set; }
+    /// <summary>
+    /// ��ͼy����
+    /// </summary>
+    public double map_y { get; set; }
+    /// <summary>
+    /// �����
+    /// </summary>
+    public string point_name { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string point_type { get; set; }
+    /// <summary>
+    /// �Ƕ�
+    /// </summary>
+    public double theta { get; set; }
+}
+
+/// <summary>
+/// �����˵�ͼWall
+/// </summary>
+public class RobotMapWall
+{
+
+    /// <summary>
+    /// 
+    /// </summary>
+    public List<double> data { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string type { get; set; }
+}
+#endregion
+
+
+/// <summary>
+/// ��������-Ѳ����б�
+/// </summary>
+public class RobotFixedPointins
+{
+    /// <summary>
+    /// ����id
+    /// </summary>
+    public string cabinId { get; set; }
+    /// <summary>
+    /// ��ע
+    /// </summary>
+    public string remark { get; set; }
+    /// <summary>
+    /// ����������
+    /// </summary>
+    public string directionName { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public string cabinType { get; set; }
+    /// <summary>
+    /// Ѳ�����
+    /// </summary>
+    public string pointNo { get; set; }
+    /// <summary>
+    /// ����id
+    /// </summary>
+    public string roomId { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string cabinNo { get; set; }
+    /// <summary>
+    /// �����
+    /// </summary>
+    public int sequence { get; set; }
+    /// <summary>
+    /// ������������
+    /// </summary>
+    public string cabinTypeName { get; set; }
+    /// <summary>
+    /// Ѳ���id
+    /// </summary>
+    public string id { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public string cabinName { get; set; }
+    /// <summary>
+    /// ���������
+    /// </summary>
+    public string direction { get; set; }
+    /// <summary>
+    /// Ѳ���״̬
+    /// </summary>
+    public int status { get; set; }
+}
+
+#region ������λ��״̬��Ϣ
+
+/// <summary>
+/// ��ǰ����
+/// </summary>
+public class Current_pose
+{
+    /// <summary>
+    /// 
+    /// </summary>
+    public string id { get; set; }
+    /// <summary>
+    /// �Ƕ�
+    /// </summary>
+    public double theta { get; set; }
+    /// <summary>
+    /// x����
+    /// </summary>
+    public double x { get; set; }
+    /// <summary>
+    /// y����
+    /// </summary>
+    public double y { get; set; }
+}
+
+/// <summary>
+/// ������λ��״̬��Ϣ
+/// </summary>
+public class RobotPos
+{
+    /// <summary>
+    /// 
+    /// </summary>
+    public string base_url { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public int battery { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string current_mapname { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public Current_pose current_pose { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string mode { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string name { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string robotId { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string status { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string system_status { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public int system_status_code { get; set; }
+}
+
+#endregion
+
+#region ��������Ϣ
+
+public class RobotInfo
+{
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pm25_value { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public int modelId { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string temperature_value { get; set; }
+    /// <summary>
+    /// ʪ��
+    /// </summary>
+    public string humidity_text { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string ipAddr { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string roomId { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string picUrl { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string onOffLineStatus { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string model { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string id { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public int power { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string runStatus { get; set; }
+    /// <summary>
+    /// Ѳ�������
+    /// </summary>
+    public string robotName { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pm25_text { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string updateTime { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string modelType { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string roomName { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pileout_time { get; set; }
+    /// <summary>
+    /// �¶�
+    /// </summary>
+    public string temperature_text { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string robot_status { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public int charger { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string humidity_value { get; set; }
+    /// <summary>
+    /// �豸�¶�
+    /// </summary>
+    public string equipment_temperature_text { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string robot_id { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string patrol_point_no { get; set; }
+    /// <summary>
+    /// Ѳ�������
+    /// </summary>
+    public string name { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string task_type { get; set; }
+    /// <summary>
+    /// ����
+    /// </summary>
+    public string noise_text { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string noise_value { get; set; }
+}
+
+#endregion
+
+public class RobotTask
+{
+    /// <summary>
+    /// ����������
+    /// </summary>
+    public List<RobotTask_data> data { get; set; }
+    /// <summary>
+    /// ������id
+    /// </summary>
+    public string robotId { get; set; }
+}
+/// <summary>
+/// ���������������
+/// </summary>
+public class RobotTask_data
+{
+    /// <summary>
+    /// ����id
+    /// </summary>
+    public string Tast_Id { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string Ins_Id { get; set; }
+    /// <summary>
+    /// �������id
+    /// </summary>
+    public string TaskQueue_Id { get; set; }
+    /// <summary>
+    /// ����״̬
+    /// </summary>
+    public string Task_State { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public string taskName { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string Task_Name { get; set; }
+    /// <summary>
+    /// ������������
+    /// </summary>
+    public string taskTypeName { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public static string Task_type{get;set;}
+    /// <summary>
+    /// ����㼯��
+    /// </summary>
+    public List<RobotTask_pois> Pois { get; set; }
+}
+
+/// <summary>
+/// 
+/// </summary>
+public class RobotTask_pois
+{
+    /// <summary>
+    /// ����״̬
+    /// </summary>
+    public string OpenDoor_State { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string Point_Name { get; set; }
+    /// <summary>
+    /// ����״̬
+    /// </summary>
+    public string Sensor_State { get; set; }
+    /// <summary>
+    /// �ȳ���״̬
+    /// </summary>
+    public string Inventory_State { get; set; }
+    /// <summary>
+    /// ����״̬
+    /// </summary>
+    public string CloseDoor_State { get; set; }
+    /// <summary>
+    /// ��׼��״̬
+    /// </summary>
+    public string TakeNormalPhoto_State { get; set; }
+    /// <summary>
+    /// ��״̬
+    /// </summary>
+    public string Point_State { get; set; }
+    /// <summary>
+    /// ��ά���̵�״̬
+    /// </summary>
+    public string QrInventory_State { get; set; }
+    /// <summary>
+    /// ����״̬
+    /// </summary>
+    public string Photo_State { get; set; }
+    /// <summary>
+    /// ������Ƶ״̬
+    /// </summary>
+    public string Voice_State { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string cabinNo { get; set; }
+}
+
+#region Ѳ�챨������
+
+public class InsItem
+{
+    /// <summary>
+    /// �澯��¼id
+    /// </summary>
+    public string alarmId { get; set; }
+    /// <summary>
+    /// �澯�ȼ�
+    /// </summary>
+    public string alarmLevel { get; set; }
+    /// <summary>
+    /// �澯�ȼ�����
+    /// </summary>
+    public string alarmLevelName { get; set; }
+    /// <summary>
+    /// �澯״̬ 1�澯 0 δ�澯
+    /// </summary>
+    public string alarmStatus { get; set; }
+    /// <summary>
+    /// �澯����
+    /// </summary>
+    public string alarmType { get; set; }
+    /// <summary>
+    /// �澯��������
+    /// </summary>
+    public string alarmTypeName { get; set; }
+    /// <summary>
+    /// ����id
+    /// </summary>
+    public string cabinId { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public string cabinName { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string cabinNo { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public string cabinType { get; set; }
+    /// <summary>
+    /// �豸id
+    /// </summary>
+    public string equipmentId { get; set; }
+    /// <summary>
+    /// �豸����
+    /// </summary>
+    public string equipmentName { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string id { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string image { get; set; }
+    /// <summary>
+    /// ���
+    /// </summary>
+    public int index { get; set; }
+    /// <summary>
+    /// Ѳ���¼id
+    /// </summary>
+    public string inspectionId { get; set; }
+    /// <summary>
+    /// �ɼ���ͼƬ��ַ
+    /// </summary>
+    public string picUrl { get; set; }
+    /// <summary>
+    /// ʶ�������
+    /// </summary>
+    public string pointStation { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string position { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string positionName { get; set; }
+    /// <summary>
+    /// ʶ���id
+    /// </summary>
+    public string resizePointId { get; set; }
+    /// <summary>
+    /// ʶ�������
+    /// </summary>
+    public string resizePointName { get; set; }
+    /// <summary>
+    /// ʶ�������
+    /// </summary>
+    public string resizePointType { get; set; }
+    /// <summary>
+    /// ʶ�����������
+    /// </summary>
+    public string resizePointTypeName { get; set; }
+    /// <summary>
+    /// ������id
+    /// </summary>
+    public string robotId { get; set; }
+    /// <summary>
+    /// ����������
+    /// </summary>
+    public string robotName { get; set; }
+    /// <summary>
+    /// ����id
+    /// </summary>
+    public string roomId { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public string roomName { get; set; }
+    /// <summary>
+    /// ʶ���ʶ����
+    /// </summary>
+    public string status { get; set; }
+    /// <summary>
+    /// ����ʱ��
+    /// </summary>
+    public string updateTime { get; set; }
+}
+
+public class ThermalItem
+{
+    /// <summary>
+    /// �澯�ȼ�
+    /// </summary>
+    public string alarmLevel { get; set; }
+    /// <summary>
+    /// �澯�ȼ�����
+    /// </summary>
+    public string alarmLevelName { get; set; }
+    /// <summary>
+    /// �澯״̬ 1�澯 0δ�澯
+    /// </summary>
+    public string alarmStatus { get; set; }
+    /// <summary>
+    /// �澯����
+    /// </summary>
+    public string alarmType { get; set; }
+    /// <summary>
+    /// �澯��������
+    /// </summary>
+    public string alarmTypeName { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string cabinDirection { get; set; }
+    /// <summary>
+    /// ����id
+    /// </summary>
+    public string cabinId { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string cabinName { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string cabinNo { get; set; }
+    /// <summary>
+    /// �ȳ������ݼ�¼id
+    /// </summary>
+    public string id { get; set; }
+    /// <summary>
+    /// ����
+    /// </summary>
+    public int index { get; set; }
+    /// <summary>
+    /// Ѳ���¼id
+    /// </summary>
+    public string inspectionId { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pic1 { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pic2 { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pic3 { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pic4 { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pic5 { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pic6 { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string pic7 { get; set; }
+    /// <summary>
+    /// ������id
+    /// </summary>
+    public string robotId { get; set; }
+    /// <summary>
+    /// ����������
+    /// </summary>
+    public string robotName { get; set; }
+    /// <summary>
+    /// ����id
+    /// </summary>
+    public string roomId { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string roomName { get; set; }
+    /// <summary>
+    /// �ȳ�����Ƭ������Ϣ
+    /// </summary>
+    public string status { get; set; }
+    /// <summary>
+    /// �ȳ�������
+    /// </summary>
+    public string thermalData { get; set; }
+    /// <summary>
+    /// �澯ʱ��
+    /// </summary>
+    public string time { get; set; }
+}
+
+/// <summary>
+/// Ѳ�챨��
+/// </summary>
+public class InsReport
+{
+    /// <summary>
+    /// ��ɱ���
+    /// </summary>
+    public string completionRatio { get; set; }
+    /// <summary>
+    /// �������ʱ��
+    /// </summary>
+    public string endTime { get; set; }
+    /// <summary>
+    /// �ɼ�������
+    /// </summary>
+    public List<InsItem> ins { get; set; }
+    /// <summary>
+    /// ������
+    /// </summary>
+    public string pointNum { get; set; }
+    /// <summary>
+    /// ����ʼʱ��
+    /// </summary>
+    public string startTime { get; set; }
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public string taskName { get; set; }
+    /// <summary>
+    /// �ȳ�������
+    /// </summary>
+    public List<ThermalItem> thermal { get; set; }
+    /// <summary>
+    /// �������ʱ�� ����
+    /// </summary>
+    public string times { get; set; }
+}
+
+#endregion
+
+
+public class ResponseData_ma
+{
+    /// <summary>
+    /// 
+    /// </summary>
+    public string code { get; set; }
+    /// <summary>
+    /// �����ɹ�
+    /// </summary>
+    public string message { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public object data { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string serverTime { get; set; }
+}
+
+/// <summary>
+/// Ѳ��������
+/// </summary>
+public class InspectionResult
+{
+    /// <summary>
+    /// 
+    /// </summary>
+    public int id { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string inspectionResult { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public int instructId { get; set; }
+    /// <summary>
+    /// 
+    /// </summary>
+    public string createTime { get; set; }
+}
\ No newline at end of file
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/Classes.cs.meta b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/Classes.cs.meta
new file mode 100644
index 000000000..87baa94e5
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/Classes.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: 150239179b5713241b84cb14da8f8fa8
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/InterfaceManager.cs b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/InterfaceManager.cs
new file mode 100644
index 000000000..9740dbbaf
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/InterfaceManager.cs
@@ -0,0 +1,273 @@
+using System;
+using System.Collections;
+using System.Collections.Generic;
+using System.Text;
+using UnityEngine;
+using UnityEngine.Networking;
+
+public static class InterfaceManager
+{
+    #region �ӿڵ�ַ
+
+    /// <summary>
+    /// �Ƿ����
+    /// </summary>
+    public static bool isLive = false;
+
+    /// <summary>
+    /// http�ӿ�ip��ַ
+    /// </summary>
+    public static string http_ip_address {  get; set; }
+
+    /// <summary>
+    /// ws�����ַ
+    /// </summary>
+    public static string ws_ip_address { get; set; }
+
+    /// <summary>
+    /// ���ʲ��ṩ�ĺ�̨ip,
+    /// </summary>
+    public static string http_ip_ma_address {  get; set; }
+
+    /// <summary>
+    /// ����ͷ
+    /// </summary>
+    public static Dictionary<string, string> request_header = new Dictionary<string, string>() { { "Authorization", "none" } };
+
+    /// <summary>
+    /// �����б�
+    /// ������
+    /// isExport=false&currentPage=1&pageSize=10
+    /// </summary>
+    public static string get_room_list => "/jk/room/list";
+
+    /// <summary>
+    /// Ѳ������
+    /// ������
+    /// pageSize=1&currentPage=0&isExport=false
+    /// </summary>
+    public static string get_record_list => "/jk/record/list";
+
+    /// <summary>
+    /// �������б�
+    /// </summary>
+    public static string get_robot_list => "/jk/robot/list";
+
+    /// <summary>
+    /// �豸�б�
+    /// ������
+    /// isExport=false
+    /// </summary>
+    public static string get_device_list => "/jk/device/list";
+
+    /// <summary>
+    /// �����б�
+    /// ������
+    /// isExport=false
+    /// pageSize=200
+    /// </summary>
+    public static string get_cabin_list => "/jk/cabin/list";
+
+    /// <summary>
+    /// ����������ͷ��Ϣ
+    /// ������
+    /// robotId=56ce6c39b8144d91ac3767e757933955
+    /// </summary>
+    public static string get_robot_camera_rtsp => "/jk/robotParam/getCameraRtspParams";
+
+    /// <summary>
+    /// �����˵�ͼ
+    /// ע��ӿڲ�����/robot/{robotId}/map
+    /// ������
+    /// robotId=56ce6c39b8144d91ac3767e757933955
+    /// </summary>
+    public static string get_robot_map => "/jk/robot/";
+
+    /// <summary>
+    /// �����б���ѯ
+    /// </summary>
+    public static string get_task_list => "/jk/task/list";
+
+    /// <summary>
+    /// ��������
+    /// </summary>
+    public static string get_task => "/jk/task/2fc8b609e202404db573946da7e30b57";
+
+    /// <summary>
+    /// �������������
+    /// 
+    /// </summary>
+    public static string get_task_queue => "/jk/task/taskqueue/list/";
+
+    /// <summary>
+    /// ���������·�
+    /// ������
+    /// {  "robotIp": "192.168.8.198",  "pointList": [    {      "pointNo": "xj01",      "04": "0",      "06": "0",      "01": "1",      "cabinType": "1",      "03": "0",      "05": "0"    }  ]}
+    /// </summary>
+    public static string post_robot_fixed_point => "/jk/robot/dofixedPointins";
+
+    /// <summary>
+    /// ����ִ����������е�����
+    /// ������
+    /// {  "robotId": "3e42c3014eb5463a94602c13dfc0921c",  "TaskQueue_Id": "1686128400786",  "interfaceNo": "goToQueueTask"}
+    /// </summary>
+    public static string post_robot_send_commond => "/jk/interface/sendCommand";
+
+    /// <summary>
+    /// ��������-Ѳ����б���ѯ�ӿ�
+    /// ������
+    /// roomId=0703de6c8f6111eeb00f0242ac0a0005
+    /// </summary>
+    public static string get_robot_fixed_pointins => "/jk/robot/fixedPointins";
+
+    /// <summary>
+    /// Ѳ�������·�
+    /// ������
+    /// {  "taskId": "",  "robotId": "56ce6c39b8144d91ac3767e757933955",  "robotIp": "192.168.8.198"}
+    /// </summary>
+    public static string post_robot_doins_task => "/jk/robot/doinsTask";
+
+    /// <summary>
+    /// Ѳ������-�����б���ѯ�ӿ�
+    /// ������
+    /// roomId=0703de6c8f6111eeb00f0242ac0a0005
+    /// </summary>
+    public static string get_robot_ins_task => "/jk/robot/insTask";
+
+    /// <summary>
+    /// ��ѯѲ�챨������
+    /// ������
+    /// insId=6978d1982a4449c48f7e4b2064d1b28b
+    /// </summary>
+    public static string get_record_ins_report => "/jk/record/insReport";
+
+    /// <summary>
+    /// Ѳ�����ݸ澯����
+    /// ������
+    /// isExport=false 
+    /// rocerdId=1f77ddf75f9f490ba84fb2a125962903
+    /// </summary>
+    public static string get_record_task_list => "/jk/record/tasklist";
+
+    /// <summary>
+    /// Ѳ������ͣ��λ�ø澯�б�
+    /// ������
+    /// inspectionPointId=1f77ddf75f9f490ba84fb2a125962903
+    /// </summary>
+    public static string get_record_dev_list => "/jk/record/devList";
+
+    /// <summary>
+    /// Ѳ������ͣ��λ��Ѳ��ͼƬ
+    /// ������
+    /// inspectionPointId=1f77ddf75f9f490ba84fb2a125962903
+    /// </summary>
+    public static string get_record_pic => "/jk/record/getPic";
+
+    /// <summary>
+    /// ��ȡ��������Ϣ
+    /// </summary>
+    public static string ws_robot_info => "/jk/api/robotinfo/clkc5gnu5000d3p6p8lu41tnj-clkc5gnu5000e3p6pvux9aid3-socket_index_page_robot_info";
+
+    /// <summary>
+    /// ������λ��״̬��Ϣ
+    /// ������
+    /// ������id��ֱ��ƴ���ڵ�ַ����
+    /// </summary>
+    public static string ws_robot_html5 => "/jk/api/html5/";
+
+    /// <summary>
+    /// Ѳ����
+    /// </summary>
+    public static string get_inspection => "/robot/queryInspection";
+
+    #endregion
+
+    #region ���ӿ�
+
+    /// <summary>
+    /// Get����
+    /// </summary>
+    /// <param name="_url"></param>
+    /// <param name="_header"></param>
+    /// <param name="_query"></param>
+    /// <param name="_callback"></param>
+    /// <returns></returns>
+    public static IEnumerator GetRequest(string _url, Dictionary<string, string> _header = null, Dictionary<string, string> _query = null, Action<string, string> _callback = null)
+    {
+
+        StringBuilder builder = new StringBuilder();
+        builder.Append(_url);
+
+        if (_query != null)
+        {
+            builder.Append("?");
+            int i = 0;
+            foreach (var item in _query)
+            {
+                if (i > 0)
+                    builder.Append("&");
+                builder.AppendFormat("{0}={1}", item.Key, item.Value);
+                i++;
+            }
+        }
+
+        using (UnityWebRequest request = UnityWebRequest.Get(builder.ToString()))
+        {
+            if (_header != null)
+            {
+                foreach (var item in _header)
+                {
+                    request.SetRequestHeader(item.Key, item.Value);
+                }
+            }
+
+            yield return request.SendWebRequest();
+
+            if (request.error != null)
+            {
+                _callback?.Invoke(request.error, null);
+            }
+            else
+            {
+                _callback?.Invoke(null, request.downloadHandler.text);
+            }
+        }
+    }
+
+    /// <summary>
+    /// Post����
+    /// </summary>
+    /// <param name="_url"></param>
+    /// <param name="_post_json"></param>
+    /// <param name="_callback"></param>
+    /// <returns></returns>
+    public static IEnumerator PostRequest(string _url, string _post_json, Dictionary<string, string> _header = null, Action<string, string> _callback = null)
+    {
+        using (UnityWebRequest request = new UnityWebRequest(_url, "POST"))
+        {
+            var data = Encoding.UTF8.GetBytes(_post_json);
+            request.uploadHandler = new UploadHandlerRaw(data);
+            request.downloadHandler = new DownloadHandlerBuffer();
+
+            if (_header != null)
+            {
+                foreach (var item in _header)
+                {
+                    request.SetRequestHeader(item.Key, item.Value);
+                }
+            }
+
+            yield return request.SendWebRequest();
+            if (request.error != null)
+            {
+                _callback?.Invoke(request.error, null);
+            }
+            else
+            {
+                _callback?.Invoke(null, request.downloadHandler.text);
+            }
+        }
+    }
+
+    #endregion
+}
diff --git a/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/InterfaceManager.cs.meta b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/InterfaceManager.cs.meta
new file mode 100644
index 000000000..5a8e733fb
--- /dev/null
+++ b/GQ_URP/GQ/Assets/Scripts/WJ/Utilities/InterfaceManager.cs.meta
@@ -0,0 +1,11 @@
+fileFormatVersion: 2
+guid: fd68e83d441514845924ab921fd17b5d
+MonoImporter:
+  externalObjects: {}
+  serializedVersion: 2
+  defaultReferences: []
+  executionOrder: 0
+  icon: {instanceID: 0}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: 
diff --git a/GQ_URP/GQ/Assets/StreamingAssets/robot.txt b/GQ_URP/GQ/Assets/StreamingAssets/robot.txt
new file mode 100644
index 000000000..574eca184
--- /dev/null
+++ b/GQ_URP/GQ/Assets/StreamingAssets/robot.txt
@@ -0,0 +1,5 @@
+{
+"http":"http://192.168.8.11:8000",
+"ws":"ws://192.168.8.11:8000",
+"http_ma":"http://192.168.8.11:8081"
+}
\ No newline at end of file
diff --git a/GQ_URP/GQ/Assets/StreamingAssets/robot.txt.meta b/GQ_URP/GQ/Assets/StreamingAssets/robot.txt.meta
new file mode 100644
index 000000000..40eed85a1
--- /dev/null
+++ b/GQ_URP/GQ/Assets/StreamingAssets/robot.txt.meta
@@ -0,0 +1,7 @@
+fileFormatVersion: 2
+guid: d0d0e688921029c41990e42fdb1ab73b
+DefaultImporter:
+  externalObjects: {}
+  userData: 
+  assetBundleName: 
+  assetBundleVariant: