[Blockly开发攻略2] 创建工作空间workspace

1. 什么是Blockly的workspace

workspace是Blockly中非常重要的对象,它是其他组件运行的基础,所有其他Blockly的组件都必须在workspace中才能工作。以下图为例,图中蓝框以内的范围都是workspace,左侧的ToolBox(下一节的内容)、中间的积木块组合(blocks)、右下方的垃圾桶和滑动条都是workspace的子对象。通常来说,一个应用只需要创建一个workspace就足够。如果想要使用多个workspace,需要解决一些命名空间冲突的问题,本攻略不包括这部分内容。


workspace

2. 创建一个workspace

a. 从github上下载Blockly并解压,然后将blockly-master文件夹拷贝到一个新的工作空间下,改名为blockly(方便后续开发)。blockly文件夹中包含了Blockly的源码、示例代码、编译程序以及编译后的代码。如果你的应用对包体大小很敏感,应当进行适当的裁剪。


blockly项目源码

在同一个目录下新建一个文件,并将名字改为 index1.html(任何xxxx.html都可以,名字不重要,后文简称index1)。


index1

b. 接下来打开并编辑index1,输入下面的代码。
<!DOCTYPE html>
<html>
    <head>
        <title>我的第一个Blockly应用</title>
        <script src="blockly/blockly_compressed.js"></script>
        <script src="blockly/msg/js/zh-hans.js"></script>
    </head>
    <body>
        <div id="blocklyDiv" style="width:400px;height:600px"></div>
        <script>
            var blocklyDiv = document.getElementById('blocklyDiv');
            var workspace = Blockly.inject(blocklyDiv, {});
        </script>
    </body>
</html>

保存后,用Chrome浏览器打开index1,你将看到下图所示的效果,在左上角的灰色线框内右键能够显示workspace最基本的右键菜单,如果不是这样,检查一下代码是否正确,或者在Chrome中按F12调出调试工具查看具体错误。


固定大小的空workspace

c. 现在我们解释一下上面的代码。
head中第一行定义了网页的标题。第二行引入了编译后的blockly模块。第三行引入了blockly自带的简体中文字符资源。Blockly支持多国语言,所以我们必须明确的引入一种资源(引入多种会产生冲突)。

    <head>
        <title>我的第一个Blockly应用</title>
        <script src="blockly/blockly_compressed.js"></script>
        <script src="blockly/msg/js/zh-hans.js"></script>
    </head>

body中第一行创建了一个空的div并且定义了它的大小,长400像素,宽600像素。
script中第一行通过id获取到了刚才创建的div元素(blocklyDiv)。
第二行用Blockly.inject(blocklyDiv, {})函数在div中注入了一个workspace,这是整个代码最核心的一行。
Blockly提供了Blockly.inject()这样一个方便的接口供我们创建workspace,其中第一个参数是一个页面中的元素,第二个参数是workspace的设置选项,在这个例子中我们全部采用默认设置,参数为空。

    <body>
        <div id="blocklyDiv" style="width:400px;height:600px"></div>
        <script>
            var blocklyDiv = document.getElementById('blocklyDiv');
            var workspace = Blockly.inject(blocklyDiv, {});
        </script>
    </body>

workspace在第一次创建,也就是inject调用时会填充整个div,但它不会随着div的变化自动适应。在介绍workspace的参数之前,我们先让workspace能跟随浏览器大小变化。

3.可变尺寸的workspace

对index1的代码做如下修改:

<!DOCTYPE html>
<html style="height:100%">
    <head>
        <title>我的第一个Blockly应用</title>
        <script src="blockly/blockly_compressed.js"></script>
        <script src="blockly/msg/js/zh-hans.js"></script>
    </head>
    <body style="height:100%">
        <div id="blocklyDiv" style="width:100%;height:100%"></div>
        <script>
            //生成模块列表区域
            var blocklyDiv = document.getElementById('blocklyDiv');
            var workspace = Blockly.inject(blocklyDiv, {});

            //调整工作区域大小
            var onresize = function (e) {
                Blockly.svgResize(workspace);
            };
            //注册resize处理函数
            window.addEventListener('resize', onresize);
            Blockly.svgResize(workspace);
        </script>
    </body>
</html>

首先修改html和body的样式,让他们占整个页面的100%(完全填充)。同时修改div的样式,让他占满整个body。这样,当窗口大小改变时,div的大小就会自动随之变化。
但此时workspace并不会随div改变而改变,Blockly提供了svgResize接口,它能让一个workspace拉伸直到填满其父元素,这里的父元素就是blocklyDiv。因此,我们需要得知div元素何时改变了大小,每当它改变大小时就调用一次Blockly.svgResize(workspace);修改workspace的大小。
div是随页面的改变而改变的,在html中,我们可以用事件(event)机制来获取页面改变的事件。
window.addEventListener('resize', onresize);注册了一个事件回调,当resize事件发生时,调用onresize函数。
我们在上面三行定义了这个onresize函数,它只做一件事情,就是调用Blockly.svgResize(workspace);调整workspace的大小。到此,我们的workspace就能够随着窗口大小改变而改变了。整个流程大致如下:

可变尺寸workspace示意图

4. workspace的设置选项

workspace目前有20个选项(options)可以设置。我们可以在var workspace = Blockly.inject(blocklyDiv, {});定义workspace时进行设置,也可以在后的程序中通过workspace.options进行修改。
下面的代码设置了几个常用的选项,包括资源目录(media)、缩放(zoom)、垃圾桶(trashcan)、滚动条(scrollBar)以及工具栏(ToolBox,下一节专门讲它的创建):

var workspace = Blockly.inject(blocklyDiv, {
    media: 'blockly/media/',
    toolbox: document.getElementById('toolbox'),
    zoom: {
        controls: true,
        wheel: true,
        startScale: 1.0,
        maxScale: 3,
        minScale: 0.5,
        scaleSpeed: 1.05
    },
    trashcan: true,
    scrollBar: true
});

实现效果如下:

workspace选项示例

更多的选项效果,可以参考https://developers.google.com/blockly/guides/get-started/web#configuration逐个进行尝试。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容

  • 概要 64学时 3.5学分 章节安排 电子商务网站概况 HTML5+CSS3 JavaScript Node 电子...
    阿啊阿吖丁阅读 9,071评论 0 3
  • scratch软件的逻辑不复杂,就是用blockly生成语句块,然后用虚拟机抽象成底层语法,最后再调用render...
    hanxianshe_9530阅读 1,242评论 0 1
  • scratch软件的逻辑不复杂,就是用blockly生成语句块,然后用虚拟机抽象成底层语法,最后再调用render...
    千茉紫依阅读 4,233评论 0 12
  • 用了一個最無聊的題目來總結我的過去一年,打算用最無聊的問答方式來進行總結。 1.2014年你去過哪些地方(旅行、演...
    FionChak阅读 276评论 0 2
  • iOS设计模式 - 策略 原理图 说明 把解决相同问题的算法抽象成策略(相同问题指的是输入参数相同,但根据算法不同...
    XZhongWen阅读 139评论 0 0