【m】111
This commit is contained in:
@@ -112,14 +112,6 @@ namespace Stary.Evo.Editor
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
// [Title("加密列表", titleAlignment: TitleAlignments.Centered)]
|
|
||||||
// [HorizontalGroup("BuildPipeline"), HideLabel]
|
|
||||||
// [ValueDropdown("GetEncryptionServices")]
|
|
||||||
// [OnValueChanged("SetEncryptionServices")]
|
|
||||||
// public Type encryption;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
[HideLabel] public AbstractBuildPipelineViewer viewer;
|
[HideLabel] public AbstractBuildPipelineViewer viewer;
|
||||||
|
|
||||||
@@ -227,23 +219,6 @@ namespace Stary.Evo.Editor
|
|||||||
_viewers.Add(selectedBuildPipelines, viewer);
|
_viewers.Add(selectedBuildPipelines, viewer);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// private List<Type> GetEncryptionServices()
|
|
||||||
// {
|
|
||||||
// var encryptionClassTypes = EditorTools.GetAssignableTypes(typeof(IEncryptionServices));
|
|
||||||
// if (encryption.IsNull())
|
|
||||||
// {
|
|
||||||
// encryption = encryptionClassTypes[0];
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// return encryptionClassTypes;
|
|
||||||
// }
|
|
||||||
//
|
|
||||||
// private void SetEncryptionServices()
|
|
||||||
// {
|
|
||||||
// AssetBundleBuilderSetting.SetPackageEncyptionClassName(packageName, selectedBuildPipelines,
|
|
||||||
// encryption.FullName);
|
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum VersionPosType
|
public enum VersionPosType
|
||||||
|
|||||||
@@ -144,7 +144,7 @@ namespace Stary.Evo
|
|||||||
/// <param name="url">获取Token值的服务URL地址(很重要)</param>
|
/// <param name="url">获取Token值的服务URL地址(很重要)</param>
|
||||||
/// <param name="postData">传入请求的参数,此处参数为JOSN格式</param>
|
/// <param name="postData">传入请求的参数,此处参数为JOSN格式</param>
|
||||||
/// <returns></returns>
|
/// <returns></returns>
|
||||||
public static async Task<ResultMessageEntity> PostFile(string url, string[] path)
|
public static async Task<ResultMessageEntity> PostFile(string url, string[] path,Action<float> uploadProgress = null)
|
||||||
{
|
{
|
||||||
if (!GetTokenState())
|
if (!GetTokenState())
|
||||||
{
|
{
|
||||||
@@ -174,7 +174,18 @@ namespace Stary.Evo
|
|||||||
webRequest.disposeDownloadHandlerOnDispose = true;
|
webRequest.disposeDownloadHandlerOnDispose = true;
|
||||||
webRequest.disposeCertificateHandlerOnDispose = true;
|
webRequest.disposeCertificateHandlerOnDispose = true;
|
||||||
webRequest.timeout = 60;
|
webRequest.timeout = 60;
|
||||||
await webRequest.SendWebRequest();
|
|
||||||
|
// 发送请求但不等待完成
|
||||||
|
var operation = webRequest.SendWebRequest();
|
||||||
|
// 轮询获取上传进度
|
||||||
|
while (!operation.isDone)
|
||||||
|
{
|
||||||
|
// 调用进度回调函数
|
||||||
|
uploadProgress?.Invoke(webRequest.uploadProgress);
|
||||||
|
// 等待一帧,避免阻塞
|
||||||
|
await UniTask.Yield();
|
||||||
|
}
|
||||||
|
|
||||||
webRequest.uploadHandler?.Dispose();
|
webRequest.uploadHandler?.Dispose();
|
||||||
// 更新错误检查方式
|
// 更新错误检查方式
|
||||||
if (webRequest.result == UnityWebRequest.Result.ConnectionError ||
|
if (webRequest.result == UnityWebRequest.Result.ConnectionError ||
|
||||||
|
|||||||
@@ -1,3 +0,0 @@
|
|||||||
fileFormatVersion: 2
|
|
||||||
guid: 125226ccd07f47c5bf3b94157bf12fc3
|
|
||||||
timeCreated: 1758179120
|
|
||||||
@@ -0,0 +1,214 @@
|
|||||||
|
using System;
|
||||||
|
using System.Collections;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using Cysharp.Threading.Tasks;
|
||||||
|
using Newtonsoft.Json;
|
||||||
|
using Newtonsoft.Json.Linq;
|
||||||
|
using Sirenix.OdinInspector;
|
||||||
|
using Sirenix.OdinInspector.Editor;
|
||||||
|
using Stary.Evo;
|
||||||
|
using Stary.Evo.Editor;
|
||||||
|
using Stary.Evo.Editor.Entity;
|
||||||
|
using UnityEditor;
|
||||||
|
using UnityEngine;
|
||||||
|
|
||||||
|
public class CreatPointModelWindow : OdinEditorWindow
|
||||||
|
{
|
||||||
|
private static List<string> _modelTypes;
|
||||||
|
public static List<string> ScenarioTypes;
|
||||||
|
|
||||||
|
[MenuItem("Evo/创建ModelLibrary")]
|
||||||
|
private static async void Init()
|
||||||
|
{
|
||||||
|
_modelTypes = await GetModelTypes();
|
||||||
|
ScenarioTypes = await GetScenarioTypes();
|
||||||
|
// Get existing open window or if none, make a new one:
|
||||||
|
CreatPointModelWindow window = (CreatPointModelWindow)EditorWindow.GetWindow(typeof(CreatPointModelWindow));
|
||||||
|
window.Show();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void OnEnable()
|
||||||
|
{
|
||||||
|
base.OnEnable();
|
||||||
|
documentFileid = EditorPrefs.GetString("documentFileid");
|
||||||
|
modelType = EditorPrefs.GetString("modelType");
|
||||||
|
scenarioType = EditorPrefs.GetString("scenarioType");
|
||||||
|
}
|
||||||
|
|
||||||
|
[TitleGroup("创建")] [InfoBox("Model名称")]
|
||||||
|
public string modelName;
|
||||||
|
|
||||||
|
[TitleGroup("创建")] [InfoBox("Model描述")] [ValueDropdown("GetModelType")][OnValueChanged("SetModelType")]
|
||||||
|
public string modelType;
|
||||||
|
|
||||||
|
[TitleGroup("创建")] [InfoBox("Scenario描述")] [ValueDropdown("GetScenarioType")][OnValueChanged("SetScenarioType")]
|
||||||
|
public string scenarioType;
|
||||||
|
|
||||||
|
[TitleGroup("创建")] [ReadOnly] [InfoBox("文件所对应数据库id")]
|
||||||
|
public string documentFileid;
|
||||||
|
|
||||||
|
private List<string> GetModelType() => _modelTypes;
|
||||||
|
private List<string> GetScenarioType() => ScenarioTypes;
|
||||||
|
|
||||||
|
private void SetModelType() => EditorPrefs.SetString("modelType", modelType);
|
||||||
|
private void SetScenarioType() => EditorPrefs.SetString("scenarioType", scenarioType);
|
||||||
|
|
||||||
|
private static async UniTask<List<string>> GetModelTypes()
|
||||||
|
{
|
||||||
|
string ip = EditorPrefs.GetString("ip");
|
||||||
|
if (string.IsNullOrEmpty(ip))
|
||||||
|
{
|
||||||
|
EditorUtility.DisplayDialog("提示", "ip不能为空", "确定");
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
// var entity = new PointModelEntity
|
||||||
|
// {
|
||||||
|
// modelName = modelName,
|
||||||
|
// modelType = modelType,
|
||||||
|
// scenarioType = scenarioType,
|
||||||
|
// };
|
||||||
|
//string postData = JsonConvert.SerializeObject(entity);
|
||||||
|
ResultMessageEntity entity = await WebRequestSystem.Get(ip, "/ModelLibrary/FindModelType");
|
||||||
|
if (entity.code == 200)
|
||||||
|
{
|
||||||
|
var modelTypes = JsonConvert.DeserializeObject<List<string>>(entity.data.ToString());
|
||||||
|
return modelTypes;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static async UniTask<List<string>> GetScenarioTypes()
|
||||||
|
{
|
||||||
|
string ip = EditorPrefs.GetString("ip");
|
||||||
|
if (string.IsNullOrEmpty(ip))
|
||||||
|
{
|
||||||
|
EditorUtility.DisplayDialog("提示", "ip不能为空", "确定");
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
ResultMessageEntity entity = await WebRequestSystem.Get(ip, "/SceneWork/FindScenarioType");
|
||||||
|
if (entity.code == 200)
|
||||||
|
{
|
||||||
|
var scenarioTypes = JsonConvert.DeserializeObject<List<string>>(entity.data.ToString());
|
||||||
|
return scenarioTypes;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[TitleGroup("创建")]
|
||||||
|
[Button("创建Model", ButtonSizes.Large)]
|
||||||
|
public async void CreatModel()
|
||||||
|
{
|
||||||
|
if (string.IsNullOrEmpty(modelName) || string.IsNullOrEmpty(modelType) || string.IsNullOrEmpty(scenarioType) ||
|
||||||
|
string.IsNullOrEmpty(documentFileid))
|
||||||
|
{
|
||||||
|
EditorUtility.DisplayDialog("提示", "modelName和modelType和scenarioType和documentFileid不能为空", "确定");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
string ip = EditorPrefs.GetString("ip");
|
||||||
|
if (string.IsNullOrEmpty(ip))
|
||||||
|
{
|
||||||
|
EditorUtility.DisplayDialog("提示", "ip不能为空", "确定");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var pointModelEntity = new PointModelEntity
|
||||||
|
{
|
||||||
|
Name = modelName,
|
||||||
|
ModelType = modelType,
|
||||||
|
ScenarioType = scenarioType,
|
||||||
|
DocumentFileid = documentFileid,
|
||||||
|
};
|
||||||
|
string postData = JsonConvert.SerializeObject(pointModelEntity);
|
||||||
|
ResultMessageEntity entity = await WebRequestSystem.Post($"{ip}/ModelLibrary/AddModel", postData);
|
||||||
|
if (entity.code == 200)
|
||||||
|
{
|
||||||
|
EditorUtility.DisplayDialog("提示", "创建成功", "确定");
|
||||||
|
modelName = "";
|
||||||
|
documentFileid = "";
|
||||||
|
EditorPrefs.SetString("documentFileid","");
|
||||||
|
EditorPrefs.SetString("modelType","");
|
||||||
|
EditorPrefs.SetString("scenarioType","");
|
||||||
|
}
|
||||||
|
else if (entity.code == 4009)
|
||||||
|
{
|
||||||
|
EditorUtility.DisplayDialog("提示", $"创建失败,存在相同名称元素", "确定");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[TitleGroup("上传")] [InfoBox("Model路径")] [Sirenix.OdinInspector.FilePath(Extensions = "$modelType")]
|
||||||
|
public string modelPath;
|
||||||
|
|
||||||
|
[TitleGroup("上传")] [ReadOnly][HideLabel, ProgressBar(0, 100f)]
|
||||||
|
public float modelUpdateInterval = 0f;
|
||||||
|
|
||||||
|
[TitleGroup("上传")]
|
||||||
|
[Button("上传Model", ButtonSizes.Large)]
|
||||||
|
public async void UpdateModel()
|
||||||
|
{
|
||||||
|
if (string.IsNullOrEmpty(modelPath))
|
||||||
|
{
|
||||||
|
EditorUtility.DisplayDialog("提示", "modelPath不能为空", "确定");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
string ip = EditorPrefs.GetString("ip");
|
||||||
|
if (string.IsNullOrEmpty(ip))
|
||||||
|
{
|
||||||
|
EditorUtility.DisplayDialog("提示", "ip不能为空", "确定");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var messageEntity = await WebRequestSystem.PostFile(ip + "/FileLoad/UpLoadFile", new[] { modelPath }, (progress) =>
|
||||||
|
{
|
||||||
|
modelUpdateInterval = progress * 100f;
|
||||||
|
});
|
||||||
|
|
||||||
|
if (messageEntity.code == 200)
|
||||||
|
{
|
||||||
|
List<ResultMessageEntity> resultMessageEntities =
|
||||||
|
JsonConvert.DeserializeObject<List<ResultMessageEntity>>(messageEntity.data.ToString());
|
||||||
|
if (resultMessageEntities.Count > 0)
|
||||||
|
{
|
||||||
|
foreach (var resultMessageEntity in resultMessageEntities)
|
||||||
|
{
|
||||||
|
var data = JsonConvert.DeserializeObject(resultMessageEntity.data.ToString()) as JObject;
|
||||||
|
documentFileid = data["id"].ToString();
|
||||||
|
EditorPrefs.SetString("documentFileid", documentFileid);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
[Serializable]
|
||||||
|
public class PointModelEntity
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 模型名称
|
||||||
|
/// </summary>
|
||||||
|
public string Name { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 模型标签
|
||||||
|
/// </summary>
|
||||||
|
public string ModelType { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 场景标签
|
||||||
|
/// </summary>
|
||||||
|
public string ScenarioType { get; set; }
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 文件id
|
||||||
|
/// </summary>
|
||||||
|
public string DocumentFileid { get; set; }
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,11 @@
|
|||||||
|
fileFormatVersion: 2
|
||||||
|
guid: 63cfd397008223c4cae6325df57adc06
|
||||||
|
MonoImporter:
|
||||||
|
externalObjects: {}
|
||||||
|
serializedVersion: 2
|
||||||
|
defaultReferences: []
|
||||||
|
executionOrder: 0
|
||||||
|
icon: {instanceID: 0}
|
||||||
|
userData:
|
||||||
|
assetBundleName:
|
||||||
|
assetBundleVariant:
|
||||||
@@ -2,7 +2,8 @@
|
|||||||
"name": "com.pointcloud.reditor",
|
"name": "com.pointcloud.reditor",
|
||||||
"rootNamespace": "",
|
"rootNamespace": "",
|
||||||
"references": [
|
"references": [
|
||||||
"GUID:d1a793c2b6959e04ea45b972eaa369c8"
|
"GUID:d1a793c2b6959e04ea45b972eaa369c8",
|
||||||
|
"GUID:f51ebe6a0ceec4240a699833d6309b23"
|
||||||
],
|
],
|
||||||
"includePlatforms": [
|
"includePlatforms": [
|
||||||
"Editor"
|
"Editor"
|
||||||
|
|||||||
Reference in New Issue
Block a user