其他分享
首页 > 其他分享> > iOS Unity 项目解析

iOS Unity 项目解析

作者:互联网

本文旨在记录Unity 导出的iOS 项目笔记,另带接入SDK的终极方案,顺带对比Android 项目

1蓝色的目录 Data 这个就是项目的数据,每个项目不一样也就是这个目录不一样,是不是可以把这个目录删掉,

把新倒出项目Data 拷贝过来就完成项目到处。

2Images.xcassets 这个就是图片目录类似 Android Drable 项目图片资源

3Main.mm  工程入口

4Class 黄色目录 这个目录类容多,也是最重要的

  PluginBase 一共四个类接入SDK 的关键类

  AppDelegateListener 顾名思义这个是App代理类,此代理非Java代理,更像是Java的接口,对应Android Activity而不是

  UIApplication,这一点apple和谷歌确实有区别,Apple更为严谨。一般sdk要接入 在适当的位置(适当的位置一定是init方法,因为一般sdk要接入app启动的监听,晚了就监听不到了)

  UnityRegisterAppDelegateListener 方法传入 实现了AppDelegateListener 代理对象

  LifeCycleListener app生命周期监听Android 也是在UIApplication 和Activity中,这也导致了Android Activity 业务太多类写的太复杂不易维护

  UnityRegisterLifeCycleListener 注册声明周期监听,要注意的是注册UnityRegisterAppDelegateListener 就会自动注册生命周期监听

  RenderPluginDelegate对应Activity controller 方法,但是Activity 不仅仅是一个view的控制器,apple就分的非常细,更加的面向对象

  - (void)mainDisplayInited:(struct UnityDisplaySurfaceBase*)surface;

  - (void)onBeforeMainDisplaySurfaceRecreate:(struct RenderingSurfaceParams*)params;

  - (void)onAfterMainDisplaySurfaceRecreate;

  - (void)onFrameResolved;--onCreat

  - (void)didBecomeActive:(NSNotification*)notification;--onStart

  - (void)willResignActive:(NSNotification*)notification;

  - (void)didEnterBackground:(NSNotification*)notification;--> Android 进入后台,apple 分的细 前后都有调用

  - (void)willEnterForeground:(NSNotification*)notification;-->

  - (void)willTerminate:(NSNotification*)notification; -->其实也挺乱的 Activity 的onFinishi 方法(我可能没记住)

      这个不是注册监听的方式,是写一个代理的实现类在main方法加载之前赋值上去的在实现类mm文件结尾加

  没有仔细研究,先挖一坑,我后面抽空填上

  UnityViewControllerListener 这个也是Activity ,哈哈我都无语了,android activity 可以存放很多view ios 一个控制器一般

  只会控制一个view ,控制器可以有子控制器来控制多个view。

  这四个或者三个就包含了skd要的所有方法比喻。启动,获取 设备token,app跳转监听,获取view 控制器。

  之前我的做法是找到 UnityAppController 和ViewController 中的方法挨个加,容易出错不说,他有很多平台方法都长一样容易出错,

  而sdk接入是否成功有的只有发行那边知道,发行说没对,来回搞浪费时间,要加班的哦。

  这个方法要改unity代码其实是不对的,就比如你拿到一个SDK,要改SDK代码一样,一般是实现接口,获取数据做业务。

  UnityIos 不需要修改unity代码 是继承UnityAppController 在他的 mm文件加上

  IMPL_APP_CONTROLLER_SUBCLASS(SubClass),这个对象+Load()方法中告诉unity 启动他的UnityAppController子类

  再在init方法中完成监听注册

  

- (instancetype)init
{
    self = [super init];
    if (self) {
        NSLog(@"-------------");
        UnityRegisterAppDelegateListener(self);//注册监听
    }
    return self;
}

这样可以不修改一句Unity 代码完成sdk接入 Andorid 项目提供了一个UnityPlayerActivity 类供使用,我一般是在这个类的里改源码接SDK,

这样坏处就是Unity会升级,unity会改这里的代码。 不能偷懒,之前我也不会。

接SDK的说完了

Classs/UI 这个就是UI业务了,我也挖个坑后面填

Classs/Unity unity的业务 调摄像头,播放视屏啥的

Classs/下面还有10几个类 崩溃日志,传感器,编译宏定义 pluginsbase 的实现类

Class/Native unity的c++代码

UnityFramework 这个对unity的封装了,比如你要继承 生命周的类你要找到这些类的目录,还有其他相关的类的头文件都拷贝到了这个.h文件

在自己的代码中加一句 

#import <UnityFramework/UnityFramework.h> 所有的你要想要的头文件都帮你倒入了,看下他的代码

#import <UIKit/UIKit.h>
#import <Foundation/Foundation.h>

#import "UnityAppController.h"

#include "UndefinePlatforms.h"
#include <mach-o/ldsyms.h>

 康康 UnityAppController.h

#import <QuartzCore/CADisplayLink.h>

#include "RenderPluginDelegate.h"

 好像有啥也没有 但是对于高级应用而言已经够了。

最后加上iOS 启动播放视屏的方法(没入门的都会,但是如果是天天搞Unity 确实让人摸不到头脑)

#import "ViewController.h"
#import <AVKit/AVKit.h>
@interface ViewController ()
@property (nonatomic,strong) UIView *myView;
@property(nonnull,strong)AVPlayerViewController* mpc;
@end
@implementation ViewController
- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    NSURL *url = [[NSBundle mainBundle] URLForResource:@"move.mov" withExtension:nil];
    self.mpc = [[AVPlayerViewController alloc] init];
    self.mpc.player = [AVPlayer playerWithURL:url];
    __weak typeof(self) weakSelf = self;
    [self.mpc.player addPeriodicTimeObserverForInterval:CMTimeMake(1.0, 1.0) queue:dispatch_get_main_queue() usingBlock:^(CMTime time) {
        /// 更新播放进度
        CGFloat progress = CMTimeGetSeconds(self.mpc.player.currentItem.currentTime) / CMTimeGetSeconds(self.mpc.player.currentItem.duration);
        [weakSelf updateProgress:progress];
    }];
    CGSize s = self.view.bounds.size;
    self.mpc.view.frame = CGRectMake(0,0,s.width, s.height);
    [self.view addSubview:self.mpc.view];
    //self.mpc.showsPlaybackControls = false;//关闭控制器,用户不能操作
    [self.mpc.player play];
}

-(void)updateProgress:(float)pro{
    if(pro >= 0.2){
        [self.mpc.player pause];
        [self.mpc.view removeFromSuperview];
    }
}
@end

 

标签:mpc,void,iOS,监听,Unity,import,解析,self,view
来源: https://www.cnblogs.com/unity-android-ios/p/15417651.html