From cb93b1cbed254e1f753ac2b7f7bd23bb4065b3e6 Mon Sep 17 00:00:00 2001 From: fundale <69996669+fundale@users.noreply.github.com> Date: Sun, 3 Nov 2024 17:10:35 -0600 Subject: [PATCH] Adjustments for Linux Unity editors --- .../Editor/VRSL_DMXPatchExporter.cs | 20 +++++++++- .../Editor/VRSL_DMXPatchSettings.cs | 37 +++++++++++++++++-- 2 files changed, 52 insertions(+), 5 deletions(-) diff --git a/Packages/com.acchosen.vr-stage-lighting/Editor/VRSL_DMXPatchExporter.cs b/Packages/com.acchosen.vr-stage-lighting/Editor/VRSL_DMXPatchExporter.cs index c2bd5f7..cfb50ae 100644 --- a/Packages/com.acchosen.vr-stage-lighting/Editor/VRSL_DMXPatchExporter.cs +++ b/Packages/com.acchosen.vr-stage-lighting/Editor/VRSL_DMXPatchExporter.cs @@ -3,7 +3,9 @@ using System.Collections.Generic; using UnityEngine; using UnityEditor; +#if UDONSHARP using UdonSharpEditor; +#endif using UnityEngine.SceneManagement; using System.IO; using System; @@ -36,9 +38,13 @@ private static void CheckForLocalPanel() // colorLabel.text = "Emission Color"; foreach (GameObject go in sceneObjects) { + #if UDONSHARP #pragma warning disable 0618 //suppressing obsoletion warnings panel = go.GetUdonSharpComponent(); #pragma warning restore 0618 + #else + panel = go.GetComponent(); + #endif if(panel != null) { hasLocalPanel = true; @@ -78,6 +84,7 @@ public static void SavePatchData() SerializedObject so = new SerializedObject(panel); so.FindProperty("fixtureSaveFile").stringValue = AssetDatabase.GUIDFromAssetPath(path).ToString(); so.ApplyModifiedProperties(); +#if UDONSHARP #pragma warning disable 0618 //suppressing obsoletion warnings panel.UpdateProxy(); #pragma warning restore 0618 //suppressing obsoletion warnings @@ -85,6 +92,9 @@ public static void SavePatchData() #pragma warning disable 0618 //suppressing obsoletion warnings panel.ApplyProxyModifications(); #pragma warning restore 0618 //suppressing obsoletion warnings +#else + panel.fixtureSaveFile = so.FindProperty("fixtureSaveFile").stringValue; +#endif /// asset = (VRSL_DMXPatchSettings) AssetDatabase.LoadAssetAtPath(AssetDatabase.GUIDToAssetPath(panel.fixtureSaveFile), typeof(VRSL_DMXPatchSettings)); // asset.SetScene(); @@ -112,6 +122,7 @@ public static void SavePatchData() SerializedObject so = new SerializedObject(panel); so.FindProperty("fixtureSaveFile").stringValue = "NONE"; so.ApplyModifiedProperties(); +#if UDONSHARP #pragma warning disable 0618 //suppressing obsoletion warnings panel.UpdateProxy(); #pragma warning restore 0618 //suppressing obsoletion warnings @@ -119,6 +130,9 @@ public static void SavePatchData() #pragma warning disable 0618 //suppressing obsoletion warnings panel.ApplyProxyModifications(); #pragma warning restore 0618 //suppressing obsoletion warnings +#else + panel.fixtureSaveFile = so.FindProperty("fixtureSaveFile").stringValue; +#endif SavePatchData(); } catch(Exception e) @@ -199,7 +213,7 @@ public static void ExportToMVR() } } - [MenuItem("VRSL/Export/To PDF", priority = 504)] + [MenuItem("VRSL/Export/To PDF (Windows)", priority = 504)] public static void ExportToPDF() { CheckForLocalPanel(); @@ -208,8 +222,12 @@ public static void ExportToPDF() { try { +#if !UNITY_EDITOR_LINUX VRSL_DMXPatchSettings asset = (VRSL_DMXPatchSettings) AssetDatabase.LoadAssetAtPath(AssetDatabase.GUIDToAssetPath(panel.fixtureSaveFile), typeof(VRSL_DMXPatchSettings)); asset.ToPDF(); +#else + EditorUtility.DisplayDialog("PDF export error", "PDF export is currently a Windows only feature", "OK", "Cancel"); +#endif } catch { diff --git a/Packages/com.acchosen.vr-stage-lighting/Editor/VRSL_DMXPatchSettings.cs b/Packages/com.acchosen.vr-stage-lighting/Editor/VRSL_DMXPatchSettings.cs index cb80c60..de90d6b 100644 --- a/Packages/com.acchosen.vr-stage-lighting/Editor/VRSL_DMXPatchSettings.cs +++ b/Packages/com.acchosen.vr-stage-lighting/Editor/VRSL_DMXPatchSettings.cs @@ -3,20 +3,27 @@ using System.Collections.Generic; using System; using System.Diagnostics; -using VRC.Udon; using UnityEngine; using UnityEngine.SceneManagement; using UnityEditor; -using UdonSharpEditor; using System.IO; using System.IO.Compression; using System.Text; using System.Xml; -using System.Drawing.Printing; using System.Drawing; using System.Data; using UnityEngine.UIElements; using System.Linq; + +#if UDONSHARP +using VRC.Udon; +using UdonSharpEditor; +#endif + +#if !UNITY_EDITOR_LINUX +using System.Drawing.Printing; +#endif + namespace VRSL.EditorScripts { public class StringWriterUtf8 : StringWriter @@ -256,9 +263,13 @@ public void SetDMXFixtureData() List sceneFixtures = new List(); foreach(GameObject go in sceneObjects) { +#if UDONSHARP #pragma warning disable 0618 //suppressing obsoletion warnings VRStageLighting_DMX_Static lightScript = go.GetUdonSharpComponent(); #pragma warning restore 0618 //suppressing obsoletion warnings +#else + VRStageLighting_DMX_Static lightScript = go.GetComponent(); +#endif if(lightScript != null) { sceneFixtures.Add(lightScript); @@ -313,9 +324,13 @@ public void LoadDMXFixtureData() List sceneFixtures = new List(); foreach(GameObject go in sceneObjects) { +#if UDONSHARP #pragma warning disable 0618 //suppressing obsoletion warnings VRStageLighting_DMX_Static lightScript = go.GetUdonSharpComponent(); #pragma warning restore 0618 //suppressing obsoletion warnings +#else + VRStageLighting_DMX_Static lightScript = go.GetComponent(); +#endif if(lightScript != null) { sceneFixtures.Add(lightScript); @@ -412,9 +427,11 @@ public void LoadDMXFixtureData() } sof.ApplyModifiedProperties(); +#if UDONSHARP #pragma warning disable 0618 //suppressing obsoletion warnings fixture.UpdateProxy(); #pragma warning restore 0618 //suppressing obsoletion warnings. +#endif fixture.enableDMXChannels = data[dmxID].enableDMXChannels; fixture.fixtureID = data[dmxID].fixtureID; @@ -445,9 +462,11 @@ public void LoadDMXFixtureData() fixture.fixtureDefintion = data[dmxID].fixtureDefintion; fixture.objRenderers = rends; +#if UDONSHARP #pragma warning disable 0618 //suppressing obsoletion warnings fixture.ApplyProxyModifications(); #pragma warning restore 0618 //suppressing obsoletion warnings +#endif if(PrefabUtility.IsPartOfAnyPrefab(fixture)) { PrefabUtility.RecordPrefabInstancePropertyModifications(fixture); @@ -485,9 +504,13 @@ private bool CheckForLocalPanel() // colorLabel.text = "Emission Color"; foreach (GameObject go in sceneObjects) { +#if UDONSHARP #pragma warning disable 0618 //suppressing obsoletion warnings panel = go.GetUdonSharpComponent(); #pragma warning restore 0618 +#else + panel = go.GetComponent(); +#endif if(panel != null) { hasLocalPanel = true; @@ -496,6 +519,7 @@ private bool CheckForLocalPanel() } return hasLocalPanel; } +#if !UNITY_EDITOR_LINUX private void OnPrintPage(object sender, PrintPageEventArgs ev) { pdfPageCount++; @@ -693,6 +717,7 @@ public void ToPDF() document.Print(); UnityEngine.Debug.Log("Sucessfully Exported PDF File"); } +#endif public string ToJsonFile(bool refreshEditor) { if(CheckForLocalPanel()) @@ -1630,9 +1655,13 @@ public override void OnInspectorGUI() { settings.ToMVRFile(); } - if(GUILayout.Button("Export To PDF File")) + if(GUILayout.Button("Export To PDF File (Windows)")) { +#if !UNITY_EDITOR_LINUX settings.ToPDF(); +#else + EditorUtility.DisplayDialog("PDF export error", "PDF export is currently a Windows only feature", "OK", "Cancel"); +#endif } if(settings.data != null) {