Scratch3的结构

整体架构

Scratch3的界面功能划分如下图

Scratch的整体架构如下图所示

scratch-gui: 是基于React的组件库,组成了整个页面。对于界面有定制化的在这个库下进行

scratch-blocks:积木编程模块,创建和生成积木块区域和拖拽效果区域。需要定制化积木块以及积木块相关功能的在这个库下进行 

scratch-vm:虚拟机,管理状态并执行业务逻辑,前端GUI的状态及逻辑部分处理。需要定制化扩展组建在这个库下进行

scratch-l10n:多语言环境,简单描述所有的翻译都在此库

scratch-render:舞台区渲染,在舞台区域出现的基于WebGL的处理器。底层处理svg使用的是scratch-svg-renderer。同类的还有一个scratch-paint,用来处理造型画图。

scratch-storage:作品存储加载

scratch-audio: 声音处理

为什么要这么设计

  • 从流程上来说,应该是用户针对每一个角色/背景在积木区拖拽出一堆积木程序,然后加上角色/背景的初始化数据,可以转化成固定的代表这个角色/背景动画的结构数据。然后用户点击运行,数据将被一个渲染引擎处理展示到舞台上,形成动画。
    从系统的复杂性来说,解耦非常由必要,那么按照流程划分,至少有这么几块,基本操作UI层(即scratch-gui,可以包括角色/背景选择,用户的点击按钮等)、单角色/背景积木拼接并转化为结构化数据(即scratch-blocks)、渲染引擎。

  • 就渲染来说,一般分成两个部分:单帧渲染和渲染动画控制
    就如同我们看视频一样,每一个视频都是由很多帧组成的,每一帧的渲染应当是同一个处理,独立出来即scrach-render。在Scratch中回控制帧的播放暂停等操作,需要由一个控制器来管理,即scratch-vm
    在Scratch的真实场景中,导致scratch-render重新绘制的情况很多,比如修改角色的大小,位置,颜色等等,这些状态的变更管理都纳入到scratch-vm中。

  • 多语言部分,对于整个系统来说,各个部分都可能需要,所以独立为一个通用模块比较好

  • Scratch代码最终会生成程序代码,需要有地方存储和加载解析。而且这块功能比较独立,所以当都作为一个模块是有必要的。
    程序的存储目前有两种方案。
    一种是将整个程序打包成一个压缩文件,里面包括了程序运行所需要的所有资源和数据结构。这种程序报可以下载下来,即使在离线的情况下,也可以本地载入运行。缺点是程序包可能会过大,而且多个程序可能共用同一个资源(比如一张图片),但是每个程序包中都必须要有一份,上传下载程序包都非常消耗带宽。
    另一个方案是所有资源都在服务器端保存,每次存储只需存储数据结构即可,资源全部使用url链接,程序包大大缩小。在程序载入时自动到远程拉取资源。缺点是无法在没有网络的情况下运行(无法保存/下载)。
    Scratch在设计之初是要做纯前端的可视化编程系统,所以内置了所有资源的url。编程后可以下载完整的程序压缩包。不用依靠后台也能玩起来。

  • 声音处理模块独立原因很简单,不是必须功能,而且功能相对独立,内部处理还复杂,独立出来就对了

  • 从结构层次来说,Scratch的结构相对扁平(不考虑服务端)。就功能来看,系统由一个个独立功能功能组成,比如scratch-blocks,该模块实现了积木拼接代码,实现代码转义为结构化数据的功能,完全可以独立出来作为一个系统。这些一个个独立的功能模块需要一个粘合剂,将他们的数据和状态串起来,这就是scratch-vm。
    scratch-vm中保存着每一个角色/背景的初始化状态,保存着每一个角色/背景的代码逻辑(积木转义而来),操控代码的渲染逻辑。提供了大量的渲染控制api以及相关事件的钩子函数。
    可以说scratch-vm是整个系统的数据处理中心。

  • Stage层是scratch-gui的共享数据层。里面保存着gui层的共享数据。

Stage层

和scratch-vm不同,scratch-vm管理的是代码编程相关的状态,直白来说就是管理让用户编辑的代码积木跑起来;而Stage是管理网页自身的数据,比如登录态数据、页面加载状态、舞台缩放展示、对话框消息数据等等。
这其中有一个比较复杂的状态:页面加载状态

这是由于这个庞大的前端项目要跑起来,需要加载的数据和处理类型比较多。比如加载一个作品,就可能出现通过作品id远程加载,如果没有id要加载默认模板,还可以通过本地上传一个程序包载入;在用户操作过程中,用户可能手动保存,但是程序自身也会定时保存。
状态的命名还是比较规范的。如果在这之间增加一写状态(比如,新增一个可以通过homeworkId获取展示默认模板,必然要在FETCHING_NEW_DEFAULT状态之上增加一个状态),则必须要对之前的状态了如执掌才能修改,否则可能导致遗漏或状态冲突.

加载优化

在实际运行中,这个系统加载的数据还是非常庞大的,而且现在移动端有独立运行舞台区的需求,而目前只展示舞台区,但是加载了很多无关的模块。需要做加载相关的优化。
分析

  • 系统庞大,代码量比较多,加载数据比较多。但是并不是每一个模块在页面初始化时用到。
  • 脚本公共出口就只有一个,加载的模块一样。应该提供一些独立功能(比如只展示舞台)的入口脚本。
  • 目前我们系统每次保存,是将编程后所有的数据(包括图片)打成了一个完整的压缩包。这块有很大优化空间
  • 对代码打包结果模块分析,发现有很多地方用到同一模块,但是每一块都有一份代码拷贝
  • 打包后所有代码只有一个js,有26M。每次一个微小的修改都打出新包,无法利用浏览器的缓存。

策略

  • 分模块异步加载,程序初始化不需要用到的模块通过异步懒加载的方式独立出去。减少初次进入的包体积
  • 公共模块打包提取。在打包过程中由很多公共包在不同的chunk中都有,重复加载了。
  • 静态模块/第三方包单独打包,这些模块通常改动比较小,程序改动了,但是没有动到这个部分,这个部分的包就不会重新打。那么可以利用浏览器缓存。
  • 运行时模块单独打包,运行时包括链接模块,加载/解析逻辑等。用来定位模块信息的manifest一并包含在里面
  • 拆分入口,主要拆分成三个入口:一个PC编程入口,包括了所有的部分;一个专门运行程序包的入口,无关模块都剔除;一个只包含积木编程区的入口,无关的模块剔除
  • 减少编程代码程序包大小。简单方案:程序包中的角色/背景图片的压缩,简单图案使用svg。后期方案:所有程序包图片资源远程保存,程序包中只保存图片资源的路径。
(0)

相关推荐

  • 纯硬货,无广告:少儿编程到底值不值得学?

    纯硬货,无广告:少儿编程到底值不值得学?

  • 【青少年编程】【Scratch】01 运动模块

    「青少年编程竞赛交流群」已成立(适合6至18周岁的青少年),公众号后台回复[Scratch]或[Python],即可进入.如果加入了之前的社群不需要重复加入. 微信后台回复"资料下载&quo ...

  • 【青少年编程】【Scratch】06 侦测模块

    06 侦测模块 侦测模块是用来检测场景中某一参数的变化,通过参数变化来为下一步操作提供运行依据.通常与控制模块中的条件语句和循环语句一起使用. 具体分为: 与运动相关的侦测: 与按键相关的侦测: 侦测 ...

  • 【青少年编程】【答疑】对「重复执行(10)次」的理解

    Scratch竞赛交流群已成立(适合6至18周岁的青少年),公众号后台回复[Scratch],即可进入.如果加入了之前的社群不需要重复加入. 微信后台回复"资料下载"可获取以往学习 ...

  • 【青少年编程】【答疑】对「等待(0)秒」的理解

    Scratch竞赛交流群已成立(适合6至18周岁的青少年),公众号后台回复[Scratch],即可进入.如果加入了之前的社群不需要重复加入. 微信后台回复"资料下载"可获取以往学习 ...

  • 【青少年编程】【答疑】控制Scratch异步代码的执行顺序

    问题 几天前,我写了一篇图文 对「等待(0)秒」的理解,发现可以利用「等待(0)秒」这个积木块来解决Scratch中异步代码的执行顺序问题,即点击绿旗后可以控制多个角色中响应该事件的代码的顺序. 在这 ...

  • 超细 ‘男’‘女’士衬衫结构制版图与推板教程!

    主编:俊美人台小银分享|超细 '男''女'士衬衫结构制版图与推板教程! 男士基本款衬衫制版和推板教程 男衬衫是男性的主要服装之一,本款为尖角翻立领,六粒扣,左前胸贴明袋一个,装双层过肩,后片两个褶裥, ...

  • 程序员必备的思维能力:结构化思维

    在日常工作中,我们时常会碰到这样的情况,有的人讲一件事情的时候逻辑非常混乱,说了很多事情的罗列,却说不到重点.有的人写代码,本身的业务逻辑并没有多复杂,但呈现出的代码却像一堆线团,混乱不堪,无法理解. ...

  • 如何判断筹码结构的好坏(图解)(2)

    再讲重点,筹码的纯洁性. 这个比较难理解,我只能通过举例来说. 做短线或者超短打板,参与牛股的人主要是谁?激进的操作者,他们的操作是最极端的,买按涨停买,卖按跌停卖.那么反应到盘面就是,极端的走势. ...

  • 如何判断筹码结构的好坏(图解)

    简单来说,好的短线筹码结构,就是两个: 1.筹码断层,筹码断层使得实际流通盘极少,拉升和打压都非常方便. 2.筹码的纯洁性,指的是只有极少的获利筹码或者风险偏好低的猥琐筹码的存在,这两个是牛股炒作的重 ...

  • 中国家谱体系的6大结构,你知道几个?

    中国家谱起源十分久远,甚至在甲骨文时期都可以寻觅到相关踪迹.家谱的编撰也是经历很长时间的演变,宋代以前的朝代,家谱以官修为主,在宋代私修家谱才得到迅速发展,并一直影响到现代. 中国的家谱是一个文化宝库 ...

  • 关于数码电子产品结构设计规范

    关于数码电子产品结构设计规范

  • 视频 | 北方人普遍比南方人胖?这和饮食结构有关系

    大妈辟谣 本栏目由谣言过滤器 × 北京大妈有话说联合推出,每周六准时放送,专为中老年人查证辟谣. 南方人的饮食结构更合理吗? 2019年10月底,中国疾病预防控制中心慢性非传染性疾病预防控制中心研究员 ...

  • 「素材」人体结构动态姿势参考

    艺学绘小编整理: 以上就是艺学绘小编为大家做的详细介绍!希望对大家有所帮助,喜欢的点个关注点个赞哦~艺学绘插画,绘画QAQ.

  • 人类生理结构有哪些不合理的地方?有什么办法能改进吗?

    可能是我们太习惯于我们的身体,所以总觉得我们就是人类演化路上的终极体,现如今这样就是最完美的状态.然而事实证明,人类身体有许多不合理之处. 人体不合理之处 直立行走是人类区别于其他灵长类的重要表现,然 ...