基于webkit内核webos系统架构(一)

基于webkit内核webos系统架构(一)1 引言 WebOS Web basedOperati 或者我们称为网络操作系统 是一种基于浏览器的虚拟的操作系统 用户通过浏览器可以在这个 WebOS 上进行应用程序的操作 而这个应用程序也不是普通的应用程序 是网络的应用程序 WebOS 提供面向网络的操作系统服务 包括 网络资源寻址 全球名称空间 远程执行程序 在客户端执行服务器程序 资源管理 认证与安全 WebOS

1 引言

WebOSWeb-based Operating System)或者我们称为网络操作系统,是一种基于浏览器的虚拟的操作系统,用户通过浏览器可以在这个WebOS上进行应用程序的操作,而这个应用程序也不是普通的应用程序,是网络的应用程序。

WebOS提供面向网络的操作系统服务,包括:网络资源寻址、全球名称空间、远程执行程序(在客户端执行服务器程序)、资源管理、认证与安全。

WebOS支持丰富的网络操作,比如:网页浏览、RSS阅读甚至直接支持一些Web API,提供集中的、全面的(涉及到方方面面的基础网络应用)、友好的(便于使用)Web资源访问能力,是一组网络功能的集合。表现上可以是一个软件包,安装这个软件,可以方便地使用互联网。

随着网络带宽的增加,网络传输速度不断提升,使WebOS的诞生成为可能。大家可以想像一下未来:我们只需要在硬件上安装浏览器软件,便可在任何接通网络的电脑上使用自己熟悉的操作系统。虽然WebOS不会替代现行的操作系统,但是它给予人们工作很大的可移动性与跨平台性,相信WebOS一定会得到长足发展。

2 系统特点简介

WebOS作为基于浏览器技术的多任务操作系统,它以webkit作为UI处理的核心,并在其基础上扩充了丰富的本地功能,通过javascript可访问这些本地功能,这使得本地应用、网页浏览、WEB应用三者的运行环境能统一起来。本地应用采用htmljavascriptCSS开发,配合操作系统提供的数量众多、功能强大的控件,能有效降低应用的开发难度和缩短开发时间。它的多任务机制使得用户可同时运行多个应用,用户可以在多个应用间切换、自由操作,有助于提升用户体验。添加手势功能很适合在小屏幕手机或平板电脑上用户对应用UI的操作。

总之,WebOS是一款注重用户体验、侧重网络应用的手机操作系统。其特点如下:

Ø  开机快,按下电源到到登录界面只需几秒。

Ø  所有的程序都是基于Web的形式。

Ø  具有自恢复、自动更新功能,一旦当机或是有错误,会自动恢复版本,在运行过程中也会检测版本是否有更新,能自动更新版本。

Ø  提供内外层沙箱机制保障系统安全。

Ø  支持HTML 5标准,支持本地存储。

Ø  多进程的浏览器架构。

Ø  对本地存储数据加密保存。

Ø  支持X86ARM体系结构的处理器。

3 系统架构

基于webkit内核webos系统架构(一)

图3.1 WebOS系统架构图

系统从下至上主要由五个部分组成:

Ø  操作系统和驱动,操作系统作为各种应用运行的基础;

Ø  OSAL层是操作系统抽象层,对操作系统提供的API的一层封装层,该层向上层提供一个统一的系统API接口,增强平台的可移植性;

Ø  运行环境和基础库,系统以webkit引擎为核心,提供应用运行的环境,管理应用的启动、运行和终止,通过JS Core扩展应用所需的各种服务,Libraries提供Webkit渲染使用的图形库和graphic库,以及网络连接协议栈等;

Ø  Framework,该层分两个部分,其中主要包含一个Html5的浏览器作为网络应用开发的基础,框架中含有窗口管理、应用管理以及包管理等功能;

Ø  应用层,其中Home是通过web技术实现一个home桌面,提供启动应用功能。系统启动后首先打开一个空白页,在上面添加应用图标,并绑定应用信息和点击事件。

下面我们对系统每个层次,详细说明其内部各模块的作用和功能。

 

3.1 操作系统及抽象层

基于webkit内核webos系统架构(一)

图3.2 操作系统及抽象层

操作系统和驱动,操作系统可以是LinuxWindows以及MacOS,操作系统作为各种应用运行的基础,理论上说,操作系统内核可以是任意一款支持多进程的操作系统内核均可。

OSAL层是操作系统抽象层,对操作系统的API的进行的一层封装层,该层向上层软件提供一套统一的API接口,以至于下层更换操作系统内核时,不会影响上层软件的实现,上层软件从而能够做到真正的跨操作系统平台。

3.2 运行环境及基础库

基于webkit内核webos系统架构(一)

图3.3 运行环境及基础库

Webos系统的运行环境以webkit引擎为核心,提供应用运行的环境,管理应用的启动、运行和终止,通过JS Core扩展应用所需的各种服务,对于耗时短的服务直接调用相应函数完成,对于耗时长、不便于在应用平台进程中实现的服务,通过专门的服务进程完成,服务进程和应用平台进程间通过D-BUS交互;Libraries提供Webkit渲染使用的图形库和graphic库,以及网络连接协议栈等。

Ø  Web Core,网页的解析、渲染、历史、下载、缓存等功能

Ø  JS CoreJS解析器

Ø  GTK,向webkit提供基础的图形组件

Ø  Skia,向webkit提供绘图、图片解码以及绘制功能等

Ø  D-BUS,系统各任务间通信

Ø  Sqlite,嵌入式数据库

Ø  Libc,提供基础C函数库,以及一些数据结构函数操作,例如链表等;同时它也是GTK的基础库

Ø  Networking,网络协议栈

3.3 Framework框架层

基于webkit内核webos系统架构(一)

图3.4 Framework框架

Framework层,是应用的编程框架。应用可以在Framework层之上建立应用程序。该层分两个部分,其中主要包含一个增强型的Html5浏览器引擎作为网络应用开发的基础,其中包括,多进程的管理、历史记录、cookie以及缓存的管理等。框架中另外一部分包含窗口管理、应用管理以及包管理等功能,主要是对系统的事件的响应,窗口的切换,管理系统多个应用的同时运行和并发管理等。

Ø  Process Manager,多进程管理器,为应用启动新的进程等

Ø  Cookie Managercookie的管理

Ø  Cache Manager,缓存的管理

Ø  History Manager,历史的管理,便于窗口的切换,避免窗口的重绘等

Ø  Window Manager,管理窗口的事件响应及焦点切换等工作

Ø  AMS,应用管理,管理应用的生命周期,以及应用的切换

Ø  Package Manager,包管理,应用信息的管理

Ø  View System,扩展的控件系统,便于应用使用集成的控件,统一UI,并减少开发工作量

Ø  Notification Manager,通知管理,通知系统到达的事件,例如小区切换,信号强弱变化,电量等

Ø  Connection Manager,连接管理,管理网络的连接

Ø  Service Manager,服务管理,对系统服务的管理,例如,电话,短信等服务

3.4 应用层

基于webkit内核webos系统架构(一)

图3.5应用层

应用层,其中Home,是通过web技术实现一个home界面,提供启动应用功能。系统启动后首先打开一个空白页,在上面添加应用图标,并绑定应用信息和点击事件处理函数,当有点击事件时调应用管理的open方法启动应用。

4 系统设计原理

4.1 系统运行原理

基于webkit内核webos系统架构(一)

图4.1 系统运行原理图

系统的桌面就是一个浏览器Browser主界面。是通过web技术实现一个hom桌面,提供启动应用功能。实现方法是系统启动后首先打开一个空白页,在上面添加应用图标,并绑定应用信息和做点击事件处理函数,当有点击事件时调应用管理服务器的open方法启动应用。

应用管理器作为系统一个服务进程存在,主要作用是应用生命周期管理和事件的过滤和派发。

Ø  应用管理页面的打开

u  系统启动时可以把home页设置为缺省页,系统启动时首先打开homescreen页面。

Ø  home页面中添加应用信息

u  应用信息放在应用所在目录的appinfo.json文件中,包含如下信息: 

u  -icon:应用图标,在应用管理页面显示。

u  -main:应用的首页名称,相当于应用的入口函数,一般是index.html,必须存在。

u  -id:应用id,必须存在且唯一,用于应用管理。

u  -directory:应用路径。

Ø  绑定点击事件的处理函数

u  通过JS的addEventListener函数实现,例如

u  target.addEventListener(type, handlerFunction);

Ø  点击启动应用

u  在点击应用图标后,事件会传到窗口管理WM服务,WM会将事件继续下发到webview,最终找到实际聚焦的view会调注册的事件处理函数,传入应用id、启动参数,在处理函数参数中根据应用id、启动参数向应用管理器发服务请求启动应用。

Ø  调用服务

u  通过JS Core扩展应用所需的各种服务,系统服务调用采用两种方式:对于耗时短的服务直接调用相应函数完成;对于耗时长、不便于在应用平台进程中实现的服务,通过专门的服务进程完成,服务进程和应用平台进程间通过D-BUS交互。

Ø  对主动上报事件的处理

u  手机中有类事件是由底层设备触发的,需要应用处理,如电话接入。应用这时候可能在运行,也可能还没启动,诸如来电就是这种情况,对于这类事件也可以采用服务机制来处理。应用启动时通过订阅服务的形式注册它感兴趣的事件,当事件到达时,应用管理器把事件发给注册的应用去处理。当应用还没启动时通过应用管理器启动应用,把事件信息作为参数传入。

点击图标启动网络或者本地的应用流程,除了前端事件处理多一些差异外,到了后期和网络应用流程是一致的,当AMSBrowser请求资源后,Browser向本地或者远端发送请求,下载资源,提供给Webkit进行渲染,最终显示在页面中。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/213344.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午6:03
下一篇 2026年3月18日 下午6:03


相关推荐

  • 二进制减法计算,负数原码、反码和补码之间的关系

    二进制减法计算,负数原码、反码和补码之间的关系二进制减法类似于十进制的减法,我们从十进制的减法来推出二进制减法如何进行运算。二进制计算例如101001-011010=001111(41-26=15)的运算。灰色部分为计算过程,绿色字为被减一得到的数,红色字为借一后得到的数。在运算过程中,从右往左逐位进行计算。1-0=1; 0不够减1,向前借一后加2变成2;2-1=1; 0在上一步被借一所以减为-1,-1不够减…

    2026年3月8日
    5
  • 堆栈指针理解

    堆栈指针理解堆栈指针 sp 在片内 RAM128B 中开辟栈区 并随时跟踪栈顶地址 它是按 先进后出 的原则存取数据 开机复位后 单片机栈底地址为 07H 主要用来保存临时数据 局部变量和中断 自程序的返回地址 堆栈指针总是指向栈顶元素 所以数据入栈的时候 堆栈指针先加 1 再压栈 向上增长方式 和计算机的方式一样 出栈的时候先弹出数据 堆栈指针再减 1 nbsp nbsp nbsp nbsp nbsp nbsp nbsp 如果堆栈的实现是往上长的 就是说往顶

    2026年3月19日
    2
  • ansible主机连通性测试报错

    ansible主机连通性测试报错报错提示 root yx01site packages ansibleall mping WARNING providedhost onlylocalhos Notethatthei all usr lib python2 7 site packages requests init py 91 RequestsDepe

    2026年3月20日
    2
  • windows修改dns服务器,windowns中dns服务器配置与管理详解(多图)

    windows修改dns服务器,windowns中dns服务器配置与管理详解(多图)安装DNS服务器在”服务器管理器”-“角色”-“添加角色”中安装DNS服务器。选择DNS服务器点下一步安装,然后安装固定服务器IP地址安装完DNS和配置好固定ip后,我们就可以开始配置DNS。在”开始”-“管理工具”-DNS打开DNS正向区域的建立并为其设置主机。选择”正向查找区域”-右击-新建区域。填写域名之后全部默认设置,直至完成。域名建立之后,我们就可以为其”新建主机”选择”hzu.com”…

    2022年6月3日
    128
  • idea设置全局搜索快捷键

    idea设置全局搜索快捷键idea默认的全局搜索二、修改为Alt+F

    2022年6月22日
    303
  • WebViewJavascriptBridge

    WebViewJavascriptBridgeWeb页面中的JS与iOSNative如何交互?JS和iOSNative就好比两块没有交集的大陆,如果想要使它们相互通信就必须要建立一座“桥梁”。WebViewJavascriptBridge是盛名已久的JSBridge库,它仅使用了少量代码就实现了对于MacOSX的WebView以及iOS平台的UIWebView和WKWebView三种组件的完美支持。WebViewJavascriptBridge主要是作为MacOSX和iOS端(Na.

    2025年8月25日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号