ARChon 分析之七:启动流程分析

引文
通过前面几篇文章的介绍,现在来看ARChon的js代码就简单多了。基础代码是 ARC 的运行环境。然后ChromeApp启动,ChromeApp在配置项中配置了apk的路径。然后调用 ARChon的扩展程序。打开一个窗口。

那么 ARChon 从哪里看起呢?

main.js

chrome.app.runtime.onLaunched.addListener(onLaunch);

...

launchAppWindow();

...

function launchAppWindow(opt_userEmail) {
    var time_0 = (new Date()).getTime();
    var abs_index_html = 'runtime/gen_index.min.html';
    var window_id = '';
    var runtime_id = getRuntimeID();
    // Workaround crbug.com/180039 by constructing the absolute path (within
    // the App CRX root) to index.html
    abs_index_html = '/_modules/' + runtime_id + '/gen_index.min.html';
    window_id = runtime_id;

    // Override the window ID so App windows from tests will be distinct.
    if (args.hasOwnProperty('windowIdOverride')) {
      window_id = args['windowIdOverride'];
    }

    appWindow = chrome.app.window.get(window_id);
    if (appWindow != null && !args.forceWindowCreate) {
      var onRelaunched = appWindow.contentWindow.arc.onRelaunched;
      if (!onRelaunched) {
        console.error('onLaunched is called during initialization.');
        return;
      }
      onRelaunched(args);
      return;
    }

    // Note: The code above this point runs every time the App Launcher
    // icon is clicked, regardless of whether the App is currently launched.
    // Do not put one-time init code above this point.
    // TODO(crbug.com/417403): Refactor this whole function, there are clearly
    // two paths here, one for when the app is already launched and needs to
    // be relaunched, and when we need a new window to be created.  There
    // should not be the need for a comment like this about not putting one-time
    // init code in "launchAppWindow".

    console.time('ARC Window Popup');
    maybeKillDexopt_();
    crashReporter.init();
    var appWidth = arcMetadata.getValue('width');
    var appHeight = arcMetadata.getValue('height') + _TOPBAR_HEIGHT;

    var options = {
      // Specify an id for the window to make the window a singleton.
      id: window_id,
      // TODO(jhorwich) Switch to innerBounds when Chrome 36 is stable as this
      // bounds is deprecated in favor of innerBounds.
      width: appWidth,
      height: appHeight,
      resizable: arcMetadata.getValue('resize') != 'disabled',
      // Showing the app window is not a cheap operation for the browser
      // process. Not to slow down nexe loading, create the window with
      // 'hidden: true', and show it later in plugin.js when the process
      // is idle.
      hidden: true,
      frame: 'none'
    };

    if (!systemDirectoriesCreated) {
      systemDirectoriesCreated = createSystemDirectories();
    }

    chrome.app.window.create(abs_index_html, options, function(w) {
      console.timeEnd('ARC Window Popup');
      console.time('ARC appWindow Init');
      if (opt_appWindowCreationCallback)
        opt_appWindowCreationCallback(w);

      appWindow = w;
      appWindow.contentWindow['arc'] = {
        launchArgs: args,
        appLaunchTime: time_0,
        backgroundPage: window,
        runtimeUpdatedWhileRunning: null,
        userEmail: opt_userEmail,
        systemDirectoriesReady: new PromiseBridge(systemDirectoriesCreated)
      };

      appWindow.setBounds({width: appWidth, height: appHeight});
      appWindow.contentWindow.openParentWindow = function(url) {
        return window.open(url);
      };
      appWindow.onClosed.addListener(function() {
        appWindow = null;
        // Reset |appLaunched| so that the onInstalled handler can dexopt
        // an apk when the app is auto-updated.
        appLaunched = false;
      });
      console.timeEnd('ARC appWindow Init');
    });
}

可以看到,它是获取了ARC运行环境,然后把参数(arcMetadata)都填给ARC。dexopt等安装细节、窗口的显示与渲染、点击事件的输出都是ARC处理的。通过nmf的配置文件可知,chrome会先做连接,然后启动 arc_nacl_x86_64.nexe

那么什么是ARC?如何编译呢?参考这篇文章的背景介绍。

// TODO 未完待续

相关推荐
<p> 欢迎参加英特尔® OpenVINO™工具套件初级课程 !本课程面向零基础学员,将从AI的基本概念开始,介绍人工智能与视觉应用的相关知识,并且帮助您快速理解英特尔® OpenVINO™工具套件的基本概念以及应用场景。整个课程包含了视频的处理,深度学习的相关知识,人工智能应用的推理加速,以及英特尔® OpenVINO™工具套件的Demo演示。通过本课程的学习,将帮助您快速上手计算机视觉的基本知识和英特尔® OpenVINO™ 工具套件的相关概念。 </p> <p> 为保证您顺利收听课程参与测试获取证书,还请您于<strong>电脑端</strong>进行课程收听学习! </p> <p> 为了便于您更好的学习本次课程,推荐您免费<strong>下载英特尔® OpenVINO™工具套件</strong>,下载地址:https://t.csdnimg.cn/yOf5 </p> <p> 收听课程并完成章节测试,可获得本课程<strong>专属定制证书</strong>,还可参与<strong>福利抽奖</strong>,活动详情:https://bss.csdn.net/m/topic/intel_openvino </p> <p> 8月1日-9月30日,学习完成【初级课程】的小伙伴,可以<span style="color:#FF0000;"><strong>免费学习【中级课程】</strong></span>,中级课程免费学习优惠券将在学完初级课程后的7个工作日内发送至您的账户,您可以在:<a href="https://i.csdn.net/#/wallet/coupon">https://i.csdn.net/#/wallet/coupon</a>查询优惠券情况,请大家报名初级课程后尽快学习哦~ </p> <p> <span style="font-size:12px;">请注意:点击报名即表示您确认您已年满18周岁,并且同意CSDN基于商务需求收集并使用您的个人信息,用于注册OpenVINO™工具套件及其课程。CSDN和英特尔会为您定制最新的科学技术和行业信息,将通过邮件或者短信的形式推送给您,您也可以随时取消订阅不再从CSDN或Intel接收此类信息。 查看更多详细信息请点击CSDN“<a href="https://passport.csdn.net/service">用户服务协议</a>”,英特尔“<a href="https://www.intel.cn/content/www/cn/zh/privacy/intel-privacy-notice.html?_ga=2.83783126.1562103805.1560759984-1414337906.1552367839&elq_cid=1761146&erpm_id=7141654/privacy/us/en/">隐私声明</a>”和“<a href="https://www.intel.cn/content/www/cn/zh/legal/terms-of-use.html?_ga=2.84823001.1188745750.1560759986-1414337906.1552367839&elq_cid=1761146&erpm_id=7141654/privacy/us/en/">使用条款</a>”。</span> </p> <p> <br /> </p>
<p> <br /> </p> <p> <br /> </p> <p> <br /> </p> <p> <b><span style="background-color:#FFE500;">【超实用课程内容】</span></b> </p> <p> <span>本课程根据实际开发中总结出来的一些学习思路,从零开始详细讲解</span><span>Flutter</span><span>的基础知识点。从简到难,从浅入深,逐步带领大家了解</span><span>Flutter</span><span>,熟悉</span><span>Flutter</span><span>的组成部分,并且带领大家学习如何使用</span><span>Flutter</span><span>实现</span><span>UI</span><span>功能编写。通过对本视频的学习,你将会掌握</span><span>Flutter</span><span>常用组件和常用布局构建复杂布局、</span><span>Flutter</span><span>路由导航实现多页面构建和交互、</span><span>Flutetr</span><span>手势处理和动画实现动态交互效果,以及如何使用音视频、图片、文字、字体等资源。除此之外,你还可以收获每一章节遇到的重难点问题的解决方案。</span> </p> <p style="font-family:Helvetica;color:#3A4151;font-size:14px;background-color:#FFFFFF;"> <b><span style="background-color:#FFE500;">【课程如何观看?】</span></b> </p> <p style="font-family:Helvetica;color:#3A4151;font-size:14px;background-color:#FFFFFF;"> PC端:<a href="https://edu.csdn.net/course/detail/26277"></a><a href="https://edu.csdn.net/course/detail/26150"></a><a href="https://edu.csdn.net/course/detail/26150"></a><a href="https://edu.csdn.net/course/detail/27286"></a><a href="https://edu.csdn.net/course/detail/26858"></a><a href="https://edu.csdn.net/course/detail/26227">https://edu.csdn.net/course/detail/26227</a> </p> <p style="font-family:Helvetica;color:#3A4151;font-size:14px;background-color:#FFFFFF;"> 移动端:CSDN 学院APP(注意不是CSDN APP哦) </p> <p style="font-family:Helvetica;color:#3A4151;font-size:14px;background-color:#FFFFFF;"> 本课程为录播课,课程永久有效观看时长,大家可以抓紧时间学习后一起讨论哦~ </p> <p class="ql-long-24357476" style="font-family:"color:#3A4151;font-size:14px;background-color:#FFFFFF;"> <strong><span style="background-color:#FFE500;">【学员专享增值服务】</span></strong> </p> <p class="ql-long-24357476" style="font-family:"color:#3A4151;font-size:14px;background-color:#FFFFFF;"> <b>源码开放</b> </p> <p class="ql-long-24357476" style="font-family:"color:#3A4151;font-size:14px;background-color:#FFFFFF;"> 课件、课程案例代码完全开放给你,你可以根据所学知识,自行修改、优化 </p> <p class="ql-long-24357476" style="font-family:"color:#3A4151;font-size:14px;background-color:#FFFFFF;"> 下载方式:电脑登录<a href="https://edu.csdn.net/course/detail/26277"></a><a href="https://edu.csdn.net/course/detail/26150"></a><a href="https://edu.csdn.net/course/detail/27286"></a><a href="https://edu.csdn.net/course/detail/26858"></a><a href="https://edu.csdn.net/course/detail/26227">https://edu.csdn.net/course/detail/26227</a>,点击右下方课程资料、代码、课件等打包下载 </p> <p> <br /> </p>
©️2020 CSDN 皮肤主题: 深蓝海洋 设计师:CSDN官方博客 返回首页