From 016661423b302199183211347bfe391e9d229938 Mon Sep 17 00:00:00 2001 From: Junya Ishihara Date: Wed, 17 Jul 2024 17:45:27 +0900 Subject: [PATCH] fixup --- sample_projects/handpose.sb3 | Bin 39520 -> 41110 bytes .../scratch3_handpose2scratch/index.js | 75 +++++++++--------- 2 files changed, 38 insertions(+), 37 deletions(-) diff --git a/sample_projects/handpose.sb3 b/sample_projects/handpose.sb3 index 06b6e97e045a44e09943be5b2c7bc1fcd3bd58e8..3ef4869258dca0672b6a7676c7ea847db78302cc 100644 GIT binary patch delta 3992 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 delta 2379 zcmZvec{J1w7sqF4hR0YcjCHb&$&#T*8cMSCWF162c4DkCnlagievvGL!ek%DPD5mg z%2M`q7~UwM$ZIc8_LSvO=RNOvpL5=O&%Ni~@43srpR`uC={h#R+?f3s7YGF61QlRM zY!0hAo8&n`pc+vSi2F#rMfCS^cO#*F0{rnzTVwxEM(_j0jwz-49a8nxJV>A6DAsQ? zB9b}jUKa1%Z@D$bIvzLBg=4Z6r^cO`uGXsAw#?9?T}<-T4b_sq`5Pzsbyv&OE;c&Q zzPD`T1TahqK(~uagJfVvPXEQLK@8zK$=Z8gPT@pg8UM~)>#`}~^F^HFF_{05Xw$_) zXx{OC&soNm(JW@Llt356WwEltu7%cPKaBLWUh<(8@=tp5wFdVdY91_o1P(aN;8tL$ zbFv?sNp#Mgcy4fagnD^O&>w=qaY9z6l=UozH&*93pnigAo}4Et1kUtjoD`qN3?v43 z`9*=pl2cJ~`QcrkIi+{PHfiHCvy)|mzw<8JE{m_1cE8fRq@{J~K#SwtDM*}+W(mc} za;$)vAugCz!0>tcxU-{7oNT%Y-Rw;|A5#1rgqrVE?>?czk6#H>vR4o4J|n$ujiqk#ZB$WD-*_@ z-Ndjv=#8SIj4tw3SPvy4%RPl<#)RxdRcN-pU%>6ba66NdTe9-W$L>~BCDi8XtXfBv zKDkB?TVP#+gsqP+`*UlfYU~wdYfHleV=gj)oQCuLyPFyaeMiV+0q|#jtQf}6%Nyz? zA6-exGm^B;y@=fvcu0${W#Yb1JK-A80bEx7TafL=>ID34GPPI@A-eo++?!o+%0$EM z4U;;TV0eee!I?jXh+Fk|xp%f96<*V6wil?c8kJbssF8P0TNIgxYH9O|PMK)<3Ic99 zYboy2D%9tEca665aVdt61HrT*iI&MsOc&u>QaDRk0zYrB0HjEn&W{`Cx_rtEof^6y zR)w=9?+!HawpxrjyRGsj{T30sPny7`qKSFaa>(t}^Tkg2hU#wNg0P@(D>FLt`7Q08 zyvP}Q^;u8EqQ&JEBSxCii;B!y;Isa=`bluyhlX$1ikIVtSGF_1+i%gHa@DOXC|Zb- zd9v3Pl1k+<%9SN1@I^7)os&SG{{A~``}d8?K9^pvLt>)s%PJ*a))IyIGj90B0Tu|ubXW%o?XA7-vvpFcxKPD z^NEQMYcQy$kW{^$r+n8zd)*lz;&1M$bEG>#@;dfu4 zS%faN9A!b(M2k$E>98??Sc;b%Hsy$`ishEDx^<`z9;(!rtqmL{&w-3+ z4N_jd+J{`Nh{5n{?SdA^>~2|fWw-A{?g;sG21}t=JdZpqss)gc?_k>j9 znZ+SbZd;hC`5kHu*YDga zG?~59H0ARVc=WQ?yF7*0VRN*Zx~b$DPlA#1={{OklgdR38tHwq%1`?PqP~7VC$}2+ z{{7VU%ioP2KJb?rA6Q<8+S%SQ`Z@zE*fZK5C`-0@tz6~#uLPqj&5tO(g%F}L|Ki>P zmq5RxjIb&pPVp}T(=Q(6n|}q~j$nJT=gcL5<*d|ol?HT5I8JS(BN(rmy}p)g;ab6= zjG4C*Ia~2$*|7b!@2-XO4sjoUH1FQKCTmrZW|?Y|9Oy_*q>#-*I2~53@J@_upD11;>dMp&rDo$x%c~+}?Kn}Si=AS{Y?9*U~<>h zpi$RGhdx&S&c5Z5&7~IhCwp}%SvL7a>opBafGjT8giq6=xmd>OcB9zNE8G_sk&n(A z>|b`}^Uz4Neqj5OS~ZVAQ*1}%#$3XcwW8NUn6)zqeofbi;Z;+|%u%v(+EVx|yjcjp z{O;Hk7b$7D(9^r%M@s*EnKVqA9&3!1AA}K3D1=46J*iNoi?zHl35+-SuD11iNKID) zw#VU)YKPmK-`cxX3rwhGjd(iGer2YWv4ixIf zw=&pb+9%gB`-)h`9_z{?#@;J~IbFB6Tg1kK-DkC_=R1%T8HcDsb?mzIRp8hTq^`-% zT)W}rjk|vGZTH7u+QUi-v~9ecalsg8a)kL~(F?FOhkNOw)wkqEWeFs%Yz>6J@vse2 zA!aNf=9z9Tk4Pv-G;iLB&W!m>KN)`fM&uQt)Ai-rGH8jzD3Qbi*gp}2zIMM-jSU1+ zISM4G_BFRV8~YJ@)XMRt#{Vp+ud_ye38~r9U|}$u0OzNGpGg;Eb4{ZTWud5(|B+UX aBuqM$Gfz$c0{yuPIr2y_2-K7Dv-=yWSY8?c diff --git a/scratch-vm/src/extensions/scratch3_handpose2scratch/index.js b/scratch-vm/src/extensions/scratch3_handpose2scratch/index.js index 4590360..b3c8ae2 100644 --- a/scratch-vm/src/extensions/scratch3_handpose2scratch/index.js +++ b/scratch-vm/src/extensions/scratch3_handpose2scratch/index.js @@ -3,18 +3,19 @@ const BlockType = require('../../extension-support/block-type'); const Cast = require('../../util/cast'); const formatMessage = require('format-message'); +// eslint-disable-next-line max-len const blockIconURI = ''; const Message = { getX: { - 'ja': '[HAND_NUMBER] つ目の [LANDMARK] のx座標', - 'ja-Hira': '[HAND_NUMBER] つめの [LANDMARK] のxざひょう', - 'en': 'x of [LANDMARK] of hand no. [HAND_NUMBER]' + 'ja': '[HAND] つ目の [KEYPOINT] のx座標', + 'ja-Hira': '[HAND] つめの [KEYPOINT] のxざひょう', + 'en': 'x of [KEYPOINT] of hand no. [HAND]' }, getY: { - 'ja': '[HAND_NUMBER] つ目の [LANDMARK] のy座標', - 'ja-Hira': 'みぎ [LANDMARK] のyざひょう', - 'en': 'y of [LANDMARK] of hand no. [HAND NUMBER]' + 'ja': '[HAND] つ目の [KEYPOINT] のy座標', + 'ja-Hira': 'みぎ [KEYPOINT] のyざひょう', + 'en': 'y of [KEYPOINT] of hand no. [HAND NUMBER]' }, videoToggle: { 'ja': 'ビデオを [VIDEO_STATE] にする', @@ -51,7 +52,7 @@ const Message = { 'ja-Hira': 'じゅんびにじかんがかかります。すこしのあいだ、そうさができなくなりますがおまちください。', 'en': 'Setup takes a while. The browser will get stuck, but please wait.' }, - landmarks: [ + keypoints: [ { 'ja': '手首', 'ja-Hira': 'てくび', @@ -162,7 +163,7 @@ const Message = { const AvailableLocales = ['en', 'ja', 'ja-Hira']; class Scratch3Handpose2ScratchBlocks { - get HAND_NUMBERS_MENU() { + get HANDS_MENU() { return [ { text: '1', @@ -207,12 +208,12 @@ class Scratch3Handpose2ScratchBlocks { ] } - get LANDMARK_MENU() { - const landmark_menu = []; + get KEYPOINTS_MENU() { + const keypoints = []; for (let i = 1; i <= 21; i++) { - landmark_menu.push({ text: `${Message.landmarks[i - 1][this._locale]} (${i})`, value: String(i) }) + keypoints.push({ text: `${Message.keypoints[i - 1][this._locale]} (${i})`, value: String(i) }) } - return landmark_menu; + return keypoints; } get VIDEO_MENU() { @@ -281,7 +282,7 @@ class Scratch3Handpose2ScratchBlocks { constructor(runtime) { this.runtime = runtime; - this.landmarks = []; + this.keypoints = []; this.ratio = 0.75; const loadScriptSynchronously = (url) => { @@ -301,7 +302,7 @@ class Scratch3Handpose2ScratchBlocks { console.log("Model loaded!") handpose.detectStart(this.video, (results) => { this.hands = results; - }); + }); }); this.runtime.ioDevices.video.enableVideo().then(() => { @@ -324,14 +325,14 @@ class Scratch3Handpose2ScratchBlocks { blockType: BlockType.REPORTER, text: Message.getX[this._locale], arguments: { - HAND_NUMBER: { + HAND: { type: ArgumentType.STRING, - menu: 'handNumbers', + menu: 'handsMenu', defaultValue: '1' }, - LANDMARK: { + KEYPOINT: { type: ArgumentType.STRING, - menu: 'landmark', + menu: 'keypointsMenu', defaultValue: '1' } } @@ -341,14 +342,14 @@ class Scratch3Handpose2ScratchBlocks { blockType: BlockType.REPORTER, text: Message.getY[this._locale], arguments: { - HAND_NUMBER: { + HAND: { type: ArgumentType.STRING, - menu: 'handNumbers', + menu: 'handsMenu', defaultValue: '1' }, - LANDMARK: { + KEYPOINT: { type: ArgumentType.STRING, - menu: 'landmark', + menu: 'keypointsMenu', defaultValue: '1' } } @@ -393,9 +394,9 @@ class Scratch3Handpose2ScratchBlocks { } ], menus: { - landmark: { + keypointsMenu: { acceptReporters: true, - items: this.LANDMARK_MENU + items: this.KEYPOINTS_MENU }, videoMenu: { acceptReporters: true, @@ -409,35 +410,35 @@ class Scratch3Handpose2ScratchBlocks { acceptReporters: true, items: this.INTERVAL_MENU }, - handNumbers: { + handsMenu: { acceptReporters: true, - items: this.HAND_NUMBERS_MENU + items: this.HANDS_MENU }, } }; } getX(args) { - let landmark = parseInt(args.LANDMARK, 10) - 1; - let hand = parseInt(args.HAND_NUMBER, 10) - 1; - if (this.hands?.[hand]?.keypoints?.[landmark]) { + let keypoint = parseInt(args.KEYPOINT, 10) - 1; + let hand = parseInt(args.HAND, 10) - 1; + if (this.hands?.[hand]?.keypoints?.[keypoint]) { if (this.runtime.ioDevices.video.mirror === false) { - return -1 * (240 - this.hands[hand].keypoints[landmark].x * this.ratio); + return -1 * (240 - this.hands[hand].keypoints[keypoint].x * this.ratio); } else { - return 240 - this.hands[hand].keypoints[landmark].x * this.ratio; + return 240 - this.hands[hand].keypoints[keypoint].x * this.ratio; } } else { - return null; + return ''; } } getY(args) { - let landmark = parseInt(args.LANDMARK, 10) - 1; - let hand = parseInt(args.HAND_NUMBER, 10) - 1; - if (this.hands?.[hand]?.keypoints?.[landmark]) { - return 180 - this.hands[hand].keypoints[landmark].y * this.ratio; + let keypoint = parseInt(args.KEYPOINT, 10) - 1; + let hand = parseInt(args.HAND, 10) - 1; + if (this.hands?.[hand]?.keypoints?.[keypoint]) { + return 180 - this.hands[hand].keypoints[keypoint].y * this.ratio; } else { - return null; + return ''; } }