From f189e5130e96bd18ef94de9ea302579d720799e8 Mon Sep 17 00:00:00 2001
From: cehua-HWJ35 <hwj35@163.com>
Date: 星期一, 13 十一月 2023 16:36:36 +0800
Subject: [PATCH] 1111 同步资源
---
Assets/Editor/XCodeProjectMod.cs | 98 +++++++++++++++++++++---------------------------
1 files changed, 43 insertions(+), 55 deletions(-)
diff --git a/Assets/Editor/XCodeProjectMod.cs b/Assets/Editor/XCodeProjectMod.cs
index ed86aed..c806509 100644
--- a/Assets/Editor/XCodeProjectMod.cs
+++ b/Assets/Editor/XCodeProjectMod.cs
@@ -2,12 +2,10 @@
using System.IO;
using UnityEditor;
using UnityEditor.iOS.Xcode.Custom;
-using UnityEditor.iOS.Xcode.Custom.Extensions;
using UnityEngine;
public class XCodeProjectMod
{
-#if UNITY_IOS
private const string CODE_SIGN_DEVELOPER = "";
private const string CODE_SIGN_DISTRIBUTION = "";
private const string PROVISIONING_DEVELOPER = "";
@@ -24,47 +22,41 @@
string _projectPath = PBXProject.GetPBXProjectPath(path);
- PBXProject _project = new PBXProject();
- _project.ReadFromString(File.ReadAllText(_projectPath));
+ PBXProject project = new PBXProject();
+ project.ReadFromString(File.ReadAllText(_projectPath));
- string _targetGUID = _project.TargetGuidByName(PBXProject.GetUnityTargetName());
+ string targetGUID = project.TargetGuidByName(PBXProject.GetUnityTargetName());
+ string fwTargetGUID = project.TargetGuidByName("UnityFramework");
//var _codeSign = Debug.isDebugBuild ? CODE_SIGN_DEVELOPER : CODE_SIGN_DISTRIBUTION;
//var _provision = Debug.isDebugBuild ? PROVISIONING_DEVELOPER : PROVISIONING_DISTRIBUTION;
// BuildSetting閲岀殑鐩稿叧璁剧疆
- _project.SetBuildProperty(_targetGUID, "ENABLE_BITCODE", "NO");
- _project.SetBuildProperty(_targetGUID, "DEVELOPMENT_TEAM", TEAM);
+ project.SetBuildProperty(project.ProjectGuid(), "ENABLE_BITCODE", "NO");
+ project.SetBuildProperty(targetGUID, "ENABLE_BITCODE", "NO");
+ project.SetBuildProperty(targetGUID, "DEVELOPMENT_TEAM", TEAM);
- _project.AddBuildProperty(_targetGUID, "OTHER_LDFLAGS", "-ObjC");
- _project.AddBuildProperty(_targetGUID, "GCC_GENERATE_DEBUGGING_SYMBOLS", "NO");
-
- // 澶勭悊 Framework
- // FreeSDK
- _project.AddFrameworkToProject(_targetGUID, "CoreGraphics.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "Security.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "CoreTelephony.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "StoreKit.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "MobileCoreServices.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "SystemConfiguration.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "AdSupport.framework", true);
-
- // 鏋佸厜鎺ㄩ��
- // JPush
- _project.AddFrameworkToProject(_targetGUID, "CFNetwork.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "CoreFoundation.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "Foundation.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "UIKit.framework", true);
- _project.AddFrameworkToProject(_targetGUID, "UserNotifications.framework", true);
+ project.AddBuildProperty(targetGUID, "OTHER_LDFLAGS", "-ObjC");
+ project.AddBuildProperty(targetGUID, "GCC_GENERATE_DEBUGGING_SYMBOLS", "NO");
+ //wkwebview
+ project.AddFrameworkToProject(fwTargetGUID, "WebKit.framework", true);
+ //bugly
+ project.AddFrameworkToProject(fwTargetGUID, "SystemConfiguration.framework", true);
+ project.AddFrameworkToProject(fwTargetGUID, "Security.framework", true);
+ project.AddFrameworkToProject(fwTargetGUID, "JavaScriptCore.framework", true);
// 澶勭悊 搴撴枃浠�
- _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libz.tbd", "Frameworks/libz.tbd", PBXSourceTree.Sdk));
- _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libsqlite3.tbd", "Frameworks/libsqlite3.tbd", PBXSourceTree.Sdk));
- _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libc++.tbd", "Frameworks/libc++.tbd", PBXSourceTree.Sdk));
- _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libiconv.tbd", "Frameworks/libiconv.tbd", PBXSourceTree.Sdk));
- _project.AddFileToBuild(_targetGUID, _project.AddFile("/usr/lib/libresolv.tbd", "Frameworks/libresolv.tbd", PBXSourceTree.Sdk));
+ project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libz.tbd", "Frameworks/libz.tbd", PBXSourceTree.Sdk));
+ project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libsqlite3.tbd", "Frameworks/libsqlite3.tbd", PBXSourceTree.Sdk));
+ project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libc++.tbd", "Frameworks/libc++.tbd", PBXSourceTree.Sdk));
+ project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libiconv.tbd", "Frameworks/libiconv.tbd", PBXSourceTree.Sdk));
+ project.AddFileToBuild(fwTargetGUID, project.AddFile("/usr/lib/libresolv.tbd", "Frameworks/libresolv.tbd", PBXSourceTree.Sdk));
- File.WriteAllText(_projectPath, _project.WriteToString());
+ //UnityFramework
+ project.AddBuildProperty(fwTargetGUID, "OTHER_LDFLAGS", "-ObjC");
+
+
+ File.WriteAllText(_projectPath, project.WriteToString());
//鍔犳帹閫�
//var _capabilityMgr = new ProjectCapabilityManager(_projectPath, "game003.entitlements", PBXProject.GetUnityTargetName());
@@ -98,9 +90,6 @@
_rootDict.SetString("NSMicrophoneUsageDescription", "浣跨敤楹﹀厠椋庢潈闄�");
_rootDict.SetString("NSPhotoLibraryAddUsageDescription", "浣跨敤鐩稿唽鏉冮檺,鐢ㄤ互瀛樺偍鎴睆鐨勮处鍙蜂俊鎭�,浠ラ槻蹇樿璐﹀彿瀵嗙爜");
- _rootDict.SetString("YLChannelId", "1000");
- _rootDict.SetString("YLPlatformId", "1000");
-
File.WriteAllText(_plistPath, _plist.WriteToString());
}
@@ -109,19 +98,25 @@
//淇敼UnityAppController.mm 鏂囦欢
var _xclass = new XClass(projectPath + "/Classes/UnityAppController.mm");
//寮曞叆UniversalSDK
- _xclass.WriteBelow("#include \"PluginBase/AppDelegateListener.h\"", "#include \"UniversalSDK.h\""+ "\n#import <SMPCQuickSDK/SMPCQuickSDK.h>");
+ _xclass.WriteBelow("#include \"PluginBase/AppDelegateListener.h\"", "#include \"UniversalSDK.h\"" + "\n#import <SMPCQuickSDK/SMPCQuickSDK.h>");
//unity浜や簰璋冪敤鐨勬柟娉�
string newCode = "\n" +
"extern \"C\" void IOSMessageHandle(const char* jsonString) {\n" +
" [GetAppController().universalSDK HandleUnityMessage:[NSString stringWithUTF8String:jsonString]];\n" +
"}";
- _xclass.WriteBelow("extern \"C\" ScreenOrientation UnityCurrentOrientation() { return GetAppController().unityView.contentOrientation; }",newCode);
+ _xclass.WriteBelow("extern \"C\" ScreenOrientation UnityCurrentOrientation() { return GetAppController().unityView.contentOrientation; }", newCode);
//鍒濆鍖朥niversalSDK
newCode = "\n" +
- " _universalSDK = [[UniversalSDK alloc] init];\n";
+ " _universalSDK = [[UniversalSDK alloc] init];\n [_universalSDK QuickSDKInit:application didFinishLaunchingWithOptions:launchOptions];";
_xclass.WriteBelow("[KeyboardDelegate Initialize];", newCode);
+
+ newCode = "\n" +
+ "if([SMPCQuickSDK defaultInstance].channelType == 39 ||[SMPCQuickSDK defaultInstance].channelType == 1803 ){\n" +
+ "return [[SMPCQuickSDK defaultInstance] application: application supportedInterfaceOrientationsForWindow:window];}\n" +
+ "else {\n" +
+ "[[SMPCQuickSDK defaultInstance] application: application supportedInterfaceOrientationsForWindow:window];}\n";
//quick sdk 鐢熷懡鍛ㄦ湡
- _xclass.WriteBelow("supportedInterfaceOrientationsForWindow:(UIWindow*)window\n{", "[[SMPCQuickSDK defaultInstance] application:application supportedInterfaceOrientationsForWindow:window];");
+ _xclass.WriteBelow("supportedInterfaceOrientationsForWindow:(UIWindow*)window\n{", newCode);
_xclass.WriteBelow("UnitySendRemoteNotification(userInfo);", "[[SMPCQuickSDK defaultInstance] application:application didReceiveRemoteNotification:userInfo];");
_xclass.WriteBelow("UnitySendDeviceToken(deviceToken);", "[[SMPCQuickSDK defaultInstance] application:application didRegisterForRemoteNotificationsWithDeviceToken:deviceToken];");
_xclass.WriteBelow("UnitySendRemoteNotificationError(error);", "[[SMPCQuickSDK defaultInstance] application:application didFailToRegisterForRemoteNotificationsWithError:error];");
@@ -135,15 +130,10 @@
//淇敼UnityAppController.h 鏂囦欢
_xclass = new XClass(projectPath + "/Classes/UnityAppController.h");
- _xclass.WriteBelow("@class DisplayConnection;", "@class UniversalSDK;");
+ _xclass.WriteBelow("@class DisplayConnection;", "@class UniversalSDK;");
_xclass.WriteBelow("DisplayConnection* _mainDisplay;", "UniversalSDK* _universalSDK;");
_xclass.WriteBelow("@property (readonly, copy, nonatomic) DisplayConnection* mainDisplay;",
"@property (readonly, copy, nonatomic) UniversalSDK* universalSDK;");
-
-
- //閫傞厤iPhoneX 搴曢儴鐧芥潯
- _xclass = new XClass(projectPath + "/Classes/UI/UnityViewControllerBase+iOS.mm");
- _xclass.Replace("return res;", "return UIRectEdgeAll;");
}
private static string GetBuildPath()
@@ -202,18 +192,16 @@
[MenuItem("Build/ipa")]
public static void BuildIPA()
{
- var _p = new System.Diagnostics.Process();
- _p.StartInfo.FileName = "osascript";
- _p.StartInfo.Arguments = string.Format("-e 'tell application \"Terminal\" \n activate \n do script \"cd {0} && sh {1} {2}\" \n end tell'",
+ var p = new System.Diagnostics.Process();
+ p.StartInfo.FileName = "osascript";
+ p.StartInfo.Arguments = string.Format("-e 'tell application \"Terminal\" \n activate \n do script \"cd {0} && sh {1} {2}\" \n end tell'",
Application.dataPath + "/../",
"buildipa.sh",
GetBuildPath());
- _p.StartInfo.UseShellExecute = false;
- _p.StartInfo.RedirectStandardOutput = false;
- _p.Start();
- _p.WaitForExit();
+ p.StartInfo.UseShellExecute = false;
+ p.StartInfo.RedirectStandardOutput = false;
+ p.Start();
+ p.WaitForExit();
}
-
-#endif
}
--
Gitblit v1.8.0