解析scratch3.0二次开发之scratch-blocks免编译修改问题
作者:取个昵称就那么难 发布时间:2022-10-18 22:36:57
scratch-blocks编译的时候会出现的问题:scratch-gui依赖的scratch-blocks模块在安装的时候编译会报错。
原因:scratch-blocks编译时要调用的build.py文件运行时发生错误。windowst系统下,代码压缩的过程是build.py通过一个closure-library的插件处理后,发送到谷歌的服务器进行压缩,返回的结果会生成blocks_compressed.js,blocks_compressed_horizontal.js,blocks_compressed_vertical.js这几个文件。(linux系统下,有网友反映会编译成功的。)build.py运行时,因为window系统在574行处要处理大量的信息流,所以导致错误发生。但即便成功,因为之后要把代码发送到国内经常访问不到的谷歌服务器,所以也会经常编译失败。这种方法每修改一次代码就要编译一次,效率比较低,比较耗时。
有没有种方法不用编译,就能修改scratch-blocks代码,而且能即时生效呢?答案是,有的。
scratch3.0是怎么引进scratch-blocks的呢?在scratch-gui的源文件src\containers\blocks.jsx中,引入了scratch-blocks,
import VMScratchBlocks from '../lib/blocks';
嗯…这是经过修改后的blocks,我们再顺着调用的路径,打开文件src\lib\blocks.js,这文件的作用是修改对应的角色(target)块的菜单项。
第一步,引入scratch-blocks,这是已经编译好的文件
import ScratchBlocks from 'scratch-blocks';
第二步,根据vm的数据修改blocks的菜单项。比如looks_costume块的修改代码如下:
ScratchBlocks.Blocks.looks_costume.init = function () {
const json = jsonForMenuBlock('COSTUME', costumesMenu, looksColors, []);
this.jsonInit(json);
};
在修改之前,looks_costume块的菜单项这样子的:
菜单项是原来在scratch-blocks里定义的,没有变化。
修改后是这样子的:
看到没?菜单项的数据和vm联系起来了。
再举个例子吧,比如修改workspace界面在block上右键弹出菜单项,我要保留’添加注释’,然后把其他两项去掉,修改前,右键弹出菜单是这样子的:
在src\lib下创建scratch-blocks-modify文件夹,文件夹里创建了blocks_svg.js文件,从scratch-blocks的core文件夹中找到blocks_svg.js,把其中需要修改的函数代码复制过来。
修改的blocks_svg.js文件代码如下 :
export default function(Blockly){
Blockly.BlockSvg.prototype.showContextMenu_ = function(e) {
if (this.workspace.options.readOnly || !this.contextMenu) {
return;
}
// Save the current block in a variable for use in closures.
var block = this;
var menuOptions = [];
if (this.isDeletable() && this.isMovable() && !block.isInFlyout) {
//menuOptions.push(
// Blockly.ContextMenu.blockDuplicateOption(block, e)); 这是注释掉的代码
if (this.isEditable() && this.workspace.options.comments) {
menuOptions.push(Blockly.ContextMenu.blockCommentOption(block));
}
//menuOptions.push(Blockly.ContextMenu.blockDeleteOption(block));这是注释掉的代码
} else if (this.parentBlock_ && this.isShadow_) {
this.parentBlock_.showContextMenu_(e);
return;
}
// Allow the block to add or modify menuOptions.
if (this.customContextMenu) {
this.customContextMenu(menuOptions);
}
Blockly.ContextMenu.show(e, menuOptions, this.RTL);
Blockly.ContextMenu.currentBlock = this;
};
}
注意:现在可以使用es6来编写代码了。
然后在src\lib\blocks.js文件引入 :
blockSvgModify是导入的函数变量。
最后刷新下界面,修改生效:
方法:知道要修改的scratch-blocks的代码,然后把代码复制到一个js文件中修改,作为一个函数导出来,再把ScratchBlock作为参数传进去,函数返回的就是改过后的scratch-block文件了。
小结:我们可以通过引入scratch-block到一个文件中,在这个文件中修改我们想要修改的scratch-block函数、属性和方法,再导出来,实现我们想要的效果。而且这种方法是热修改。和修改react一样,每次修改会引起gui界面相应的变化,避免反复编译源文件繁琐的过程。
来源:https://blog.csdn.net/jyht1226/article/details/102614337
猜你喜欢
- 摘要在Nginx和uWSGI还没配置时,单独在url.py使用apscheduler设置定时任务,使用python manage.py ru
- 1.首先,我们需要过滤所有客户端提交的内容,其中包括?id=N一类,另外还有提交的html代码中的操作数据库的select及asp文件操作语
- 平时我们在使用MySQL数据库的时候经常会因为操作失误造成数据丢失,MySQL数据库备份可以帮助我们避免由于各种原因造成的数据丢失或着数据库
- 网页得来,原网页广告太多,影响心情 <html> <head> <title>检查是否为URL</
- 什么是PRC&GRPCRPC是远程过程调用(Remote Procedure Call)的缩写形式, RPC 的主要功能目标是让构建
- 首先使用内置模块os.>>> import os>>> code = os.system("p
- 当您使用FILESYSTEMOBJECT(fso)对象获得某个目录下的文件列表的时候,你有没有发现无法控制它们的排序方式,比如按照名字排序,
- 本文实例讲述了python静态方法。分享给大家供大家参考。具体实现方法如下:staticmethod Found at: __builtin
- 引言Python 是一个强大的语言,提供了许多内置函数以帮助开发者编写高效、简洁的代码。在这篇文章中,我们将深入探讨三个内置函数:map、f
- kruskal算法基本思路:先对边按权重从小到大排序,先选取权重最小的一条边,如果该边的两个节点均为不同的分量,则加入到最小生成树,否则计算
- (本篇部分代码综合整理自B站,B站有手把手说明的教程)1.网易云非付费内容爬取器(声明:由于技术十分简单,未到触犯软件使用规则的程度)驱动E
- 代码如下:--销售冠军 --问题:在公司中,老板走进来,要一张每个地区销量前3名的销售额与销售员的报表 --- create t
- 目录前言全局锁表级锁表锁元数据锁(Metadata Locking,简称:MDL锁)总结参考资料前言在真实的企业开发环境中使用MySQL,M
- 授权就是为某个用户赋予某些权限。例如,可以为新建的用户赋予查询所有数据库和表的权限。MySQL 提供了 GRANT 语句来为用户设置权限。在
- PID算法实现import timeclass PID: def __init__(self, P=0.2, I=0.0, D=
- 文件上传是所有UI自动化测试都要面对的一个头疼问题,今天博主在这里给大家分享下自己处理文件上传的经验,希望能够帮助到广大被文件上传坑住的se
- 一、功能介绍1.MySQL Servers该功能是mysql主要的服务,也是必须安装的功能。2.Mysql WorkBench这个是mysq
- 昨天我突发奇想,想用display:inline来实现三列的布局可是搞了半天就是不行。但是理论上是可以的呀(后来才发现是不理解的不深刻,我的
- 最近在D4得到一本(美) Penny Mcintire写的《Visual Design for the Modern Web》.突然觉得可用
- 假设有一个可迭代对象,现在想要对它内部的元素进行排序,我们一般会使用内置函数 sorted,举个例子:data = (3