十年網站開發(fā)經驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網站問題一站解決
Unity3D 開發(fā)游戲需要接入平臺方的SDK才能夠正式發(fā)布,本文記錄IOS SDK接入的流程。
Unity與IOS的互調
要實現(xiàn)游戲SDK的接入,首先要解決的是Unity3D與原生IOS代碼之間的相互調用問題。Unity使用C#作為開發(fā)語言,而IOS采用Objective-C作為開發(fā)語言,如何讓C#調用OC代碼,或者讓OC調用C#代碼。所幸OC和C#都支持直接嵌入C/C++代碼,這里使用C作為兩者之間的橋梁。
為了簡化兩者之間的接口調用和數(shù)據(jù)傳遞,在設計Unity與IOS SDK之間的接口時,Unity調用SDK只有一個接口,而SDK調用Unity也只有一個接口。由于平臺方的SDK差異性較大,如何保證一個接口可以解決問題?這里我們開發(fā)了一個通用SDK層,游戲只會與通用SDK層交互,而由通用SDK層再與具體的平臺SDK對接。
Unity中調用SDK層的功能:
using System.Runtime.InteropServices; using Cross; using UnityEngine; namespace MuGame { public class IOSPlatformSDK : IPlotformSDK { //!--IOS插件聲明,所有unity調用ios SDK插件走這里 [DllImport("__Internal")] public static extern void CallSDKFunc(string type, string jsonpara);unity中所有的調用都轉化為CallSDKFunc,該函數(shù)由通用SDK提供,參數(shù)type表示功能分類,jsonpara是以json字串表示的一系列參數(shù)。
通用SDK調用返回結果給Unity
//!---------------------------外部接口聲明-------------------------------------------- #if defined(__cplusplus) extern "C"{ #endif extern void UnitySendMessage(const char*, const char*, const char*); #if defined(__cplusplus) } #endif這里使用unityengine.dll提供的C接口UnitySendMessage,這里第1個char* 表示接受該消息的GameObject的name, 第2個表示該GameObject的腳本中接受消息的函數(shù)名,第3個表示傳遞的數(shù)據(jù),這里我們還是使用json來傳遞,同時附帶消息類型。
SDK暴露的C接口的聲明與定義
#if defined(__cplusplus) extern "C" { #endif //游戲層訪問SDK的接口 void CallSDKFunc(char *type, char * jsonpara) { if(connector == NULL) { connector = [SDKConnector sharedInstance]; } [connector _CallSDKFunc :CreateNSString(type) :CreateNSString(jsonpara)]; } #if defined(__cplusplus) } #endif這里CallSDKFunc即上述Unity調用SDK的接口,在OC層,直接由SDKConnector類接收,并分發(fā)處理。
通用SDK
SDKConnector負責消息的分發(fā)
- (void)_CallSDKFunc :(NSString*)type :(NSString*)jsonpara { NSLog(@"[SDK] Recevie cmd = %@ jsonpara = %@\n",type,jsonpara); if ([type isEqualToString:@"login"]) {//登錄 [LanPlatform login:[SDKListener sharedInstance]]; } else if ([type isEqualToString:@"loginout"]) {//登出 [LanPlatform logout:[SDKListener sharedInstance]]; } else if ([type isEqualToString:@"switchAccount"]) {//切換賬號 [LanPlatform switchAccount:[SDKListener sharedInstance]]; } else if ([type isEqualToString:@"pay"]) {//充值 [LanPlatform pay:[SDKListener sharedInstance]]; }這里根據(jù)type類型將消息分發(fā)到通用SDK層對應的處理模塊,再由通用SDK層去調用平臺SDK的API進行具體的處理,注意這里傳入了一個實例SDKListener,SDKListener負責接送平臺SDK的回應,并將數(shù)據(jù)發(fā)送至Unity側。
通用SDK層的功能
目前包含以下常見的模塊:登錄,登出,切換賬號,充值,用戶中心,用戶論壇,用戶反饋,防沉迷,實名認證。以及各項游戲數(shù)據(jù)的上報:選服,進入游戲,創(chuàng)建角色,升級等等。
應用生命周期SDK
SDK中比較特殊的一類,基本上也是所有SDK都需要接入的API是生命周期API,本文處理項對比較特殊一點。
@protocol SDKLifeCycleListener這里定義了一個SDK生命周期監(jiān)聽的協(xié)議SDKLifeCycleListener, 以及注冊該協(xié)議的接口SDKRegisterLifeCycleListener。在App加載的時候,將該監(jiān)聽注冊進去,實現(xiàn)該協(xié)議的也是SDKListener。
@implementation SDKListener //加載函數(shù),實現(xiàn)在加載該類時,注冊生命周期監(jiān)聽函數(shù) +(void)load { NSLog(@"[SDK] load\n"); SDKRegisterLifeCycleListener([SDKListener sharedInstance]); }小結
至此,大概介紹了一下所實現(xiàn)的IOS SDK的方法。簡而言之,unity通過CallSDKFunc調用通用SDK功能,通用SDK通過SDKConnector分發(fā)消息給具體的通用SDK模塊,再由平臺SDK處理。SDKListener負責接收平臺處理的結果和生命周期事件,并將需要的結果返回給Unity。
就目前的實現(xiàn)來看,能夠較好的相對解耦游戲與SDK之間的聯(lián)系,不會因平臺的差異性導致游戲代碼的頻繁改動。當然目前接入的SDK還相對較少還需測試。
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。