自定义语言生成器到Blockly

时间:2017-07-04 01:01:50

标签: javascript json blockly

我知道我可以使用

Blockly.JavaScript['my_code'] = function() {  ... }

但是如何添加像JSON这样的其他语言支持? 我试过..

Blockly.Json['my_code'] = function() {  ... }

我尝试恢复时失败

Blockly.Json.workspaceToCode(this.workspace)

workspaceToCode不是函数。

我需要为Blockly添加新语言

  

我不会显示这种新语言(JSON),它只会用于向机器人发送指令。

我试着

Blockly.Json = new Blockly.Generator('Json');
Blockly.Json['my_code'] = function() {  ... }

中发生错误
Blockly.Json.workspaceToCode(this.workspace)

错误..

Uncaught TypeError: this.init is not a function
    at js.ou3v.module.exports.Blockly.Generator.workspaceToCode

1 个答案:

答案 0 :(得分:2)

为Blockly创建一个新的语言生成器是一项相当大的工作,考虑到这一点,文档在创建文档方面似乎没有太多帮助。

根据我的经验,构建生成器的最佳方法是查看generators/中的现有生成器,我使用JavaScript生成器作为我想要生成C ++的项目的模板码。

值得注意的是Block Factory生成JSON以供在其他Blockly应用程序中使用,但是当我查看code时,没有为它定义实际的生成器。

我认为你得到的错误是因为Blockly.Json没有init函数。这是现有生成器文件中定义的内容,例如,来自JavaScript生成器:

/**
* Initialise the database of variable names.
* @param {!Blockly.Workspace} workspace Workspace to generate code from.
*/
Blockly.JavaScript.init = function(workspace) {
  ....
};

考虑到这一点,您的功能将如下所示:

/**
* Initialise the database of variable names.
* @param {!Blockly.Workspace} workspace Workspace to generate code from.
*/
Blockly.Json.init = function(workspace) {
 .....
};

生成器文件包含其他功能,但是查看现有代码并根据需要进行调整可以帮助您顺利完成。