[Scratch3.0 拡張機能] 文字からユニコード番号に変換するちょっとしたエクステンションを作る
※ 当ページには【広告/PR】を含む場合があります。
2020/12/16
何かから何かを変換するブロックタイプ ~ レポーター
+ コマンドタイプ:
何かの処理を実行するブロック
+ レポータータイプ:
文字列や数値を返すブロック
+ ブーリアンタイプ:
判定を行うブロック
+ ハットタイプ:
イベントを監視・処理をするブロック
文字のユニコード番号をコスチューム画像の識別に利用したい
Scratch3エクステンションの作成
エクステンションのブロック表紙絵とアイコン画像
str2unicode.png
str2unicode-small.png
scratch-gui/src/lib/libraries/extensions/str2unicode
index.jsxの中身を修正
scratch-gui/src/lib/libraries/extensions
index.jsx
str2unicode
import React from 'react';
import {FormattedMessage} from 'react-intl';
//...中略
//👇先程作った画像までのリソースパスを定義
import str2unicodeURL from './str2unicode/str2unicode.png';
import str2unicodeIconURL from './str2unicode/str2unicode-small.png';
export default [
///...中略
//👇拡張機能を追加登録
{
name: '文字からユニコードへ変換',
extensionId: 'str2unicode',
iconURL: str2unicodeURL,
insetIconURL: str2unicodeIconURL,
description: (
<FormattedMessage
defaultMessage="文字からユニコードを調べます"
description="Description for the 'Str2Unicode' extension"
id="gui.extension.str2unicode.description"
/>
),
featured: true
}
];
拡張機能の中身を実装
scratch-vm/src/extensions
scratch3_str2unicode
const ArgumentType = require('../../extension-support/argument-type');
const BlockType = require('../../extension-support/block-type');
const Cast = require('../../util/cast');
const log = require('../../util/log');
// 👇先程作成したアイコン画像
const commonSvgIcon = '';
const blockIconURI = commonSvgIcon;
const menuIconURI = commonSvgIcon;
class Scratch3Str2Unicode {
constructor (runtime) {
this.runtime = runtime;
}
getInfo () {
return {
id: 'str2unicode',
name: 'String To Unicode#',
menuIconURI: menuIconURI,
blockIconURI: blockIconURI,
blocks: [
{
opcode: 'writeLog',
blockType: BlockType.COMMAND,
text: 'log [TEXT]',
arguments: {
TEXT: {
type: ArgumentType.STRING,
defaultValue: "hello"
}
}
},
{
opcode: 'getBrowser',
text: 'browser',
blockType: BlockType.REPORTER
}
],
menus: {
}
};
}
writeLog (args) {
const text = Cast.toString(args.TEXT);
log.log(text);
}
getBrowser () {
return navigator.userAgent;
}
}
module.exports = Scratch3Str2Unicode;
scratch-vmの拡張機能リストに追加
scratch-vm/src/extension-support/extension-manager.js
const dispatch = require('../dispatch/central-dispatch');
const log = require('../util/log');
const maybeFormatMessage = require('../util/maybe-format-message');
const BlockType = require('./block-type');
// These extensions are currently built into the VM repository but should not be loaded at startup.
// TODO: move these out into a separate repository?
// TODO: change extension spec so that library info, including extension ID, can be collected through static methods
const builtinExtensions = {
//...中略
//👇新規エクステンションのindex.jsのパスで登録
str2unicode: () => require('../extensions/scratch3_str2unicode')
};
//...以下略
エクステンションの動作確認
$ npm start
#OR
$ yarn start
http://localhost:8601
codePointAtメソッド
// "あ"のコードポイントを取得
console.log("あ".codePointAt(0)); // => 12354
// "あ"のコードポイントを取得
console.log("あ".codePointAt(0)).toString(16); // => 3042
文字からコードポイントを返すスクラッチブロック
scratch-vm/src/extensions/scratch3_str2unicode/index.js
const ArgumentType = require('../../extension-support/argument-type');
///...略
class Scratch3Str2Unicode {
///...略
getInfo () {
return {
id: 'str2unicode',
///...略
blocks: [
///...略
//👇①レポータータイプの(引数あり)関数を定義
{
opcode: 'getCodePoint',
text: '文字>コードポイント [STR]',
blockType: BlockType.REPORTER,
arguments: {
STR: {
type: ArgumentType.STRING,
defaultValue: 'あ'
}
}
}
],
///...略
};
}
//👇②文字をコードポイントに変換するレポーター
getCodePoint (args) {
//👇STRで定義していた引数を受け取る
const text = Cast.toString(args.STR);
//👇文字からポイントコードポイントへ変換して返す
return text.codePointAt(0).toString(16);
}
}
///...以下略
+ COMMAND:
関数を実行するブロック。
引数を定義して利用することも可能
+ REPORTER:
特定の文字列や数値などを返すブロック。
引数を与えて利用することもできる
+ BOOLEAN:
判定に特化したブロック。
true/falseのどちらかを返す。
引数を与えて真偽を判断して返すことも可能。
+ HAT:
エクステンションのコード内部の変数(true/false)を監視して、
trueのときにだけ処理を実行するブロック。
イベントのトリガーとして利用できる
まとめ
参考サイト
記事を書いた人
ナンデモ系エンジニア
これからの"地方格差"なきプログラミング教育とは何かを考えながら、 地方密着型プログラミング学習関連テーマの記事を不定期で独自にブログ発信しています。
カテゴリー