|
@@ -1,696 +1,604 @@
|
|
|
-using Newtonsoft.Json;
|
|
|
-using System;
|
|
|
-using System.Collections;
|
|
|
-using System.Collections.Generic;
|
|
|
-using UnityEngine;
|
|
|
-using UnityEngine.UI;
|
|
|
-using Ximmerse.XR.Tag;
|
|
|
-
|
|
|
-public class MachineSceneManager : MonoSingleton<MachineSceneManager>
|
|
|
-{
|
|
|
-
|
|
|
- public MachineRoomData data;
|
|
|
-
|
|
|
- public GameObject cabinetObj;
|
|
|
-
|
|
|
- public GameObject bladeServer;
|
|
|
-
|
|
|
- public bool isInit = false;
|
|
|
-
|
|
|
- public MachineRoomTagData tagData;
|
|
|
-
|
|
|
- public List<EditorTag> listEditorTag;
|
|
|
- GameObject tagObjPoint;
|
|
|
- private List<BladeServerItem> listBSItem;
|
|
|
-
|
|
|
- public TagTracking foundTracking;
|
|
|
-
|
|
|
- public GameObject cubeY;
|
|
|
-
|
|
|
- public Transform leftLine;
|
|
|
- public Transform rightLine;
|
|
|
-
|
|
|
- bool isSelect = false;
|
|
|
-
|
|
|
- private Transform selectTrigger;
|
|
|
- private Vector3 selectTOldPos;
|
|
|
- private Vector3 selectTOldRot;
|
|
|
-
|
|
|
- public bool isDataInit = false;
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- private List<int> listTagid;
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- private DeviceParameters dp1;
|
|
|
- private DeviceParameters dp2;
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- public List<string> listRoomName;
|
|
|
-
|
|
|
- public void Init()
|
|
|
- {
|
|
|
- tagObjPoint = new GameObject();
|
|
|
-
|
|
|
- listBSItem = new List<BladeServerItem>();
|
|
|
-
|
|
|
- listRoomName = new List<string>();
|
|
|
-
|
|
|
- listRoomName.Add("4A-23");
|
|
|
- listRoomName.Add("4A-24");
|
|
|
- listRoomName.Add("4A-25");
|
|
|
- listRoomName.Add("4A-26");
|
|
|
- listRoomName.Add("4A-27");
|
|
|
-
|
|
|
-
|
|
|
- listTagid = new List<int>();
|
|
|
-
|
|
|
- listTagid.Add(31);
|
|
|
- listTagid.Add(61);
|
|
|
- listTagid.Add(64);
|
|
|
- listTagid.Add(43);
|
|
|
- listTagid.Add(3161);
|
|
|
- listTagid.Add(3164);
|
|
|
- listTagid.Add(4361);
|
|
|
- listTagid.Add(4364);
|
|
|
-
|
|
|
-
|
|
|
- if (PlayerPrefs.HasKey("MachineRoomData"))
|
|
|
- {
|
|
|
- string msg = PlayerPrefs.GetString("MachineRoomData");
|
|
|
- UILogManager.Instance.text1.text = msg;
|
|
|
- Debug.Log("MachineRoomData " + msg);
|
|
|
- data = JsonConvert.DeserializeObject<MachineRoomData>(msg);
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
- data = new MachineRoomData();
|
|
|
- data.line = 4;
|
|
|
- data.list = 3;
|
|
|
- data.intervalW = 1;
|
|
|
- data.intervalL = 2;
|
|
|
- data.cabinetW = 0.6f;
|
|
|
- data.cabinetH = 2f;
|
|
|
- data.bladeSeverNumber = 4;
|
|
|
- data.bIntervalH = 0.2f;
|
|
|
- data.firstBladeSeverH = 0.4f;
|
|
|
- data.TagOffestPosY = 1f;
|
|
|
- data.CameraFar = 3;
|
|
|
- data.roomName = "4A-23";
|
|
|
- data.totalCapacity = 8520;
|
|
|
- data.usedCapacity = 4420;
|
|
|
- data.totalPower = 1278;
|
|
|
- data.usedPower = 846.24f;
|
|
|
- data.totalLoadBearing = 85.2f;
|
|
|
- data.usedBearing = 46.83f;
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- data.listEquipmentData = null;
|
|
|
- data.listTagData = null;
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- if (PlayerPrefs.HasKey("MachineRoomTagData"))
|
|
|
- {
|
|
|
- string msg = PlayerPrefs.GetString("MachineRoomTagData");
|
|
|
-
|
|
|
- Debug.Log("MachineRoomTagData " + msg);
|
|
|
- data.listTagData = JsonConvert.DeserializeObject<List<MachineRoomTagData>>(msg);
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- }
|
|
|
- else
|
|
|
- {
|
|
|
-
|
|
|
- data.listTagData = new List<MachineRoomTagData>();
|
|
|
-
|
|
|
- MachineRoomTagData data1 = new MachineRoomTagData();
|
|
|
- data1.id = 65;
|
|
|
- data1.pos = new Vector3(4.5f, 0, 0);
|
|
|
- data1.rot = new Vector3(0, 180, 0);
|
|
|
- data1.offestPos = Vector3.zero;
|
|
|
- data1.offestrot = Vector3.zero;
|
|
|
-
|
|
|
- MachineRoomTagData data2 = new MachineRoomTagData();
|
|
|
- data2.id = 22;
|
|
|
- data2.pos = new Vector3(4.5f, 0, 1.8f);
|
|
|
- data2.rot = new Vector3(0, 180, 0);
|
|
|
- data2.offestPos = Vector3.zero;
|
|
|
- data2.offestrot = Vector3.zero;
|
|
|
-
|
|
|
- MachineRoomTagData data3 = new MachineRoomTagData();
|
|
|
- data3.id = 23;
|
|
|
- data3.pos = new Vector3(4.5f, 0, 3.7f);
|
|
|
- data3.rot = new Vector3(0, 180, 0);
|
|
|
- data3.offestPos = Vector3.zero;
|
|
|
- data3.offestrot = Vector3.zero;
|
|
|
-
|
|
|
- MachineRoomTagData data4 = new MachineRoomTagData();
|
|
|
- data4.id = 141;
|
|
|
- data4.pos = new Vector3(4.5f, 2.5f, 3.7f);
|
|
|
- data4.rot = new Vector3(0, 180, 0);
|
|
|
- data4.offestPos = Vector3.zero;
|
|
|
- data4.offestrot = Vector3.zero;
|
|
|
-
|
|
|
-
|
|
|
- MachineRoomTagData data5 = new MachineRoomTagData();
|
|
|
- data5.id = 142;
|
|
|
- data5.pos = new Vector3(4.5f, 2.5f, 3.7f);
|
|
|
- data5.rot = new Vector3(0, 180, 0);
|
|
|
- data5.offestPos = Vector3.zero;
|
|
|
- data5.offestrot = Vector3.zero;
|
|
|
-
|
|
|
-
|
|
|
- data.listTagData.Add(data1);
|
|
|
- data.listTagData.Add(data2);
|
|
|
- data.listTagData.Add(data3);
|
|
|
- data.listTagData.Add(data4);
|
|
|
- data.listTagData.Add(data5);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- if (PlayerPrefs.HasKey("MachineRoomCabinetData"))
|
|
|
- {
|
|
|
- string msg = PlayerPrefs.GetString("MachineRoomCabinetData");
|
|
|
-
|
|
|
-
|
|
|
- data.listEquipmentData = JsonConvert.DeserializeObject<List<MachineParameters>>(msg);
|
|
|
- }
|
|
|
-
|
|
|
- dp1 = new DeviceParameters();
|
|
|
- dp1.deviceId = 1;
|
|
|
- dp1.deviceName = "NetView4000_1";
|
|
|
- dp1.deviceModel = "NetView4000";
|
|
|
- dp1.deviceType = "流量溯源";
|
|
|
- dp1.assetTagNumber = "781010G001AAAAAAA";
|
|
|
- dp1.serialNumber = "B4U120800057";
|
|
|
- dp1.equipmentNumber = "HW-SEC-OTAAAAAA";
|
|
|
- dp1.assetStatus = null;
|
|
|
- dp1.deviceStatus = "运行中";
|
|
|
- dp1.deliveryData = "2022-11-25";
|
|
|
- dp1.enabledDate = "2022-05-31";
|
|
|
- dp1.serverUsageType = null;
|
|
|
- dp1.typicalModel = null;
|
|
|
- dp1.equipmentBrand = "神州数码";
|
|
|
- dp1.manufacturer = "神州数码";
|
|
|
- dp1.equipmentWeight = 30;
|
|
|
- dp1.equipmentPower = 1200;
|
|
|
- dp1.originType = "国产";
|
|
|
- dp1.collectionCPName = "其它安...";
|
|
|
- dp1.resourcePool = "湘潭资源池";
|
|
|
- dp1.wherePOD = "PUB1-1";
|
|
|
- dp1.networkDomain = "公共域";
|
|
|
- dp1.city = "湖南";
|
|
|
- dp1.building = "二级楼";
|
|
|
- dp1.floor = "5";
|
|
|
- dp1.computerRoomName = "507机房";
|
|
|
- dp1.computerRoomCoding = "ITC-4300000...";
|
|
|
- dp1.cabinetNumber = "P06";
|
|
|
- dp1.uMessage = "24-24";
|
|
|
- dp1.deviceOrientation = "前";
|
|
|
- dp1.manageIP = "10.207.90.50";
|
|
|
- dp1.saveIP = null;
|
|
|
- dp1.iPMIIP = null;
|
|
|
- dp1.businessIP = null;
|
|
|
- dp1.projectName = "2021年IT基础...";
|
|
|
- dp1.equipmentSupplier = "神州数码";
|
|
|
- dp1.assetOwner = "陈国威(chen guo wei)";
|
|
|
- dp1.territorialPAManager = "张泽宇(zhang ze yu)";
|
|
|
- dp1.equipmentBTTOrganization = "中移动信息";
|
|
|
- dp1.facilityManagementOrganization = null;
|
|
|
- dp1.equipmentMaintenanceOrganization = "湖南公司信...";
|
|
|
- dp1.businessSystem = null;
|
|
|
-
|
|
|
- dp2 = new DeviceParameters();
|
|
|
- dp2.deviceId = 2;
|
|
|
- dp2.deviceName = "NetView4000_2";
|
|
|
- dp2.deviceModel = "NetView4000";
|
|
|
- dp2.deviceType = "流量溯源";
|
|
|
- dp2.assetTagNumber = "781010G002AAAAAAA";
|
|
|
- dp2.serialNumber = "B4U120800057";
|
|
|
- dp2.equipmentNumber = "HW-SEC-OTBBBBB";
|
|
|
- dp2.assetStatus = null;
|
|
|
- dp2.deviceStatus = "运行中";
|
|
|
- dp2.deliveryData = "2022-11-25";
|
|
|
- dp2.enabledDate = "2022-05-31";
|
|
|
- dp2.serverUsageType = null;
|
|
|
- dp2.typicalModel = null;
|
|
|
- dp2.equipmentBrand = "神州数码";
|
|
|
- dp2.manufacturer = "神州数码";
|
|
|
- dp2.equipmentWeight = 30;
|
|
|
- dp2.equipmentPower = 1200;
|
|
|
- dp2.originType = "国产";
|
|
|
- dp2.collectionCPName = "其它安...";
|
|
|
- dp2.resourcePool = "湘潭资源池";
|
|
|
- dp2.wherePOD = "PUB1-1";
|
|
|
- dp2.networkDomain = "公共域";
|
|
|
- dp2.city = "湖南";
|
|
|
- dp2.building = "二级楼";
|
|
|
- dp2.floor = "5";
|
|
|
- dp2.computerRoomName = "507机房";
|
|
|
- dp2.computerRoomCoding = "ITC-4300000...";
|
|
|
- dp2.cabinetNumber = "P06";
|
|
|
- dp2.uMessage = "24-24";
|
|
|
- dp2.deviceOrientation = "前";
|
|
|
- dp2.manageIP = "10.207.90.50";
|
|
|
- dp2.saveIP = null;
|
|
|
- dp2.iPMIIP = null;
|
|
|
- dp2.businessIP = null;
|
|
|
- dp2.projectName = "2021年IT基础...";
|
|
|
- dp2.equipmentSupplier = "神州数码";
|
|
|
- dp2.assetOwner = "陈国威(chen guo wei)";
|
|
|
- dp2.territorialPAManager = "张泽宇(zhang ze yu)";
|
|
|
- dp2.equipmentBTTOrganization = "中移动信息";
|
|
|
- dp2.facilityManagementOrganization = null;
|
|
|
- dp2.equipmentMaintenanceOrganization = "湖南公司信...";
|
|
|
- dp2.businessSystem = null;
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- private void Start()
|
|
|
- {
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-#if UNITY_EDITOR
|
|
|
-
|
|
|
-#endif
|
|
|
- }
|
|
|
-
|
|
|
- public void SceneInit()
|
|
|
- {
|
|
|
- SettingMachineRoomData.Instance.Init(data);
|
|
|
- OpenXRCamera.Instance.head.GetComponent<Camera>().farClipPlane = data.CameraFar;
|
|
|
- MachineInit();
|
|
|
-
|
|
|
-
|
|
|
- isDataInit = true;
|
|
|
- }
|
|
|
-
|
|
|
- private void Update()
|
|
|
- {
|
|
|
- if (state && tagData != null)
|
|
|
- {
|
|
|
- for (int i = 0; i < listEditorTag.Count; i++)
|
|
|
- {
|
|
|
- listEditorTag[i].gameObject.SetActive(!state);
|
|
|
-
|
|
|
- if (listEditorTag[i].id == tagData.id)
|
|
|
- listEditorTag[i].gameObject.SetActive(true);
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- if (tagData != null && foundTracking != null && DragManager.Instance.triggerState == TriggerState.No && !state)
|
|
|
- {
|
|
|
- tagObjPoint.transform.SetParent(foundTracking.transform);
|
|
|
-
|
|
|
- tagObjPoint.transform.localEulerAngles = new Vector3(0, tagData.offestrot == Vector3.zero ? tagData.rot.y : tagData.offestrot.y, 0);
|
|
|
- tagObjPoint.transform.localPosition = tagData.offestPos == Vector3.zero ? tagData.pos : tagData.offestPos;
|
|
|
-
|
|
|
- transform.eulerAngles = new Vector3(0, tagObjPoint.transform.eulerAngles.y, 0);
|
|
|
- transform.position = new Vector3(tagObjPoint.transform.position.x, foundTracking.transform.position.y + data.TagOffestPosY, tagObjPoint.transform.position.z);
|
|
|
- }
|
|
|
-
|
|
|
- if (Input.GetKeyDown(KeyCode.K))
|
|
|
- {
|
|
|
- OnTrackingFound(foundTracking);
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- public List<MachineObj> listObjes = new List<MachineObj>();
|
|
|
- public void MachineInit()
|
|
|
- {
|
|
|
-
|
|
|
- listObjes.Clear();
|
|
|
- listObjes = new List<MachineObj>();
|
|
|
-
|
|
|
- if (data.listEquipmentData == null || data.listEquipmentData.Count != (data.line * data.list))
|
|
|
- {
|
|
|
- data.listEquipmentData = new List<MachineParameters>();
|
|
|
-
|
|
|
- for (int i = 0; i < data.line; i++)
|
|
|
- {
|
|
|
- for (int j = 0; j < data.list; j++)
|
|
|
- {
|
|
|
-
|
|
|
- MachineParameters mp1 = new MachineParameters();
|
|
|
- mp1.deviceId = (i * data.list + j + 1);
|
|
|
- mp1.tagID = -1000;
|
|
|
- mp1.offsetPos = new Vector3(-0.4f, 0, -0.3f);
|
|
|
- mp1.eulerAxle = 3;
|
|
|
- mp1.deviceName = "设备" + (i * data.list + j + 1).ToString();
|
|
|
- mp1.carryingSystem = "承载系统1";
|
|
|
- mp1.deviceLocation = "4A-23机房";
|
|
|
- mp1.equipmentType = "机柜";
|
|
|
- mp1.equipmentModel = null;
|
|
|
- mp1.factory = null;
|
|
|
- mp1.specification = null;
|
|
|
- mp1.listDevicesParameters = new List<DeviceParameters>();
|
|
|
-
|
|
|
- if (mp1.deviceId % 2 == 0)
|
|
|
- mp1.listDevicesParameters.Add(dp1);
|
|
|
- else
|
|
|
- mp1.listDevicesParameters.Add(dp2);
|
|
|
- data.listEquipmentData.Add(mp1);
|
|
|
- }
|
|
|
- }
|
|
|
- for (int i = 0; i < listTagid.Count; i++)
|
|
|
- {
|
|
|
- if ((i + 1) < data.listEquipmentData.Count)
|
|
|
- {
|
|
|
- data.listEquipmentData[i].tagID = listTagid[i];
|
|
|
- }
|
|
|
- else
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- GameObject rDataItem = Resources.Load<GameObject>("DataItem");
|
|
|
- for (int i = 0; i < data.listEquipmentData.Count; i++)
|
|
|
- {
|
|
|
- GameObject obj = GameObject.Instantiate(cabinetObj, transform);
|
|
|
- obj.transform.localScale = new Vector3(data.cabinetW, data.cabinetH, obj.transform.localScale.z);
|
|
|
- Debug.Log(data.cabinetH + " " + data.cabinetW);
|
|
|
- obj.name = data.listEquipmentData[i].deviceName;
|
|
|
-
|
|
|
- obj.transform.localPosition = new Vector3((i % data.line) * (data.cabinetW + data.intervalW), 0, (i / data.line) * data.intervalL);
|
|
|
- obj.GetComponent<MachineObj>().Setting((i / data.line) % 2 == 0);
|
|
|
- listObjes.Add(obj.GetComponent<MachineObj>());
|
|
|
- listObjes[i].deviceParameters = data.listEquipmentData[i];
|
|
|
-
|
|
|
-
|
|
|
- GameObject item = GameObject.Instantiate(rDataItem);
|
|
|
- DataItem dataItem = item.GetComponent<DataItem>();
|
|
|
- dataItem.Init(data.listEquipmentData[i]);
|
|
|
-
|
|
|
-
|
|
|
- for (int j = 0; j < data.listEquipmentData[i].listDevicesParameters.Count; j++)
|
|
|
- {
|
|
|
- dataItem.SetDeviceParametersData(data.listEquipmentData[i].listDevicesParameters);
|
|
|
- }
|
|
|
- listObjes[i].dataItem = dataItem;
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- Vector3 leftPos = new Vector3(-1 * (data.cabinetW + data.intervalW), 0, 0);
|
|
|
- Vector3 rightPos = new Vector3((data.cabinetW * data.list + data.intervalW * data.list+ data.cabinetW+data.intervalW), 0, 0);
|
|
|
- WayFindingManager.Instance.SetLine(leftPos, rightPos);
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- SaveAllData();
|
|
|
- isInit = true;
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- public IEnumerator RandomRange()
|
|
|
- {
|
|
|
- yield return 2f;
|
|
|
- int randomNum = UnityEngine.Random.Range(0, listObjes.Count - 1);
|
|
|
-
|
|
|
-
|
|
|
- List<MachineObj> listMachineObj = new List<MachineObj>();
|
|
|
-
|
|
|
- for (int i = 0; i < 3; i++)
|
|
|
- {
|
|
|
- if (i < listObjes.Count - 1)
|
|
|
- {
|
|
|
- listMachineObj.Add(listObjes[i]);
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- WayFindingManager.Instance.NavigatorServer(listMachineObj);
|
|
|
- }
|
|
|
-
|
|
|
- public void SettingMachine()
|
|
|
- {
|
|
|
- if (listObjes != null)
|
|
|
- {
|
|
|
- for (int i = 0; i < listObjes.Count; i++)
|
|
|
- {
|
|
|
- listObjes[i].gameObject.SetActive(false);
|
|
|
- }
|
|
|
- listObjes.Clear();
|
|
|
- listObjes = new List<MachineObj>();
|
|
|
- }
|
|
|
-
|
|
|
- if (BladeServerManager.Instance.listTagTracking != null)
|
|
|
- {
|
|
|
- for (int i = 0; i < BladeServerManager.Instance.listTagTracking.Count; i++)
|
|
|
- {
|
|
|
- BladeServerManager.Instance.listTagTracking[i].gameObject.SetActive(false);
|
|
|
- }
|
|
|
- BladeServerManager.Instance.listTagTracking.Clear();
|
|
|
- }
|
|
|
-
|
|
|
- data.listEquipmentData = new List<MachineParameters>();
|
|
|
- for (int i = 0; i < data.line; i++)
|
|
|
- {
|
|
|
- for (int j = 0; j < data.list; j++)
|
|
|
- {
|
|
|
- data.listEquipmentData = new List<MachineParameters>();
|
|
|
- MachineParameters mp1 = new MachineParameters();
|
|
|
- mp1.deviceId = (i * data.list + j + 1);
|
|
|
- mp1.tagID = -1000;
|
|
|
- mp1.offsetPos = new Vector3(0f, 0, 0f);
|
|
|
- mp1.eulerAxle = 3;
|
|
|
- mp1.deviceName = "设备" + (i * data.list + j + 1).ToString();
|
|
|
- mp1.carryingSystem = "承载系统1";
|
|
|
- mp1.deviceLocation = "4A-23机房";
|
|
|
- mp1.equipmentType = "机柜";
|
|
|
- mp1.equipmentModel = null;
|
|
|
- mp1.factory = null;
|
|
|
- mp1.specification = null;
|
|
|
- mp1.listDevicesParameters = new List<DeviceParameters>();
|
|
|
-
|
|
|
- if (mp1.deviceId % 2 == 0)
|
|
|
- mp1.listDevicesParameters.Add(dp1);
|
|
|
- else
|
|
|
- mp1.listDevicesParameters.Add(dp2);
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- MachineInit();
|
|
|
- }
|
|
|
-
|
|
|
- public void SettingCameraFar()
|
|
|
- {
|
|
|
- OpenXRCamera.Instance.head.GetComponent<Camera>().farClipPlane = data.CameraFar;
|
|
|
- }
|
|
|
-
|
|
|
- public void OnTrackingFirst(TagTracking tracking)
|
|
|
- {
|
|
|
- if (isDataInit)
|
|
|
- QueryTagData(tracking);
|
|
|
- }
|
|
|
-
|
|
|
- public void OnTrackingStay(TagTracking tracking)
|
|
|
- {
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- public void OnTrackingFound(TagTracking tracking)
|
|
|
- {
|
|
|
-
|
|
|
- if (isDataInit)
|
|
|
- QueryTagData(tracking);
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- public void OnTrackingLost(TagTracking tracking)
|
|
|
- {
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- private void QueryTagData(TagTracking tracking)
|
|
|
- {
|
|
|
- if (isDataInit)
|
|
|
- {
|
|
|
- foundTracking = tracking;
|
|
|
- tagData = null;
|
|
|
- Debug.Log("DGJ ===> QueryTagData" + data.listTagData.Count);
|
|
|
- for (int i = 0; i < data.listTagData.Count; i++)
|
|
|
- {
|
|
|
- if (data.listTagData[i].id == tracking.TrackId)
|
|
|
- {
|
|
|
- tagData = data.listTagData[i];
|
|
|
- break;
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
- bool state = false;
|
|
|
- public void EditorTag(Text text)
|
|
|
- {
|
|
|
- text.text = state ? "打开" : "关闭";
|
|
|
- text.text += "场景编辑";
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- state = !state;
|
|
|
- DragManager.Instance.state = state;
|
|
|
- cubeY.SetActive(state);
|
|
|
-
|
|
|
- for (int i = 0; i < listObjes.Count; i++)
|
|
|
- {
|
|
|
- listObjes[i].MeshState(state);
|
|
|
- }
|
|
|
-
|
|
|
- if (!state && foundTracking != null)
|
|
|
- {
|
|
|
- for (int i = 0; i < listEditorTag.Count; i++)
|
|
|
- {
|
|
|
- listEditorTag[i].gameObject.SetActive(state);
|
|
|
- }
|
|
|
-
|
|
|
- for (int i = 0; i < data.listTagData.Count; i++)
|
|
|
- {
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- for (int j = 0; j < listEditorTag.Count; j++)
|
|
|
- {
|
|
|
- if (listEditorTag[j].id == data.listTagData[i].id)
|
|
|
- {
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- transform.SetParent(listEditorTag[j].transform.parent);
|
|
|
- data.listTagData[i].offestPos = transform.localPosition;
|
|
|
- data.listTagData[i].offestrot = transform.localEulerAngles;
|
|
|
- transform.parent = null;
|
|
|
-
|
|
|
- Debug.Log("DGJ ===> 保存 Tag " + listEditorTag[j].id);
|
|
|
- }
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
- selectTOldPos = Vector3.zero;
|
|
|
- selectTOldRot = Vector3.zero;
|
|
|
- DragManager.Instance.triggerState = TriggerState.No;
|
|
|
- selectTrigger = null;
|
|
|
- }
|
|
|
-
|
|
|
- if (!state)
|
|
|
- {
|
|
|
- SaveAllData();
|
|
|
- }
|
|
|
- }
|
|
|
-
|
|
|
- public void SaveAllData()
|
|
|
- {
|
|
|
- PlayerPrefs.SetString("MachineRoomTagData", JsonConvert.SerializeObject(data.listTagData));
|
|
|
-
|
|
|
- PlayerPrefs.SetString("MachineRoomCabinetData", JsonConvert.SerializeObject(data.listEquipmentData));
|
|
|
- PlayerPrefs.SetString("MachineRoomData", JsonConvert.SerializeObject(data));
|
|
|
-
|
|
|
- Debug.Log(" 保存成功 " + JsonConvert.SerializeObject(data));
|
|
|
- }
|
|
|
-
|
|
|
- private void SaveData()
|
|
|
- {
|
|
|
- if (data != null)
|
|
|
- {
|
|
|
- string _str = JsonConvert.SerializeObject(data);
|
|
|
-
|
|
|
- System.IO.Directory.CreateDirectory(Application.persistentDataPath + "/Data");
|
|
|
- string NowTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss").Replace(" ", "_").Replace("/", "_").Replace(":", "_");
|
|
|
- Debug.Log(Application.persistentDataPath + "/Data");
|
|
|
- using (System.IO.StreamWriter writer = System.IO.File.CreateText(Application.persistentDataPath + "/Data" + "/" + NowTime + "_data.txt"))
|
|
|
- {
|
|
|
- writer.Write(_str);
|
|
|
-
|
|
|
- }
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- }
|
|
|
- }
|
|
|
- private void OnDisable()
|
|
|
- {
|
|
|
- PlayerPrefs.SetString("MachineRoomTagData", JsonConvert.SerializeObject(data.listTagData));
|
|
|
- PlayerPrefs.SetString("MachineRoomCabinetData", JsonConvert.SerializeObject(data.listEquipmentData));
|
|
|
- PlayerPrefs.SetString("MachineRoomData", JsonConvert.SerializeObject(data));
|
|
|
- SaveData();
|
|
|
- }
|
|
|
-
|
|
|
-}
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|