diff --git a/fieldeditors/extensions.ts b/fieldeditors/extensions.ts
index 7df5025e..94c4bf5b 100644
--- a/fieldeditors/extensions.ts
+++ b/fieldeditors/extensions.ts
@@ -1,10 +1,15 @@
///
///
+import { FieldGestures } from "./field_gestures";
+
pxt.editor.initFieldExtensionsAsync = function (opts: pxt.editor.FieldExtensionOptions): Promise {
pxt.debug('loading pxt-microbit field editors...')
const res: pxt.editor.FieldExtensionResult = {
- fieldEditors: []
+ fieldEditors: [{
+ selector: "gestures",
+ editor: FieldGestures
+ }]
};
return Promise.resolve(res);
}
\ No newline at end of file
diff --git a/fieldeditors/field_gestures.ts b/fieldeditors/field_gestures.ts
new file mode 100644
index 00000000..350cd294
--- /dev/null
+++ b/fieldeditors/field_gestures.ts
@@ -0,0 +1,33 @@
+///
+///
+///
+
+export interface FieldGesturesOptions extends pxtblockly.FieldImagesOptions {
+ columns?: string;
+ width?: string;
+}
+
+export class FieldGestures extends pxtblockly.FieldImages implements Blockly.FieldCustom {
+ public isFieldCustom_ = true;
+
+ constructor(text: string, options: FieldGesturesOptions, validator?: Function) {
+ super(text, options, validator);
+
+ this.columns_ = parseInt(options.columns) || 4;
+ this.width_ = parseInt(options.width) || 350;
+ this.addLabel_ = true;
+
+ this.setText = Blockly.FieldDropdown.prototype.setText;
+ this.updateWidth = (Blockly.Field as any).prototype.updateWidth;
+ this.updateTextNode_ = Blockly.Field.prototype.updateTextNode_;
+ }
+
+ trimOptions_() {
+ }
+
+ protected buttonClick_ = function (e: any) {
+ let value = e.target.getAttribute('data-value');
+ this.setValue(value);
+ Blockly.DropDownDiv.hide();
+ };
+}
\ No newline at end of file
diff --git a/libs/core/enums.d.ts b/libs/core/enums.d.ts
index 9a7689c1..431629c3 100644
--- a/libs/core/enums.d.ts
+++ b/libs/core/enums.d.ts
@@ -69,56 +69,67 @@ declare namespace basic {
* Raised when shaken
*/
//% block=shake
+ //% jres=gestures.shake
Shake = 11, // MICROBIT_ACCELEROMETER_EVT_SHAKE
/**
* Raised when the logo is upward and the screen is vertical
*/
//% block="logo up"
+ //% jres=gestures.tiltforward
LogoUp = 1, // MICROBIT_ACCELEROMETER_EVT_TILT_UP
/**
* Raised when the logo is downward and the screen is vertical
*/
//% block="logo down"
+ //% jres=gestures.tiltbackwards
LogoDown = 2, // MICROBIT_ACCELEROMETER_EVT_TILT_DOWN
/**
* Raised when the screen is pointing down and the board is horizontal
*/
//% block="screen up"
+ //% jres=gestures.frontsideup
ScreenUp = 5, // MICROBIT_ACCELEROMETER_EVT_FACE_UP
/**
* Raised when the screen is pointing up and the board is horizontal
*/
//% block="screen down"
+ //% jres=gestures.backsideup
ScreenDown = 6, // MICROBIT_ACCELEROMETER_EVT_FACE_DOWN
/**
* Raised when the screen is pointing left
*/
//% block="tilt left"
+ //% jres=gestures.tiltleft
TiltLeft = 3, // MICROBIT_ACCELEROMETER_EVT_TILT_LEFT
/**
* Raised when the screen is pointing right
*/
//% block="tilt right"
+ //% jres=gestures.tiltright
TiltRight = 4, // MICROBIT_ACCELEROMETER_EVT_TILT_RIGHT
/**
* Raised when the board is falling!
*/
//% block="free fall"
+ //% jres=gestures.freefall
FreeFall = 7, // MICROBIT_ACCELEROMETER_EVT_FREEFALL
/**
* Raised when a 3G shock is detected
*/
//% block="3g"
+ //% jres=gestures.impact3g
ThreeG = 8, // MICROBIT_ACCELEROMETER_EVT_3G
/**
* Raised when a 6G shock is detected
*/
//% block="6g"
+ //% jres=gestures.impact6g
SixG = 9, // MICROBIT_ACCELEROMETER_EVT_6G
/**
* Raised when a 8G shock is detected
*/
//% block="8g"
+ //% jres=gestures.impact8g
EightG = 10, // MICROBIT_ACCELEROMETER_EVT_8G
}
diff --git a/libs/core/gestures.jres b/libs/core/gestures.jres
new file mode 100644
index 00000000..05a112f2
--- /dev/null
+++ b/libs/core/gestures.jres
@@ -0,0 +1,39 @@
+{
+ "*": {
+ "namespace": "gestures",
+ "dataEncoding": "base64"
+ },
+ "shake": {
+ "icon": ""
+ },
+ "freefall": {
+ "icon": ""
+ },
+ "frontsideup": {
+ "icon": ""
+ },
+ "backsideup": {
+ "icon": ""
+ },
+ "impact3g": {
+ "icon": ""
+ },
+ "impact6g": {
+ "icon": ""
+ },
+ "impact8g": {
+ "icon": ""
+ },
+ "tiltleft": {
+ "icon": ""
+ },
+ "tiltright": {
+ "icon": ""
+ },
+ "tiltbackwards": {
+ "icon": ""
+ },
+ "tiltforward": {
+ "icon": ""
+ }
+}
\ No newline at end of file
diff --git a/libs/core/input.cpp b/libs/core/input.cpp
index 63dbccf9..e5d90292 100644
--- a/libs/core/input.cpp
+++ b/libs/core/input.cpp
@@ -59,56 +59,67 @@ enum class Gesture {
* Raised when shaken
*/
//% block=shake
+ //% jres=gestures.shake
Shake = MICROBIT_ACCELEROMETER_EVT_SHAKE,
/**
* Raised when the logo is upward and the screen is vertical
*/
//% block="logo up"
+ //% jres=gestures.tiltforward
LogoUp = MICROBIT_ACCELEROMETER_EVT_TILT_UP,
/**
* Raised when the logo is downward and the screen is vertical
*/
//% block="logo down"
+ //% jres=gestures.tiltbackwards
LogoDown = MICROBIT_ACCELEROMETER_EVT_TILT_DOWN,
/**
* Raised when the screen is pointing down and the board is horizontal
*/
//% block="screen up"
+ //% jres=gestures.frontsideup
ScreenUp = MICROBIT_ACCELEROMETER_EVT_FACE_UP,
/**
* Raised when the screen is pointing up and the board is horizontal
*/
//% block="screen down"
+ //% jres=gestures.backsideup
ScreenDown = MICROBIT_ACCELEROMETER_EVT_FACE_DOWN,
/**
* Raised when the screen is pointing left
*/
//% block="tilt left"
+ //% jres=gestures.tiltleft
TiltLeft = MICROBIT_ACCELEROMETER_EVT_TILT_LEFT,
/**
* Raised when the screen is pointing right
*/
//% block="tilt right"
+ //% jres=gestures.tiltright
TiltRight = MICROBIT_ACCELEROMETER_EVT_TILT_RIGHT,
/**
* Raised when the board is falling!
*/
//% block="free fall"
+ //% jres=gestures.freefall
FreeFall = MICROBIT_ACCELEROMETER_EVT_FREEFALL,
/**
* Raised when a 3G shock is detected
*/
//% block="3g"
+ //% jres=gestures.impact3g
ThreeG = MICROBIT_ACCELEROMETER_EVT_3G,
/**
* Raised when a 6G shock is detected
*/
//% block="6g"
+ //% jres=gestures.impact6g
SixG = MICROBIT_ACCELEROMETER_EVT_6G,
/**
* Raised when a 8G shock is detected
*/
//% block="8g"
+ //% jres=gestures.impact8g
EightG = MICROBIT_ACCELEROMETER_EVT_8G
};
@@ -169,7 +180,7 @@ namespace input {
//% help=input/on-gesture weight=84 blockGap=8
//% blockId=device_gesture_event block="on |%NAME"
//% parts="accelerometer"
- //% NAME.fieldEditor="gridpicker" NAME.fieldOptions.columns=4
+ //% NAME.fieldEditor="gestures" NAME.fieldOptions.columns=4
void onGesture(Gesture gesture, Action body) {
int gi = (int)gesture;
if (gi == MICROBIT_ACCELEROMETER_EVT_3G && uBit.accelerometer.getRange() < 3)
diff --git a/libs/core/jres/gestures/backsideup-icon.png b/libs/core/jres/gestures/backsideup-icon.png
new file mode 100644
index 00000000..225d5cb3
Binary files /dev/null and b/libs/core/jres/gestures/backsideup-icon.png differ
diff --git a/libs/core/jres/gestures/freefall-icon.png b/libs/core/jres/gestures/freefall-icon.png
new file mode 100644
index 00000000..5b2bb2ed
Binary files /dev/null and b/libs/core/jres/gestures/freefall-icon.png differ
diff --git a/libs/core/jres/gestures/frontsideup-icon.png b/libs/core/jres/gestures/frontsideup-icon.png
new file mode 100644
index 00000000..074e7d3d
Binary files /dev/null and b/libs/core/jres/gestures/frontsideup-icon.png differ
diff --git a/libs/core/jres/gestures/impact3g-icon.png b/libs/core/jres/gestures/impact3g-icon.png
new file mode 100644
index 00000000..759d23ed
Binary files /dev/null and b/libs/core/jres/gestures/impact3g-icon.png differ
diff --git a/libs/core/jres/gestures/impact6g-icon.png b/libs/core/jres/gestures/impact6g-icon.png
new file mode 100644
index 00000000..ca128d96
Binary files /dev/null and b/libs/core/jres/gestures/impact6g-icon.png differ
diff --git a/libs/core/jres/gestures/impact8g-icon.png b/libs/core/jres/gestures/impact8g-icon.png
new file mode 100644
index 00000000..7c70a7cd
Binary files /dev/null and b/libs/core/jres/gestures/impact8g-icon.png differ
diff --git a/libs/core/jres/gestures/shake-icon.png b/libs/core/jres/gestures/shake-icon.png
new file mode 100644
index 00000000..59e1dc43
Binary files /dev/null and b/libs/core/jres/gestures/shake-icon.png differ
diff --git a/libs/core/jres/gestures/tiltbackwards-icon.png b/libs/core/jres/gestures/tiltbackwards-icon.png
new file mode 100644
index 00000000..92962e55
Binary files /dev/null and b/libs/core/jres/gestures/tiltbackwards-icon.png differ
diff --git a/libs/core/jres/gestures/tiltforward-icon.png b/libs/core/jres/gestures/tiltforward-icon.png
new file mode 100644
index 00000000..41d49270
Binary files /dev/null and b/libs/core/jres/gestures/tiltforward-icon.png differ
diff --git a/libs/core/jres/gestures/tiltleft-icon.png b/libs/core/jres/gestures/tiltleft-icon.png
new file mode 100644
index 00000000..d119a15f
Binary files /dev/null and b/libs/core/jres/gestures/tiltleft-icon.png differ
diff --git a/libs/core/jres/gestures/tiltright-icon.png b/libs/core/jres/gestures/tiltright-icon.png
new file mode 100644
index 00000000..9f8308f8
Binary files /dev/null and b/libs/core/jres/gestures/tiltright-icon.png differ
diff --git a/libs/core/pxt.json b/libs/core/pxt.json
index 3e12d367..2c275ddf 100644
--- a/libs/core/pxt.json
+++ b/libs/core/pxt.json
@@ -21,6 +21,7 @@
"icons.jres",
"input.cpp",
"input.ts",
+ "gestures.jres",
"control.ts",
"control.cpp",
"game.ts",
diff --git a/libs/core/shims.d.ts b/libs/core/shims.d.ts
index 3018e5bc..5df6892c 100644
--- a/libs/core/shims.d.ts
+++ b/libs/core/shims.d.ts
@@ -233,7 +233,7 @@ declare namespace input {
//% help=input/on-gesture weight=84 blockGap=8
//% blockId=device_gesture_event block="on |%NAME"
//% parts="accelerometer"
- //% NAME.fieldEditor="gridpicker" NAME.fieldOptions.columns=4 shim=input::onGesture
+ //% NAME.fieldEditor="gestures" NAME.fieldOptions.columns=4 shim=input::onGesture
function onGesture(gesture: Gesture, body: () => void): void;
/**
diff --git a/resources/gestures/BackSideUp.svg b/resources/gestures/BackSideUp.svg
new file mode 100755
index 00000000..69323d1b
--- /dev/null
+++ b/resources/gestures/BackSideUp.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/resources/gestures/FreeFall.svg b/resources/gestures/FreeFall.svg
new file mode 100755
index 00000000..eee781ab
--- /dev/null
+++ b/resources/gestures/FreeFall.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/resources/gestures/FrontSideUp.svg b/resources/gestures/FrontSideUp.svg
new file mode 100755
index 00000000..07d2d1c6
--- /dev/null
+++ b/resources/gestures/FrontSideUp.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/resources/gestures/Impact3G.svg b/resources/gestures/Impact3G.svg
new file mode 100755
index 00000000..3d1d6b0c
--- /dev/null
+++ b/resources/gestures/Impact3G.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/resources/gestures/Impact6G.svg b/resources/gestures/Impact6G.svg
new file mode 100755
index 00000000..456d2f6f
--- /dev/null
+++ b/resources/gestures/Impact6G.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/resources/gestures/Impact8G.svg b/resources/gestures/Impact8G.svg
new file mode 100755
index 00000000..f4696728
--- /dev/null
+++ b/resources/gestures/Impact8G.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/resources/gestures/Shake.svg b/resources/gestures/Shake.svg
new file mode 100755
index 00000000..0a09f218
--- /dev/null
+++ b/resources/gestures/Shake.svg
@@ -0,0 +1,72 @@
+
+
diff --git a/resources/gestures/TiltBackward.svg b/resources/gestures/TiltBackward.svg
new file mode 100755
index 00000000..b79e4442
--- /dev/null
+++ b/resources/gestures/TiltBackward.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/resources/gestures/TiltForward.svg b/resources/gestures/TiltForward.svg
new file mode 100755
index 00000000..1d67aea5
--- /dev/null
+++ b/resources/gestures/TiltForward.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/resources/gestures/TiltLeft.svg b/resources/gestures/TiltLeft.svg
new file mode 100755
index 00000000..159acb0b
--- /dev/null
+++ b/resources/gestures/TiltLeft.svg
@@ -0,0 +1 @@
+
\ No newline at end of file
diff --git a/resources/gestures/TiltRight.svg b/resources/gestures/TiltRight.svg
new file mode 100755
index 00000000..8a7368b9
--- /dev/null
+++ b/resources/gestures/TiltRight.svg
@@ -0,0 +1 @@
+
\ No newline at end of file