From 8ea6dc64b3c2aa30c1715152bee63f0ec2a19585 Mon Sep 17 00:00:00 2001 From: chaoyuexing <931368239@qq.com> Date: Wed, 29 Aug 2018 14:45:39 +0800 Subject: [PATCH 01/20] =?UTF-8?q?=E5=88=A0=E9=99=A4=E6=97=A0=E7=94=A8?= =?UTF-8?q?=E7=9A=84=E6=96=87=E4=BB=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- assets/scripts/Player1.js | 4 ---- assets/scripts/Player1.js.meta | 9 --------- assets/scripts/Player2.js | 3 --- assets/scripts/Player2.js.meta | 9 --------- assets/scripts/Player3.js | 3 --- assets/scripts/Player3.js.meta | 9 --------- 6 files changed, 37 deletions(-) delete mode 100644 assets/scripts/Player1.js delete mode 100644 assets/scripts/Player1.js.meta delete mode 100644 assets/scripts/Player2.js delete mode 100644 assets/scripts/Player2.js.meta delete mode 100644 assets/scripts/Player3.js delete mode 100644 assets/scripts/Player3.js.meta diff --git a/assets/scripts/Player1.js b/assets/scripts/Player1.js deleted file mode 100644 index ebc2660..0000000 --- a/assets/scripts/Player1.js +++ /dev/null @@ -1,4 +0,0 @@ - -cc.Class({ - extends: require("Player") -}); diff --git a/assets/scripts/Player1.js.meta b/assets/scripts/Player1.js.meta deleted file mode 100644 index 7072625..0000000 --- a/assets/scripts/Player1.js.meta +++ /dev/null @@ -1,9 +0,0 @@ -{ - "ver": "1.0.5", - "uuid": "6c688bfb-d907-4e29-a982-1824fec5a01d", - "isPlugin": false, - "loadPluginInWeb": true, - "loadPluginInNative": true, - "loadPluginInEditor": false, - "subMetas": {} -} \ No newline at end of file diff --git a/assets/scripts/Player2.js b/assets/scripts/Player2.js deleted file mode 100644 index d9fab5c..0000000 --- a/assets/scripts/Player2.js +++ /dev/null @@ -1,3 +0,0 @@ -cc.Class({ - extends: require("Player") -}) diff --git a/assets/scripts/Player2.js.meta b/assets/scripts/Player2.js.meta deleted file mode 100644 index 5f2ddc9..0000000 --- a/assets/scripts/Player2.js.meta +++ /dev/null @@ -1,9 +0,0 @@ -{ - "ver": "1.0.5", - "uuid": "aad309fa-38f1-4e20-bcb4-060202733608", - "isPlugin": false, - "loadPluginInWeb": true, - "loadPluginInNative": true, - "loadPluginInEditor": false, - "subMetas": {} -} \ No newline at end of file diff --git a/assets/scripts/Player3.js b/assets/scripts/Player3.js deleted file mode 100644 index d9fab5c..0000000 --- a/assets/scripts/Player3.js +++ /dev/null @@ -1,3 +0,0 @@ -cc.Class({ - extends: require("Player") -}) diff --git a/assets/scripts/Player3.js.meta b/assets/scripts/Player3.js.meta deleted file mode 100644 index 731122d..0000000 --- a/assets/scripts/Player3.js.meta +++ /dev/null @@ -1,9 +0,0 @@ -{ - "ver": "1.0.5", - "uuid": "a2d377cb-3489-495d-ae4b-10f4e13d9e06", - "isPlugin": false, - "loadPluginInWeb": true, - "loadPluginInNative": true, - "loadPluginInEditor": false, - "subMetas": {} -} \ No newline at end of file From 4d4660e17923e5be3d5a3e1bbe5acde66c7c9443 Mon Sep 17 00:00:00 2001 From: chaoyuexing <931368239@qq.com> Date: Tue, 25 Sep 2018 11:52:59 +0800 Subject: [PATCH 02/20] =?UTF-8?q?demo=E4=BC=98=E5=8C=96=E5=92=8C=E9=80=82?= =?UTF-8?q?=E9=85=8Dcreator2.0+=E7=89=88=E6=9C=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- assets/match.fire.meta | 7 - assets/mikado_outline_shadow.fnt | 99 - assets/mikado_outline_shadow.fnt.meta | 7 - assets/mikado_outline_shadow.png | Bin 117347 -> 0 bytes assets/mikado_outline_shadow.png.meta | 30 - assets/result.fire | 440 - assets/result.fire.meta | 7 - assets/roomList.fire.meta | 7 - assets/scene.meta | 5 + .../{roomList.fire => scene/CreateRoom.fire} | 2886 ++- .../CreateRoom.fire.meta} | 2 +- assets/{game.fire => scene/Game.fire} | 137 +- .../JoinCertainRoom.fire} | 520 +- .../JoinCertainRoom.fire.meta} | 0 assets/{independent.fire => scene/Lobby.fire} | 1321 +- .../Lobby.fire.meta} | 2 +- assets/{login.fire => scene/Login.fire} | 1282 +- .../Login.fire.meta} | 2 +- assets/{createRoom.fire => scene/Match.fire} | 1539 +- .../Match.fire.meta} | 2 +- assets/{match.fire => scene/Result.fire} | 1003 +- assets/scene/Result.fire.meta | 7 + assets/{lobby.fire => scene/RoomList.fire} | 1959 +- assets/scene/RoomList.fire.meta | 7 + .../SelfDefMatch.fire} | 945 +- assets/scene/SelfDefMatch.fire.meta | 7 + assets/{ => scene}/game.fire.meta | 0 assets/scripts/CreateRoom.js | 162 +- assets/scripts/Game.js | 66 +- assets/scripts/Glb.js | 12 +- assets/scripts/Independent.js | 11 +- assets/scripts/JoinCertainRoom.js | 30 +- assets/scripts/Lobby.js | 46 +- assets/scripts/Login.js | 63 +- assets/scripts/Match.js | 81 +- assets/scripts/Matchvs.js | 34 +- assets/scripts/MatchvsDemoResponse.js | 68 +- assets/scripts/MatvhvsMessage.js | 1 + assets/scripts/Player.js | 74 +- assets/scripts/RoomList.js | 45 +- assets/scripts/SelfDefMatch.js | 17 +- assets/scripts/Star.js | 21 +- assets/scripts/result.js | 50 +- assets/selfDefMatch.fire.meta | 7 - assets/textures/PurpleMonster.png | Bin 3013 -> 0 bytes assets/textures/PurpleMonster2.png | Bin 4785 -> 0 bytes assets/textures/PurpleMonster3.png | Bin 4428 -> 0 bytes assets/textures/bg.jpg | Bin 0 -> 27170 bytes .../{btn_play.png.meta => bg.jpg.meta} | 16 +- assets/textures/btn_bg.png | Bin 0 -> 107 bytes ...PurpleMonster.png.meta => btn_bg.png.meta} | 16 +- assets/textures/btn_play.png | Bin 2444 -> 0 bytes assets/textures/icon_arrow_left.png | Bin 0 -> 314 bytes assets/textures/icon_arrow_left.png.meta | 30 + assets/textures/icon_back.png | Bin 0 -> 388 bytes assets/textures/icon_back.png.meta | 30 + assets/textures/owner.png | Bin 0 -> 1101 bytes ...PurpleMonster2.png.meta => owner.png.meta} | 16 +- assets/textures/redio_off.png | Bin 0 -> 534 bytes ...leMonster3.png.meta => redio_off.png.meta} | 16 +- assets/textures/redio_on.png | Bin 0 -> 734 bytes assets/textures/redio_on.png.meta | 30 + creator.d.ts | 20485 ++++++++++++++++ .../matchvs/matchvsjssdk/matchvs.all.js | 483 +- settings/builder.json | 3 +- settings/project.json | 16 +- 66 files changed, 27280 insertions(+), 6872 deletions(-) delete mode 100644 assets/match.fire.meta delete mode 100644 assets/mikado_outline_shadow.fnt delete mode 100644 assets/mikado_outline_shadow.fnt.meta delete mode 100644 assets/mikado_outline_shadow.png delete mode 100644 assets/mikado_outline_shadow.png.meta delete mode 100644 assets/result.fire delete mode 100644 assets/result.fire.meta delete mode 100644 assets/roomList.fire.meta create mode 100644 assets/scene.meta rename assets/{roomList.fire => scene/CreateRoom.fire} (59%) rename assets/{independent.fire.meta => scene/CreateRoom.fire.meta} (65%) rename assets/{game.fire => scene/Game.fire} (97%) rename assets/{joinCertainRoom.fire => scene/JoinCertainRoom.fire} (82%) rename assets/{joinCertainRoom.fire.meta => scene/JoinCertainRoom.fire.meta} (100%) rename assets/{independent.fire => scene/Lobby.fire} (53%) rename assets/{createRoom.fire.meta => scene/Lobby.fire.meta} (65%) rename assets/{login.fire => scene/Login.fire} (79%) rename assets/{lobby.fire.meta => scene/Login.fire.meta} (65%) rename assets/{createRoom.fire => scene/Match.fire} (70%) rename assets/{login.fire.meta => scene/Match.fire.meta} (65%) rename assets/{match.fire => scene/Result.fire} (77%) create mode 100644 assets/scene/Result.fire.meta rename assets/{lobby.fire => scene/RoomList.fire} (65%) create mode 100644 assets/scene/RoomList.fire.meta rename assets/{selfDefMatch.fire => scene/SelfDefMatch.fire} (82%) create mode 100644 assets/scene/SelfDefMatch.fire.meta rename assets/{ => scene}/game.fire.meta (100%) delete mode 100644 assets/selfDefMatch.fire.meta delete mode 100644 assets/textures/PurpleMonster.png delete mode 100644 assets/textures/PurpleMonster2.png delete mode 100644 assets/textures/PurpleMonster3.png create mode 100644 assets/textures/bg.jpg rename assets/textures/{btn_play.png.meta => bg.jpg.meta} (59%) create mode 100644 assets/textures/btn_bg.png rename assets/textures/{PurpleMonster.png.meta => btn_bg.png.meta} (59%) delete mode 100644 assets/textures/btn_play.png create mode 100644 assets/textures/icon_arrow_left.png create mode 100644 assets/textures/icon_arrow_left.png.meta create mode 100644 assets/textures/icon_back.png create mode 100644 assets/textures/icon_back.png.meta create mode 100644 assets/textures/owner.png rename assets/textures/{PurpleMonster2.png.meta => owner.png.meta} (59%) create mode 100644 assets/textures/redio_off.png rename assets/textures/{PurpleMonster3.png.meta => redio_off.png.meta} (59%) create mode 100644 assets/textures/redio_on.png create mode 100644 assets/textures/redio_on.png.meta create mode 100644 creator.d.ts diff --git a/assets/match.fire.meta b/assets/match.fire.meta deleted file mode 100644 index a2407b7..0000000 --- a/assets/match.fire.meta +++ /dev/null @@ -1,7 +0,0 @@ -{ - "ver": "1.0.0", - "uuid": "a6c2b82c-6fa1-4ce4-a281-578aec93a8d7", - "asyncLoadAssets": false, - "autoReleaseAssets": false, - "subMetas": {} -} \ No newline at end of file diff --git a/assets/mikado_outline_shadow.fnt b/assets/mikado_outline_shadow.fnt deleted file mode 100644 index 0a43dfe..0000000 --- a/assets/mikado_outline_shadow.fnt +++ /dev/null @@ -1,99 +0,0 @@ -info face="Mikado" size=36 bold=1 italic=0 charset="" unicode=0 stretchH=100 smooth=1 aa=1 padding=0,0,0,0 spacing=2,2 -common lineHeight=49 base=36 scaleW=512 scaleH=256 pages=1 packed=0 -page id=0 file="mikado_outline_shadow.png" -chars count=95 -char id=32 x=294 y=208 width=0 height=0 xoffset=0 yoffset=40 xadvance=7 page=0 chnl=0 letter="space" -char id=33 x=460 y=132 width=18 height=37 xoffset=1 yoffset=3 xadvance=11 page=0 chnl=0 letter="!" -char id=34 x=131 y=208 width=23 height=22 xoffset=0 yoffset=3 xadvance=15 page=0 chnl=0 letter=""" -char id=35 x=68 y=132 width=31 height=37 xoffset=-0 yoffset=3 xadvance=22 page=0 chnl=0 letter="#" -char id=36 x=122 y=2 width=30 height=44 xoffset=0 yoffset=-1 xadvance=21 page=0 chnl=0 letter="$" -char id=37 x=128 y=51 width=39 height=38 xoffset=-0 yoffset=3 xadvance=30 page=0 chnl=0 letter="%" -char id=38 x=242 y=51 width=33 height=38 xoffset=1 yoffset=3 xadvance=25 page=0 chnl=0 letter="&" -char id=39 x=156 y=208 width=15 height=22 xoffset=0 yoffset=3 xadvance=7 page=0 chnl=0 letter="'" -char id=40 x=251 y=2 width=23 height=42 xoffset=0 yoffset=3 xadvance=14 page=0 chnl=0 letter="(" -char id=41 x=276 y=2 width=23 height=42 xoffset=-1 yoffset=3 xadvance=14 page=0 chnl=0 letter=")" -char id=42 x=50 y=208 width=23 height=24 xoffset=0 yoffset=1 xadvance=15 page=0 chnl=0 letter="*" -char id=43 x=232 y=171 width=28 height=30 xoffset=-0 yoffset=9 xadvance=19 page=0 chnl=0 letter="+" -char id=44 x=30 y=208 width=18 height=26 xoffset=0 yoffset=21 xadvance=10 page=0 chnl=0 letter="," -char id=45 x=246 y=208 width=22 height=16 xoffset=1 yoffset=16 xadvance=14 page=0 chnl=0 letter="-" -char id=46 x=196 y=208 width=18 height=19 xoffset=0 yoffset=22 xadvance=10 page=0 chnl=0 letter="." -char id=47 x=223 y=2 width=26 height=42 xoffset=-0 yoffset=1 xadvance=17 page=0 chnl=0 letter="/" -char id=48 x=134 y=92 width=30 height=38 xoffset=0 yoffset=3 xadvance=22 page=0 chnl=0 letter="0" -char id=49 x=435 y=132 width=23 height=37 xoffset=-1 yoffset=3 xadvance=15 page=0 chnl=0 letter="1" -char id=50 x=349 y=132 width=27 height=37 xoffset=-0 yoffset=3 xadvance=19 page=0 chnl=0 letter="2" -char id=51 x=351 y=92 width=28 height=38 xoffset=-0 yoffset=2 xadvance=19 page=0 chnl=0 letter="3" -char id=52 x=35 y=132 width=31 height=37 xoffset=-1 yoffset=3 xadvance=21 page=0 chnl=0 letter="4" -char id=53 x=321 y=92 width=28 height=38 xoffset=-0 yoffset=2 xadvance=19 page=0 chnl=0 letter="5" -char id=54 x=259 y=92 width=29 height=38 xoffset=0 yoffset=2 xadvance=20 page=0 chnl=0 letter="6" -char id=55 x=378 y=132 width=27 height=37 xoffset=-0 yoffset=3 xadvance=17 page=0 chnl=0 letter="7" -char id=56 x=228 y=92 width=29 height=38 xoffset=0 yoffset=3 xadvance=21 page=0 chnl=0 letter="8" -char id=57 x=290 y=92 width=29 height=38 xoffset=-0 yoffset=2 xadvance=20 page=0 chnl=0 letter="9" -char id=58 x=456 y=171 width=18 height=30 xoffset=0 yoffset=11 xadvance=10 page=0 chnl=0 letter=":" -char id=59 x=480 y=132 width=18 height=37 xoffset=1 yoffset=10 xadvance=11 page=0 chnl=0 letter=";" -char id=60 x=2 y=208 width=26 height=27 xoffset=-0 yoffset=10 xadvance=17 page=0 chnl=0 letter="<" -char id=61 x=103 y=208 width=26 height=22 xoffset=1 yoffset=13 xadvance=19 page=0 chnl=0 letter="=" -char id=62 x=476 y=171 width=26 height=28 xoffset=0 yoffset=11 xadvance=18 page=0 chnl=0 letter=">" -char id=63 x=381 y=92 width=25 height=38 xoffset=-0 yoffset=2 xadvance=17 page=0 chnl=0 letter="?" -char id=64 x=17 y=2 width=44 height=46 xoffset=0 yoffset=3 xadvance=36 page=0 chnl=0 letter="@" -char id=65 x=427 y=92 width=35 height=37 xoffset=-0 yoffset=3 xadvance=26 page=0 chnl=0 letter="A" -char id=66 x=101 y=132 width=30 height=37 xoffset=1 yoffset=3 xadvance=23 page=0 chnl=0 letter="B" -char id=67 x=2 y=92 width=32 height=38 xoffset=0 yoffset=3 xadvance=23 page=0 chnl=0 letter="C" -char id=68 x=464 y=92 width=32 height=37 xoffset=1 yoffset=3 xadvance=25 page=0 chnl=0 letter="D" -char id=69 x=260 y=132 width=28 height=37 xoffset=1 yoffset=3 xadvance=21 page=0 chnl=0 letter="E" -char id=70 x=290 y=132 width=28 height=37 xoffset=1 yoffset=3 xadvance=21 page=0 chnl=0 letter="F" -char id=71 x=312 y=51 width=33 height=38 xoffset=0 yoffset=3 xadvance=25 page=0 chnl=0 letter="G" -char id=72 x=277 y=51 width=33 height=38 xoffset=1 yoffset=3 xadvance=27 page=0 chnl=0 letter="H" -char id=73 x=408 y=92 width=17 height=38 xoffset=1 yoffset=3 xadvance=11 page=0 chnl=0 letter="I" -char id=74 x=407 y=132 width=26 height=37 xoffset=-1 yoffset=3 xadvance=17 page=0 chnl=0 letter="J" -char id=75 x=36 y=92 width=32 height=38 xoffset=1 yoffset=3 xadvance=24 page=0 chnl=0 letter="K" -char id=76 x=320 y=132 width=27 height=37 xoffset=1 yoffset=3 xadvance=19 page=0 chnl=0 letter="L" -char id=77 x=85 y=51 width=41 height=38 xoffset=-0 yoffset=3 xadvance=32 page=0 chnl=0 letter="M" -char id=78 x=417 y=51 width=33 height=38 xoffset=1 yoffset=3 xadvance=27 page=0 chnl=0 letter="N" -char id=79 x=169 y=51 width=35 height=38 xoffset=0 yoffset=3 xadvance=27 page=0 chnl=0 letter="O" -char id=80 x=165 y=132 width=30 height=37 xoffset=1 yoffset=3 xadvance=23 page=0 chnl=0 letter="P" -char id=81 x=85 y=2 width=35 height=45 xoffset=0 yoffset=3 xadvance=27 page=0 chnl=0 letter="Q" -char id=82 x=2 y=132 width=31 height=37 xoffset=1 yoffset=4 xadvance=24 page=0 chnl=0 letter="R" -char id=83 x=197 y=132 width=30 height=37 xoffset=-0 yoffset=3 xadvance=21 page=0 chnl=0 letter="S" -char id=84 x=133 y=132 width=30 height=37 xoffset=-1 yoffset=3 xadvance=21 page=0 chnl=0 letter="T" -char id=85 x=452 y=51 width=32 height=38 xoffset=1 yoffset=3 xadvance=26 page=0 chnl=0 letter="U" -char id=86 x=206 y=51 width=34 height=38 xoffset=-1 yoffset=2 xadvance=24 page=0 chnl=0 letter="V" -char id=87 x=40 y=51 width=43 height=38 xoffset=-0 yoffset=3 xadvance=34 page=0 chnl=0 letter="W" -char id=88 x=382 y=51 width=33 height=38 xoffset=-1 yoffset=3 xadvance=23 page=0 chnl=0 letter="X" -char id=89 x=347 y=51 width=33 height=38 xoffset=-1 yoffset=3 xadvance=23 page=0 chnl=0 letter="Y" -char id=90 x=229 y=132 width=29 height=37 xoffset=0 yoffset=3 xadvance=21 page=0 chnl=0 letter="Z" -char id=91 x=200 y=2 width=21 height=43 xoffset=1 yoffset=3 xadvance=13 page=0 chnl=0 letter="[" -char id=92 x=387 y=2 width=25 height=40 xoffset=-0 yoffset=1 xadvance=16 page=0 chnl=0 letter="\" -char id=93 x=301 y=2 width=21 height=42 xoffset=-0 yoffset=3 xadvance=13 page=0 chnl=0 letter="]" -char id=94 x=75 y=208 width=26 height=23 xoffset=-0 yoffset=2 xadvance=17 page=0 chnl=0 letter="^" -char id=95 x=270 y=208 width=22 height=15 xoffset=1 yoffset=30 xadvance=15 page=0 chnl=0 letter="_" -char id=96 x=173 y=208 width=21 height=19 xoffset=1 yoffset=2 xadvance=14 page=0 chnl=0 letter="`" -char id=97 x=321 y=171 width=26 height=30 xoffset=-0 yoffset=10 xadvance=18 page=0 chnl=0 letter="a" -char id=98 x=324 y=2 width=30 height=40 xoffset=-0 yoffset=1 xadvance=21 page=0 chnl=0 letter="b" -char id=99 x=349 y=171 width=26 height=30 xoffset=-0 yoffset=11 xadvance=17 page=0 chnl=0 letter="c" -char id=100 x=414 y=2 width=30 height=39 xoffset=0 yoffset=2 xadvance=22 page=0 chnl=0 letter="d" -char id=101 x=292 y=171 width=27 height=30 xoffset=-0 yoffset=10 xadvance=18 page=0 chnl=0 letter="e" -char id=102 x=476 y=2 width=26 height=39 xoffset=-1 yoffset=2 xadvance=15 page=0 chnl=0 letter="f" -char id=103 x=102 y=92 width=30 height=38 xoffset=0 yoffset=10 xadvance=22 page=0 chnl=0 letter="g" -char id=104 x=446 y=2 width=28 height=39 xoffset=1 yoffset=1 xadvance=21 page=0 chnl=0 letter="h" -char id=105 x=2 y=51 width=17 height=39 xoffset=1 yoffset=1 xadvance=10 page=0 chnl=0 letter="i" -char id=106 x=63 y=2 width=20 height=46 xoffset=-2 yoffset=2 xadvance=10 page=0 chnl=0 letter="j" -char id=107 x=356 y=2 width=29 height=40 xoffset=0 yoffset=1 xadvance=20 page=0 chnl=0 letter="k" -char id=108 x=21 y=51 width=17 height=39 xoffset=1 yoffset=1 xadvance=9 page=0 chnl=0 letter="l" -char id=109 x=68 y=171 width=38 height=30 xoffset=1 yoffset=10 xadvance=31 page=0 chnl=0 letter="m" -char id=110 x=202 y=171 width=28 height=30 xoffset=1 yoffset=10 xadvance=21 page=0 chnl=0 letter="n" -char id=111 x=171 y=171 width=29 height=30 xoffset=-0 yoffset=10 xadvance=20 page=0 chnl=0 letter="o" -char id=112 x=70 y=92 width=30 height=38 xoffset=1 yoffset=10 xadvance=22 page=0 chnl=0 letter="p" -char id=113 x=197 y=92 width=29 height=38 xoffset=0 yoffset=11 xadvance=21 page=0 chnl=0 letter="q" -char id=114 x=431 y=171 width=23 height=30 xoffset=1 yoffset=10 xadvance=14 page=0 chnl=0 letter="r" -char id=115 x=377 y=171 width=25 height=30 xoffset=-0 yoffset=11 xadvance=16 page=0 chnl=0 letter="s" -char id=116 x=2 y=171 width=24 height=35 xoffset=-0 yoffset=6 xadvance=15 page=0 chnl=0 letter="t" -char id=117 x=262 y=171 width=28 height=30 xoffset=1 yoffset=11 xadvance=21 page=0 chnl=0 letter="u" -char id=118 x=108 y=171 width=30 height=30 xoffset=-0 yoffset=11 xadvance=20 page=0 chnl=0 letter="v" -char id=119 x=28 y=171 width=38 height=30 xoffset=-0 yoffset=11 xadvance=29 page=0 chnl=0 letter="w" -char id=120 x=140 y=171 width=29 height=30 xoffset=-1 yoffset=11 xadvance=19 page=0 chnl=0 letter="x" -char id=121 x=166 y=92 width=29 height=38 xoffset=-1 yoffset=10 xadvance=19 page=0 chnl=0 letter="y" -char id=122 x=404 y=171 width=25 height=30 xoffset=-0 yoffset=10 xadvance=16 page=0 chnl=0 letter="z" -char id=123 x=154 y=2 width=21 height=43 xoffset=-1 yoffset=3 xadvance=12 page=0 chnl=0 letter="{" -char id=124 x=2 y=2 width=13 height=47 xoffset=1 yoffset=1 xadvance=7 page=0 chnl=0 letter="|" -char id=125 x=177 y=2 width=21 height=43 xoffset=-0 yoffset=3 xadvance=12 page=0 chnl=0 letter="}" -char id=126 x=216 y=208 width=28 height=18 xoffset=0 yoffset=14 xadvance=20 page=0 chnl=0 letter="~" diff --git a/assets/mikado_outline_shadow.fnt.meta b/assets/mikado_outline_shadow.fnt.meta deleted file mode 100644 index c5adaba..0000000 --- a/assets/mikado_outline_shadow.fnt.meta +++ /dev/null @@ -1,7 +0,0 @@ -{ - "ver": "2.1.0", - "uuid": "fbb33c90-3a2b-4581-91c0-b45c9b89db30", - "textureUuid": "0f0d9bf9-c718-4ab0-bd20-f7a4bfe5909c", - "fontSize": 36, - "subMetas": {} -} \ No newline at end of file diff --git a/assets/mikado_outline_shadow.png b/assets/mikado_outline_shadow.png deleted file mode 100644 index 30f9d34aa4d1667df78380186a91d61c00ae13c5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 117347 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

I# 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 literal 0 HcmV?d00001 diff --git a/assets/textures/btn_play.png.meta b/assets/textures/bg.jpg.meta similarity index 59% rename from assets/textures/btn_play.png.meta rename to assets/textures/bg.jpg.meta index 6303be0..a8b282c 100644 --- a/assets/textures/btn_play.png.meta +++ b/assets/textures/bg.jpg.meta @@ -1,14 +1,14 @@ { "ver": "1.0.0", - "uuid": "07d60076-0f0c-46be-a3da-aa9fe87d604b", + "uuid": "f7dcd8c8-82c1-462a-b505-3b5dcbb7df5a", "type": "sprite", "wrapMode": "clamp", "filterMode": "bilinear", "subMetas": { - "btn_play": { + "bg": { "ver": "1.0.3", - "uuid": "64f414e2-338c-4fd1-87ba-6431b5daa8ca", - "rawTextureUuid": "07d60076-0f0c-46be-a3da-aa9fe87d604b", + "uuid": "0cbd03ff-a827-4248-a85b-6bfd7ebfcabd", + "rawTextureUuid": "f7dcd8c8-82c1-462a-b505-3b5dcbb7df5a", "trimType": "auto", "trimThreshold": 1, "rotated": false, @@ -16,10 +16,10 @@ "offsetY": 0, "trimX": 0, "trimY": 0, - "width": 195, - "height": 57, - "rawWidth": 195, - "rawHeight": 57, + "width": 1280, + "height": 258, + "rawWidth": 1280, + "rawHeight": 258, "borderTop": 0, "borderBottom": 0, "borderLeft": 0, diff --git a/assets/textures/btn_bg.png b/assets/textures/btn_bg.png new file mode 100644 index 0000000000000000000000000000000000000000..90a92d618364424470978788064a696f51e70730 GIT binary patch literal 107 zcmeAS@N?(olHy`uVBq!ia0vp^CxFEakt!I-STe&hdfzJEMMGXoJ&(ujd!g_z~yRO#0lK(!2>u6{1-oD!M|JV2UeZTMf*4q051J)br zTk4}wC_{fgCL5V=A}e z8CruvY3~sPhrwa24RoGZh~v!3;AFx?L>q-#<0VVv@ZupD!-Zl5A`k3%Z9Ntv;Co<0 zDJ%jjkpaaD{8A-QP-;LhFEyS=<72%%F>7RW#DEZjIT)ERK_sQiJg}ea(vkJtF&>Ng zBm&2KU_XNjV+CRuVhMzy;3xo(Km;*V8V;mTs8pg0hDZR(cmjwANdQQrlgV@f0rTa- zBHkqYXgZte`^6Ws^T5W!a3UR#Pfkw8C6jPsNemvO(P(%A5lJ%1GS$Zy z1bryp6cWLgL}j{CsU!xOL7La~7fE4`hzHI479hUA=u-bum(Gwt99S#~7K;<+s~|8| z42z|);zSIC@hR&VhfsltFHV*^&ZX&d)J#Ys*a`7{C1N4w6VG(PH!#r191b5O69F=b zN&pBvvKzo5g9sfYK8;ENd6Z}li2b6^{}X?o>l8Ub;z*o_Lyx9XAr6(y1;|tg0zeR= z09+c;4WX0*(V_`to~xTH7LP#0&y~)fN@@NGsn5CP*Tz6LUt0?jA^jvl8Ye|j>w!Y) z6!|l~gJlm!PDUh{Y&N-FSq(&J&gl$m_V#GjvCf&s>RGBmODiVBgyI>+J)7@&+&pq7 z^|f~{XlJK<|2*rK<>Bm?sH*#!m<7k^+Sh+?9;(H)hBjby_fs%&?f9aWBck}TTRdfW!mb+#*J@RaI^2r z`f_Y=@3O+&XMJ)qc9MP@5`h@XhnBRAgIJ8{mZA}-G;4D0q?VuuVsF*kC?PJs%f3XF zqDRj#Cn&bE(hp*FU)8VT%2ah2rZCgIw`<9spOTCjt7g}#%CpSFw%9S@z;)Kf62qKK z5lla;Cp72X{)xD(jM!s+018^k&=3~!gF^2iQ^Vm#-*3Qko{mZ#eXY1RIcC9I{C%Qo3kJ@|IViqA6)-xv zu%onJI(*dch+47!ts<^%idv;xiVL)kl|^no*0*AO$Fnu{; zUy@$$DBf^nIYD+QdYRVR!qRdhh8ysM6}+-at0m5?``-IZdyQ%TyZE2OHTNf1%H;`_ zWhsr9fdf~@tJH@VA9Yk3V^qEPCr%5}<&l;9?W>K@#@BA`iVd&XLSc@*9=UyO@Oa^? z7v5=SOc;suiRtc)n-|;eD<9auc~_9vA=i@I*W1g)gW+v;tq+7&ubz*+-8LNcyPJxq zd-iab?eO%WNv$_2&cO9$ROB#W|INX^! z=Td!gi<3{^!d9(_lXTIB0!^@3Qo8BVM(R_W5sP(MWzGK>D$cG^R%m_?$b-w4wk{s* z>>fxNwVk{4c94u;bj+^RpfX<^-LY+oBv3VAmka&~D&oFR*U8viBD;Y#)!Sd8$;gC5 zXREffMOa)5(!Dnm;Gq2I@bapPITi;jR7zD)!liA459MnB2@;-%dnRDf>@4cJ778ueKJ7-De^T0}c9g(){u* zR%g&=hxS!U>U2Z$1|KDyHVnzzI(S{Ocvo7*q+rHs`mUbP{equQ(}32)spCeGcOLyx zn|}KVtc@^)K4boWqj|HzGUUQZ8{Af6jox$&qa;me+YCE2Ud&I!Fh}>A*EF#wbR4HV_;u!r8>cd6Gsc!IXop5jm=&G{p9|405l0nCbZQM>;OP2KuL diff --git a/assets/textures/icon_arrow_left.png b/assets/textures/icon_arrow_left.png new file mode 100644 index 0000000000000000000000000000000000000000..72b55bb0a9bc17f2885ad500570c4078e4e3542e GIT binary patch literal 314 zcmV-A0mc4_P)OWs@leYG-6e6Z`ClVxJvR?6V__eRgayvQz7m#XdW#7}yEf z(ZoJGqS$B079+d#HiVdtP3sY>UFsIc|EUYv-$(K0gbT#x#0vzI3ipvnY)O11{4`1u z+nPNH6rwhXb=dQn#5mCVOk)3OLnZ_4n)Z5!D>+qSKAm+rzLO`JGs;-pCv&bHUKooic;pYYXJn`?WY`enTFj}gON zCX*S71K5v|BUHIDVOR&$gF^7_SB?q77r{u?m;iiHj8ctx244(gRAU~&_X1;8V;;cw z7UNZ8?!osN6I5evAPwsWCaK0;LJHPjOjV6JgCwk6OjnILh6Jo4%uoQgp*=#Y*Kh;ud_@)R(Mz=z`UYo$68R(GII0 z`_!XWqZ!s9j;Kd1M?I_rPN_#NK{c!-E~rN>Ksl@wuB%7QMKP>2?y5)4LLPkg)uX24 zAAAqhqo(2qd{5M)CgU@F0rjYfcn4olJ!(8&z!$aLotrWvjp?3oIA!RaoKK>Z`^-BO3Gcgh?F_R3#PNhI^{k5e0bT1bpAYy9GO5Y*ThZ?ZO?x@4E)OWo*pUmK7HVqU!b|!&DVe1HrTi^9{9HB zuMCS`G(N>Mya>EBV@7q4+q*a1xdXRuLC>D?3_Etr?_3DH2go_NxquZbptUvFu3baY z@6dLWCY65f&p$_E(V}>U9WgcX3M5Bnh;bIZ?AU?Cy?b!|dg=D?AriA@m45Egqal|A z&xUN(ysODt5$_Opr=pa(xulE zycioj5cvCm`*QDRpCPGNvvsR_b|JIzdUJDdoA=-MAAiIMm^d-mZr)S|8`eh0a9=() zx*y$8bNo0GLx&o0w{Kg^WRUE(BDQz0|M;Fq#rppHNQateoNIHlhLOViu3m*lk19L< z(xuSY7;Fz7=p5l~mM@Rgxz`0n_Q8Wqyq?J@lnXz`*s=B-6A5_t zWnuRdA)0cN>gwz^rTwWC5}$rr{224+BdJ2^+ouOOYE&_^as2;jJ7kFSi4gZwe=6BN zeryx8En7^Il+VK#UuZh6u)|%n$b^WSHYpkkE;p$5Q*C|wt<$ML_mkay`WR??_SkKQ z4#EBVg6eM{26NZ0!fo|n4jibiZQbgAvfKIc4mrjVBLe;pFn!(U%~J_jHFDKBUhm}{ z$$}>L3!0K8eDN>gOBSuhzi2gCrXBw>?c~LTxL!;Me-)=2P@BApL#p0n@BEc0}645?szdposB+K{IqkT*jiLw)wW|I1R_=5M_H zt~&h(o9bdCy+9IHG=fm#WG3wcdNSzu}C1BhM8hY!#{8rn_)*ZinH**@nwn z@|MjI-ZfKs;bIQ~1tu0oB?p4kKXaA}i+Sg!pZ-~5qq3IsL)5GAr?a-G9Jsyr--9~u zS%MF|SK4dpdnz;Snfj}{$orPSgT4Qb*=9O5T>lk)eF-b$v|rJxnGOy8zu4QK{A8(E zQ(xdS&%a^$FZSgi?z;K{KOlGdFZSszeT@4&KX4p#=lH?fEPwHV2H#pB0@HTaFVcm8~Jt-$RE`HL?Strk&eeme<*Kglq(=$(< zJNN(pe+w74RqHqW`}fbuFW~gK^FROn-~Zvq{1;!o{QXz+-~->$NBl=0J^JxS=gc$R zGtYwK625%>I^&+C0?+{hB|(0{4BGuyKmTW&@^|k)pke?2ef})i#lXP$-_yl0q=ND7 zZC0k+20RXd>>_=qdQba&-~S*;=5reVKkLK%QAXj85=WUVMBEb--c2$QKCn~AH}CJ$ zpedni`4~$>#U{mb`z*a2dSGXsdr)%Ing#Y17j-usXbIAK;HtT>b4k#FZZ9Qa@3jr$ zTaUQ8F#5Z22(WN4v4BVc1t4+&q6Q#haBN^;Y+_(!VgVv#1qbRm7{C2$ewbk*^QD?= z2VcRR8`IO)G@NEozdW<{c#c)zfyjo>t$z(=Jh-qe?9;rdxx8P$Gc)$(Wb3|bP0l+XkK$#gP< literal 0 HcmV?d00001 diff --git a/assets/textures/redio_on.png.meta b/assets/textures/redio_on.png.meta new file mode 100644 index 0000000..14797ac --- /dev/null +++ b/assets/textures/redio_on.png.meta @@ -0,0 +1,30 @@ +{ + "ver": "1.0.0", + "uuid": "d0240485-9995-4376-b481-53aac186d34e", + "type": "sprite", + "wrapMode": "clamp", + "filterMode": "bilinear", + "subMetas": { + "redio_on": { + "ver": "1.0.3", + "uuid": "84faf979-6331-42a5-b2f0-b880f65cfa78", + "rawTextureUuid": "d0240485-9995-4376-b481-53aac186d34e", + "trimType": "auto", + "trimThreshold": 1, + "rotated": false, + "offsetX": 0, + "offsetY": 0, + "trimX": 0, + "trimY": 0, + "width": 640, + "height": 92, + "rawWidth": 640, + "rawHeight": 92, + "borderTop": 0, + "borderBottom": 0, + "borderLeft": 0, + "borderRight": 0, + "subMetas": {} + } + } +} \ No newline at end of file diff --git a/creator.d.ts b/creator.d.ts new file mode 100644 index 0000000..25e9b70 --- /dev/null +++ b/creator.d.ts @@ -0,0 +1,20485 @@ + +/** !#en +The main namespace of Cocos2d-JS, all engine core classes, functions, properties and constants are defined in this namespace. +!#zh +Cocos 引擎的主要命名空间,引擎代码中所有的类,函数,属性和常量都在这个命名空间中定义。 */ +declare module cc { + /** The current version of Cocos2d being used.
+ Please DO NOT remove this String, it is an important flag for bug tracking.
+ If you post a bug to forum, please attach this flag. */ + export var ENGINE_VERSION: string; + /** The element contains the game canvas */ + export var container: HTMLDivElement; + /** + !#en Init Debug setting. + !#zh 设置调试模式。 + @param mode mode + */ + export function _initDebugSetting(mode: DebugMode): void; + /** + !#en + Outputs an error message to the Cocos Creator Console (editor) or Web Console (runtime).
+ - In Cocos Creator, error is red.
+ - In Chrome, error have a red icon along with red message text.
+ !#zh + 输出错误消息到 Cocos Creator 编辑器的 Console 或运行时页面端的 Console 中。
+ - 在 Cocos Creator 中,错误信息显示是红色的。
+ - 在 Chrome 中,错误信息有红色的图标以及红色的消息文本。
+ @param msg A JavaScript string containing zero or more substitution strings. + @param subst JavaScript objects with which to replace substitution strings within msg. This gives you additional control over the format of the output. + */ + export function error(msg: any, ...subst: any[]): void; + /** + !#en + Outputs a warning message to the Cocos Creator Console (editor) or Web Console (runtime). + - In Cocos Creator, warning is yellow. + - In Chrome, warning have a yellow warning icon with the message text. + !#zh + 输出警告消息到 Cocos Creator 编辑器的 Console 或运行时 Web 端的 Console 中。
+ - 在 Cocos Creator 中,警告信息显示是黄色的。
+ - 在 Chrome 中,警告信息有着黄色的图标以及黄色的消息文本。
+ @param msg A JavaScript string containing zero or more substitution strings. + @param subst JavaScript objects with which to replace substitution strings within msg. This gives you additional control over the format of the output. + */ + export function warn(msg: any, ...subst: any[]): void; + /** + !#en Outputs a message to the Cocos Creator Console (editor) or Web Console (runtime). + !#zh 输出一条消息到 Cocos Creator 编辑器的 Console 或运行时 Web 端的 Console 中。 + @param msg A JavaScript string containing zero or more substitution strings. + @param subst JavaScript objects with which to replace substitution strings within msg. This gives you additional control over the format of the output. + */ + export function log(msg: string|any, ...subst: any[]): void; + /** + !#en + Outputs an informational message to the Cocos Creator Console (editor) or Web Console (runtime). + - In Cocos Creator, info is blue. + - In Firefox and Chrome, a small "i" icon is displayed next to these items in the Web Console's log. + !#zh + 输出一条信息消息到 Cocos Creator 编辑器的 Console 或运行时 Web 端的 Console 中。 + - 在 Cocos Creator 中,Info 信息显示是蓝色的。
+ - 在 Firefox 和 Chrome 中,Info 信息有着小 “i” 图标。 + @param msg A JavaScript string containing zero or more substitution strings. + @param subst JavaScript objects with which to replace substitution strings within msg. This gives you additional control over the format of the output. + */ + export function info(msg: any, ...subst: any[]): void; + /** + !#en + Creates the speed action which changes the speed of an action, making it take longer (speed > 1) + or less (speed < 1) time.
+ Useful to simulate 'slow motion' or 'fast forward' effect. + !#zh 修改目标动作的速率。 + @param action action + @param speed speed + + @example + ```js + // change the target action speed; + var action = cc.scaleTo(0.2, 1, 0.6); + var newAction = cc.speed(action, 0.5); + ``` + */ + export function speed(action: ActionInterval, speed: number): Action; + /** + !#en Create a follow action which makes its target follows another node. + !#zh 追踪目标节点的位置。 + @param followedNode followedNode + @param rect rect + + @example + ```js + // example + // creates the action with a set boundary + var followAction = cc.follow(targetNode, cc.rect(0, 0, screenWidth * 2 - 100, screenHeight)); + node.runAction(followAction); + + // creates the action with no boundary set + var followAction = cc.follow(targetNode); + node.runAction(followAction); + ``` + */ + export function follow(followedNode: Node, rect: Rect): Action; + /** + Points setter + @param points points + */ + export function setPoints(points: any[]): void; + /** + !#en Creates an action with a Cardinal Spline array of points and tension. + !#zh 按基数样条曲线轨迹移动到目标位置。 + @param duration duration + @param points array of control points + @param tension tension + + @example + ```js + //create a cc.CardinalSplineTo + var action1 = cc.cardinalSplineTo(3, array, 0); + ``` + */ + export function cardinalSplineTo(duration: number, points: any[], tension: number): ActionInterval; + /** + update position of target + @param newPos newPos + */ + export function updatePosition(newPos: Vec2): void; + /** + !#en Creates an action with a Cardinal Spline array of points and tension. + !#zh 按基数样条曲线轨迹移动指定的距离。 + @param duration duration + @param points points + @param tension tension + */ + export function cardinalSplineBy(duration: number, points: any[], tension: number): ActionInterval; + /** + !#en Creates an action with a Cardinal Spline array of points and tension. + !#zh 按 Catmull Rom 样条曲线轨迹移动到目标位置。 + @param dt dt + @param points points + + @example + ```js + var action1 = cc.catmullRomTo(3, array); + ``` + */ + export function catmullRomTo(dt: number, points: any[]): ActionInterval; + /** + !#en Creates an action with a Cardinal Spline array of points and tension. + !#zh 按 Catmull Rom 样条曲线轨迹移动指定的距离。 + @param dt dt + @param points points + + @example + ```js + var action1 = cc.catmullRomBy(3, array); + ``` + */ + export function catmullRomBy(dt: number, points: any[]): ActionInterval; + /** + !#en + Creates the action easing object with the rate parameter.
+ From slow to fast. + !#zh 创建 easeIn 缓动对象,由慢到快。 + @param rate rate + + @example + ```js + action.easing(cc.easeIn(3.0)); + ``` + */ + export function easeIn(rate: number): any; + /** + !#en + Creates the action easing object with the rate parameter.
+ From fast to slow. + !#zh 创建 easeOut 缓动对象,由快到慢。 + @param rate rate + + @example + ```js + action.easing(cc.easeOut(3.0)); + ``` + */ + export function easeOut(rate: number): any; + /** + !#en + Creates the action easing object with the rate parameter.
+ Slow to fast then to slow. + !#zh 创建 easeInOut 缓动对象,慢到快,然后慢。 + @param rate rate + + @example + ```js + action.easing(cc.easeInOut(3.0)); + ``` + */ + export function easeInOut(rate: number): any; + /** + !#en + Creates the action easing object with the rate parameter.
+ Reference easeInExpo:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeExponentialIn 缓动对象。
+ EaseExponentialIn 是按指数函数缓动进入的动作。
+ 参考 easeInExpo:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + action.easing(cc.easeExponentialIn()); + ``` + */ + export function easeExponentialIn(): any; + /** + !#en + Creates the action easing object.
+ Reference easeOutExpo:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeExponentialOut 缓动对象。
+ EaseExponentialOut 是按指数函数缓动退出的动作。
+ 参考 easeOutExpo:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + action.easing(cc.easeExponentialOut()); + ``` + */ + export function easeExponentialOut(): any; + /** + !#en + Creates an EaseExponentialInOut action easing object.
+ Reference easeInOutExpo:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeExponentialInOut 缓动对象。
+ EaseExponentialInOut 是按指数函数缓动进入并退出的动作。
+ 参考 easeInOutExpo:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + action.easing(cc.easeExponentialInOut()); + ``` + */ + export function easeExponentialInOut(): any; + /** + !#en + Creates an EaseSineIn action.
+ Reference easeInSine:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 EaseSineIn 缓动对象。
+ EaseSineIn 是按正弦函数缓动进入的动作。
+ 参考 easeInSine:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + action.easing(cc.easeSineIn()); + ``` + */ + export function easeSineIn(): any; + /** + !#en + Creates an EaseSineOut action easing object.
+ Reference easeOutSine:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 EaseSineOut 缓动对象。
+ EaseSineIn 是按正弦函数缓动退出的动作。
+ 参考 easeOutSine:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + action.easing(cc.easeSineOut()); + ``` + */ + export function easeSineOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeInOutSine:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeSineInOut 缓动对象。
+ EaseSineIn 是按正弦函数缓动进入并退出的动作。
+ 参考 easeInOutSine:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + action.easing(cc.easeSineInOut()); + ``` + */ + export function easeSineInOut(): any; + /** + !#en + Creates the action easing obejct with the period in radians (default is 0.3).
+ Reference easeInElastic:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeElasticIn 缓动对象。
+ EaseElasticIn 是按弹性曲线缓动进入的动作。
+ 参数 easeInElastic:http://www.zhihu.com/question/21981571/answer/19925418 + @param period period + + @example + ```js + // example + action.easing(cc.easeElasticIn(3.0)); + ``` + */ + export function easeElasticIn(period: number): any; + /** + !#en + Creates the action easing object with the period in radians (default is 0.3).
+ Reference easeOutElastic:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeElasticOut 缓动对象。
+ EaseElasticOut 是按弹性曲线缓动退出的动作。
+ 参考 easeOutElastic:http://www.zhihu.com/question/21981571/answer/19925418 + @param period period + + @example + ```js + // example + action.easing(cc.easeElasticOut(3.0)); + ``` + */ + export function easeElasticOut(period: number): any; + /** + !#en + Creates the action easing object with the period in radians (default is 0.3).
+ Reference easeInOutElastic:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeElasticInOut 缓动对象。
+ EaseElasticInOut 是按弹性曲线缓动进入并退出的动作。
+ 参考 easeInOutElastic:http://www.zhihu.com/question/21981571/answer/19925418 + @param period period + + @example + ```js + // example + action.easing(cc.easeElasticInOut(3.0)); + ``` + */ + export function easeElasticInOut(period: number): any; + /** + !#en + Creates the action easing object.
+ Eased bounce effect at the beginning. + !#zh + 创建 easeBounceIn 缓动对象。
+ EaseBounceIn 是按弹跳动作缓动进入的动作。 + + @example + ```js + // example + action.easing(cc.easeBounceIn()); + ``` + */ + export function easeBounceIn(): any; + /** + !#en + Creates the action easing object.
+ Eased bounce effect at the ending. + !#zh + 创建 easeBounceOut 缓动对象。
+ EaseBounceOut 是按弹跳动作缓动退出的动作。 + + @example + ```js + // example + action.easing(cc.easeBounceOut()); + ``` + */ + export function easeBounceOut(): any; + /** + !#en + Creates the action easing object.
+ Eased bounce effect at the begining and ending. + !#zh + 创建 easeBounceInOut 缓动对象。
+ EaseBounceInOut 是按弹跳动作缓动进入并退出的动作。 + + @example + ```js + // example + action.easing(cc.easeBounceInOut()); + ``` + */ + export function easeBounceInOut(): any; + /** + !#en + Creates the action easing object.
+ In the opposite direction to move slowly, and then accelerated to the right direction. + !#zh + 创建 easeBackIn 缓动对象。
+ easeBackIn 是在相反的方向缓慢移动,然后加速到正确的方向。
+ + @example + ```js + // example + action.easing(cc.easeBackIn()); + ``` + */ + export function easeBackIn(): any; + /** + !#en + Creates the action easing object.
+ Fast moving more than the finish, and then slowly back to the finish. + !#zh + 创建 easeBackOut 缓动对象。
+ easeBackOut 快速移动超出目标,然后慢慢回到目标点。 + + @example + ```js + // example + action.easing(cc.easeBackOut()); + ``` + */ + export function easeBackOut(): any; + /** + !#en + Creates the action easing object.
+ Begining of cc.EaseBackIn. Ending of cc.EaseBackOut. + !#zh + 创建 easeBackInOut 缓动对象。
+ + @example + ```js + // example + action.easing(cc.easeBackInOut()); + ``` + */ + export function easeBackInOut(): any; + /** + !#en + Creates the action easing object.
+ Into the 4 reference point.
+ To calculate the motion curve. + !#zh + 创建 easeBezierAction 缓动对象。
+ EaseBezierAction 是按贝塞尔曲线缓动的动作。 + @param p0 The first bezier parameter + @param p1 The second bezier parameter + @param p2 The third bezier parameter + @param p3 The fourth bezier parameter + + @example + ```js + // example + action.easing(cc.easeBezierAction(0.5, 0.5, 1.0, 1.0)); + ``` + */ + export function easeBezierAction(p0: number, p1: number, p2: number, p3: number): any; + /** + !#en + Creates the action easing object.
+ Reference easeInQuad:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeQuadraticActionIn 缓动对象。
+ EaseQuadraticIn是按二次函数缓动进入的动作。
+ 参考 easeInQuad:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeQuadraticActionIn()); + ``` + */ + export function easeQuadraticActionIn(): any; + /** + !#en + Creates the action easing object.
+ Reference easeOutQuad:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeQuadraticActionOut 缓动对象。
+ EaseQuadraticOut 是按二次函数缓动退出的动作。
+ 参考 easeOutQuad:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeQuadraticActionOut()); + ``` + */ + export function easeQuadraticActionOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeInOutQuad:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeQuadraticActionInOut 缓动对象。
+ EaseQuadraticInOut 是按二次函数缓动进入并退出的动作。
+ 参考 easeInOutQuad:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeQuadraticActionInOut()); + ``` + */ + export function easeQuadraticActionInOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeIntQuart:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeQuarticActionIn 缓动对象。
+ EaseQuarticIn 是按四次函数缓动进入的动作。
+ 参考 easeIntQuart:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeQuarticActionIn()); + ``` + */ + export function easeQuarticActionIn(): any; + /** + !#en + Creates the action easing object.
+ Reference easeOutQuart:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeQuarticActionOut 缓动对象。
+ EaseQuarticOut 是按四次函数缓动退出的动作。
+ 参考 easeOutQuart:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.QuarticActionOut()); + ``` + */ + export function easeQuarticActionOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeInOutQuart:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeQuarticActionInOut 缓动对象。
+ EaseQuarticInOut 是按四次函数缓动进入并退出的动作。
+ 参考 easeInOutQuart:http://www.zhihu.com/question/21981571/answer/19925418 + */ + export function easeQuarticActionInOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeInQuint:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeQuinticActionIn 缓动对象。
+ EaseQuinticIn 是按五次函数缓动进的动作。
+ 参考 easeInQuint:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeQuinticActionIn()); + ``` + */ + export function easeQuinticActionIn(): any; + /** + !#en + Creates the action easing object.
+ Reference easeOutQuint:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeQuinticActionOut 缓动对象。
+ EaseQuinticOut 是按五次函数缓动退出的动作 + 参考 easeOutQuint:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeQuadraticActionOut()); + ``` + */ + export function easeQuinticActionOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeInOutQuint:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeQuinticActionInOut 缓动对象。
+ EaseQuinticInOut是按五次函数缓动进入并退出的动作。
+ 参考 easeInOutQuint:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeQuinticActionInOut()); + ``` + */ + export function easeQuinticActionInOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeInCirc:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeCircleActionIn 缓动对象。
+ EaseCircleIn是按圆形曲线缓动进入的动作。
+ 参考 easeInCirc:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeCircleActionIn()); + ``` + */ + export function easeCircleActionIn(): any; + /** + !#en + Creates the action easing object.
+ Reference easeOutCirc:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeCircleActionOut 缓动对象。
+ EaseCircleOut是按圆形曲线缓动退出的动作。
+ 参考 easeOutCirc:http://www.zhihu.com/question/21981571/answer/19925418 + */ + export function easeCircleActionOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeInOutCirc:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeCircleActionInOut 缓动对象。
+ EaseCircleInOut 是按圆形曲线缓动进入并退出的动作。
+ 参考 easeInOutCirc:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeCircleActionInOut()); + ``` + */ + export function easeCircleActionInOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeInCubic:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeCubicActionIn 缓动对象。
+ EaseCubicIn 是按三次函数缓动进入的动作。
+ 参考 easeInCubic:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeCubicActionIn()); + ``` + */ + export function easeCubicActionIn(): any; + /** + !#en + Creates the action easing object.
+ Reference easeOutCubic:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeCubicActionOut 缓动对象。
+ EaseCubicOut 是按三次函数缓动退出的动作。
+ 参考 easeOutCubic:http://www.zhihu.com/question/21981571/answer/19925418 + + @example + ```js + //example + action.easing(cc.easeCubicActionOut()); + ``` + */ + export function easeCubicActionOut(): any; + /** + !#en + Creates the action easing object.
+ Reference easeInOutCubic:
+ http://www.zhihu.com/question/21981571/answer/19925418 + !#zh + 创建 easeCubicActionInOut 缓动对象。
+ EaseCubicInOut是按三次函数缓动进入并退出的动作。
+ 参考 easeInOutCubic:http://www.zhihu.com/question/21981571/answer/19925418 + */ + export function easeCubicActionInOut(): any; + /** + !#en Show the Node. + !#zh 立即显示。 + + @example + ```js + // example + var showAction = cc.show(); + ``` + */ + export function show(): ActionInstant; + /** + !#en Hide the node. + !#zh 立即隐藏。 + + @example + ```js + // example + var hideAction = cc.hide(); + ``` + */ + export function hide(): ActionInstant; + /** + !#en Toggles the visibility of a node. + !#zh 显隐状态切换。 + + @example + ```js + // example + var toggleVisibilityAction = cc.toggleVisibility(); + ``` + */ + export function toggleVisibility(): ActionInstant; + /** + !#en Create a RemoveSelf object with a flag indicate whether the target should be cleaned up while removing. + !#zh 从父节点移除自身。 + @param isNeedCleanUp isNeedCleanUp + + @example + ```js + // example + var removeSelfAction = cc.removeSelf(); + ``` + */ + export function removeSelf(isNeedCleanUp ?: boolean): ActionInstant; + /** + !#en Create a FlipX action to flip or unflip the target. + !#zh X轴翻转。 + @param flip Indicate whether the target should be flipped or not + + @example + ```js + var flipXAction = cc.flipX(true); + ``` + */ + export function flipX(flip: boolean): ActionInstant; + /** + !#en Create a FlipY action to flip or unflip the target. + !#zh Y轴翻转。 + @param flip flip + + @example + ```js + var flipYAction = cc.flipY(true); + ``` + */ + export function flipY(flip: boolean): ActionInstant; + /** + !#en Creates a Place action with a position. + !#zh 放置在目标位置。 + @param pos pos + @param y y + + @example + ```js + // example + var placeAction = cc.place(cc.p(200, 200)); + var placeAction = cc.place(200, 200); + ``` + */ + export function place(pos: Vec2|number, y?: number): ActionInstant; + /** + !#en Creates the action with the callback. + !#zh 执行回调函数。 + @param selector selector + @param selectorTarget selectorTarget + @param data data for function, it accepts all data types. + + @example + ```js + // example + // CallFunc without data + var finish = cc.callFunc(this.removeSprite, this); + + // CallFunc with data + var finish = cc.callFunc(this.removeFromParentAndCleanup, this._grossini, true); + ``` + */ + export function callFunc(selector: Function, selectorTarget?: any, data?: any): ActionInstant; + /** + !#en + Helper constructor to create an array of sequenceable actions + The created action will run actions sequentially, one after another. + !#zh 顺序执行动作,创建的动作将按顺序依次运行。 + @param actionOrActionArray actionOrActionArray + @param tempArray tempArray + + @example + ```js + // example + // create sequence with actions + var seq = cc.sequence(act1, act2); + + // create sequence with array + var seq = cc.sequence(actArray); + ``` + */ + export function sequence(actionOrActionArray: FiniteTimeAction|FiniteTimeAction[], ...tempArray: FiniteTimeAction[]): ActionInterval; + /** + !#en Creates a Repeat action. Times is an unsigned integer between 1 and pow(2,30) + !#zh 重复动作,可以按一定次数重复一个动,如果想永远重复一个动作请使用 repeatForever 动作来完成。 + @param action action + @param times times + + @example + ```js + // example + var rep = cc.repeat(cc.sequence(jump2, jump1), 5); + ``` + */ + export function repeat(action: FiniteTimeAction, times: number): ActionInterval; + /** + !#en Create a acton which repeat forever, as it runs forever, it can't be added into cc.sequence and cc.spawn. + !#zh 永远地重复一个动作,有限次数内重复一个动作请使用 repeat 动作,由于这个动作不会停止,所以不能被添加到 cc.sequence 或 cc.spawn 中。 + @param action action + + @example + ```js + // example + var repeat = cc.repeatForever(cc.rotateBy(1.0, 360)); + ``` + */ + export function repeatForever(action: FiniteTimeAction): ActionInterval; + /** + !#en Create a spawn action which runs several actions in parallel. + !#zh 同步执行动作,同步执行一组动作。 + @param actionOrActionArray actionOrActionArray + @param tempArray tempArray + + @example + ```js + // example + var action = cc.spawn(cc.jumpBy(2, cc.p(300, 0), 50, 4), cc.rotateBy(2, 720)); + todo:It should be the direct use new + ``` + */ + export function spawn(actionOrActionArray: FiniteTimeAction|FiniteTimeAction[], ...tempArray: FiniteTimeAction[]): FiniteTimeAction; + /** + !#en + Rotates a Node object to a certain angle by modifying its rotation property.
+ The direction will be decided by the shortest angle. + !#zh 旋转到目标角度,通过逐帧修改它的 rotation 属性,旋转方向将由最短的角度决定。 + @param duration duration in seconds + @param deltaAngleX deltaAngleX in degrees. + @param deltaAngleY deltaAngleY in degrees. + + @example + ```js + // example + var rotateTo = cc.rotateTo(2, 61.0); + ``` + */ + export function rotateTo(duration: number, deltaAngleX: number, deltaAngleY?: number): ActionInterval; + /** + !#en + Rotates a Node object clockwise a number of degrees by modifying its rotation property. + Relative to its properties to modify. + !#zh 旋转指定的角度。 + @param duration duration in seconds + @param deltaAngleX deltaAngleX in degrees + @param deltaAngleY deltaAngleY in degrees + + @example + ```js + // example + var actionBy = cc.rotateBy(2, 360); + ``` + */ + export function rotateBy(duration: number, deltaAngleX: number, deltaAngleY?: number): ActionInterval; + /** + !#en + Moves a Node object x,y pixels by modifying its position property.
+ x and y are relative to the position of the object.
+ Several MoveBy actions can be concurrently called, and the resulting
+ movement will be the sum of individual movements. + !#zh 移动指定的距离。 + @param duration duration in seconds + @param deltaPos deltaPos + @param deltaY deltaY + + @example + ```js + // example + var actionTo = cc.moveBy(2, cc.p(windowSize.width - 40, windowSize.height - 40)); + ``` + */ + export function moveBy(duration: number, deltaPos: Vec2|number, deltaY?: number): ActionInterval; + /** + !#en + Moves a Node object to the position x,y. x and y are absolute coordinates by modifying its position property.
+ Several MoveTo actions can be concurrently called, and the resulting
+ movement will be the sum of individual movements. + !#zh 移动到目标位置。 + @param duration duration in seconds + @param position position + @param y y + + @example + ```js + // example + var actionBy = cc.moveTo(2, cc.p(80, 80)); + ``` + */ + export function moveTo(duration: number, position: Vec2|number, y?: number): ActionInterval; + /** + !#en + Create a action which skews a Node object to given angles by modifying its skewX and skewY properties. + Changes to the specified value. + !#zh 偏斜到目标角度。 + @param t time in seconds + @param sx sx + @param sy sy + + @example + ```js + // example + var actionTo = cc.skewTo(2, 37.2, -37.2); + ``` + */ + export function skewTo(t: number, sx: number, sy: number): ActionInterval; + /** + !#en + Skews a Node object by skewX and skewY degrees.
+ Relative to its property modification. + !#zh 偏斜指定的角度。 + @param t time in seconds + @param sx sx skew in degrees for X axis + @param sy sy skew in degrees for Y axis + + @example + ```js + // example + var actionBy = cc.skewBy(2, 0, -90); + ``` + */ + export function skewBy(t: number, sx: number, sy: number): ActionInterval; + /** + !#en + Moves a Node object simulating a parabolic jump movement by modifying it's position property. + Relative to its movement. + !#zh 用跳跃的方式移动指定的距离。 + @param duration duration + @param position position + @param y y + @param height height + @param jumps jumps + + @example + ```js + // example + var actionBy = cc.jumpBy(2, cc.p(300, 0), 50, 4); + var actionBy = cc.jumpBy(2, 300, 0, 50, 4); + ``` + */ + export function jumpBy(duration: number, position: Vec2|number, y?: number, height?: number, jumps?: number): ActionInterval; + /** + !#en + Moves a Node object to a parabolic position simulating a jump movement by modifying its position property.
+ Jump to the specified location. + !#zh 用跳跃的方式移动到目标位置。 + @param duration duration + @param position position + @param y y + @param height height + @param jumps jumps + + @example + ```js + // example + var actionTo = cc.jumpTo(2, cc.p(300, 300), 50, 4); + var actionTo = cc.jumpTo(2, 300, 300, 50, 4); + ``` + */ + export function jumpTo(duration: number, position: Vec2|number, y?: number, height?: number, jumps?: number): ActionInterval; + /** + !#en + An action that moves the target with a cubic Bezier curve by a certain distance. + Relative to its movement. + !#zh 按贝赛尔曲线轨迹移动指定的距离。 + @param t time in seconds + @param c Array of points + + @example + ```js + // example + var bezier = [cc.p(0, windowSize.height / 2), cc.p(300, -windowSize.height / 2), cc.p(300, 100)]; + var bezierForward = cc.bezierBy(3, bezier); + ``` + */ + export function bezierBy(t: number, c: Vec2[]): ActionInterval; + /** + !#en An action that moves the target with a cubic Bezier curve to a destination point. + !#zh 按贝赛尔曲线轨迹移动到目标位置。 + @param t t + @param c Array of points + + @example + ```js + // example + var bezier = [cc.p(0, windowSize.height / 2), cc.p(300, -windowSize.height / 2), cc.p(300, 100)]; + var bezierTo = cc.bezierTo(2, bezier); + ``` + */ + export function bezierTo(t: number, c: Vec2[]): ActionInterval; + /** + !#en Scales a Node object to a zoom factor by modifying it's scale property. + !#zh 将节点大小缩放到指定的倍数。 + @param duration duration + @param sx scale parameter in X + @param sy scale parameter in Y, if Null equal to sx + + @example + ```js + // example + // It scales to 0.5 in both X and Y. + var actionTo = cc.scaleTo(2, 0.5); + + // It scales to 0.5 in x and 2 in Y + var actionTo = cc.scaleTo(2, 0.5, 2); + ``` + */ + export function scaleTo(duration: number, sx: number, sy?: number): ActionInterval; + /** + !#en + Scales a Node object a zoom factor by modifying it's scale property. + Relative to its changes. + !#zh 按指定的倍数缩放节点大小。 + @param duration duration in seconds + @param sx sx scale parameter in X + @param sy sy scale parameter in Y, if Null equal to sx + + @example + ```js + // example without sy, it scales by 2 both in X and Y + var actionBy = cc.scaleBy(2, 2); + + //example with sy, it scales by 0.25 in X and 4.5 in Y + var actionBy2 = cc.scaleBy(2, 0.25, 4.5); + ``` + */ + export function scaleBy(duration: number, sx: number, sy?: number|void): ActionInterval; + /** + !#en Blinks a Node object by modifying it's visible property. + !#zh 闪烁(基于透明度)。 + @param duration duration in seconds + @param blinks blinks in times + + @example + ```js + // example + var action = cc.blink(2, 10); + ``` + */ + export function blink(duration: number, blinks: number): ActionInterval; + /** + !#en + Fades an object that implements the cc.RGBAProtocol protocol. + It modifies the opacity from the current value to a custom one. + !#zh 修改透明度到指定值。 + @param duration duration + @param opacity 0-255, 0 is transparent + + @example + ```js + // example + var action = cc.fadeTo(1.0, 0); + ``` + */ + export function fadeTo(duration: number, opacity: number): ActionInterval; + /** + !#en Fades In an object that implements the cc.RGBAProtocol protocol. It modifies the opacity from 0 to 255. + !#zh 渐显效果。 + @param duration duration in seconds + + @example + ```js + //example + var action = cc.fadeIn(1.0); + ``` + */ + export function fadeIn(duration: number): ActionInterval; + /** + !#en Fades Out an object that implements the cc.RGBAProtocol protocol. It modifies the opacity from 255 to 0. + !#zh 渐隐效果。 + @param d duration in seconds + + @example + ```js + // example + var action = cc.fadeOut(1.0); + ``` + */ + export function fadeOut(d: number): ActionInterval; + /** + !#en Tints a Node that implements the cc.NodeRGB protocol from current tint to a custom one. + !#zh 修改颜色到指定值。 + @param duration duration + @param red 0-255 + @param green 0-255 + @param blue 0-255 + + @example + ```js + // example + var action = cc.tintTo(2, 255, 0, 255); + ``` + */ + export function tintTo(duration: number, red: number, green: number, blue: number): ActionInterval; + /** + !#en + Tints a Node that implements the cc.NodeRGB protocol from current tint to a custom one. + Relative to their own color change. + !#zh 按照指定的增量修改颜色。 + @param duration duration in seconds + @param deltaRed deltaRed + @param deltaGreen deltaGreen + @param deltaBlue deltaBlue + + @example + ```js + // example + var action = cc.tintBy(2, -127, -255, -127); + ``` + */ + export function tintBy(duration: number, deltaRed: number, deltaGreen: number, deltaBlue: number): ActionInterval; + /** + !#en Delays the action a certain amount of seconds. + !#en 延迟指定的时间量。 + @param d duration in seconds + + @example + ```js + // example + var delay = cc.delayTime(1); + ``` + */ + export function delayTime(d: number): ActionInterval; + /** + !#en Executes an action in reverse order, from time=duration to time=0. + !#zh 反转目标动作的时间轴。 + @param action action + + @example + ```js + // example + var reverse = cc.reverseTime(this); + ``` + */ + export function reverseTime(action: FiniteTimeAction): ActionInterval; + /** + !#en Create an action with the specified action and forced target. + !#zh 用已有动作和一个新的目标节点创建动作。 + @param target target + @param action action + */ + export function targetedAction(target: Node, action: FiniteTimeAction): ActionInterval; + /** !#en cc.view is the shared view object. + !#zh cc.view 是全局的视图对象。 */ + export var view: View; + /** !#en Director + !#zh 导演类。 */ + export var director: Director; + /** !#en cc.winSize is the alias object for the size of the current game window. + !#zh cc.winSize 为当前的游戏窗口的大小。 */ + export var winSize: Size; + export var game: Game; + /** !#en The System event singleton for global usage + !#zh 系统事件单例,方便全局使用 */ + export var systemEvent: SystemEvent; + /** + !#en Defines a CCClass using the given specification, please see [Class](/docs/editors_and_tools/creator-chapters/scripting/class.html) for details. + !#zh 定义一个 CCClass,传入参数必须是一个包含类型参数的字面量对象,具体用法请查阅[类型定义](/docs/creator/scripting/class.html)。 + @param options options + + @example + ```js + // define base class + var Node = cc.Class(); + + // define sub class + var Sprite = cc.Class({ + name: 'Sprite', + extends: Node, + ctor: function () { + this.url = ""; + this.id = 0; + }, + + statics: { + // define static members + count: 0, + getBounds: function (spriteList) { + // compute bounds... + } + }, + + properties { + width: { + default: 128, + type: 'Integer', + tooltip: 'The width of sprite' + }, + height: 128, + size: { + get: function () { + return cc.v2(this.width, this.height); + } + } + }, + + load: function () { + // load this.url... + }; + }); + + // instantiate + + var obj = new Sprite(); + obj.url = 'sprite.png'; + obj.load(); + ``` + */ + export function Class(options?: {name?: string; extends?: Function; ctor?: Function; __ctor__?: Function; properties?: any; statics?: any; mixins?: Function[]; editor?: {executeInEditMode?: boolean; requireComponent?: Function; menu?: string; executionOrder?: number; disallowMultiple?: boolean; playOnFocus?: boolean; inspector?: string; icon?: string; help?: string; }; update?: Function; lateUpdate?: Function; onLoad?: Function; start?: Function; onEnable?: Function; onDisable?: Function; onDestroy?: Function; onFocusInEditor?: Function; onLostFocusInEditor?: Function; resetInEditor?: Function; onRestore?: Function; _getLocalBounds?: Function; }): Function; + /** + Checks whether subclass is child of superclass or equals to superclass + @param subclass subclass + @param superclass superclass + */ + export function isChildClassOf(subclass: Function, superclass: Function): boolean; + /** + Return all super classes + @param constructor constructor + */ + export function getInheritanceChain(constructor: Function): Function[]; + /** + !#en + Define an enum type.
+ If a enum item has a value of -1, it will be given an Integer number according to it's order in the list.
+ Otherwise it will use the value specified by user who writes the enum definition. + + !#zh + 定义一个枚举类型。
+ 用户可以把枚举值设为任意的整数,如果设为 -1,系统将会分配为上一个枚举值 + 1。 + @param obj a JavaScript literal object containing enum names and values, or a TypeScript enum type + + @example + ```js + // JavaScript: + + var WrapMode = cc.Enum({ + Repeat: -1, + Clamp: -1 + }); + + // Texture.WrapMode.Repeat == 0 + // Texture.WrapMode.Clamp == 1 + // Texture.WrapMode[0] == "Repeat" + // Texture.WrapMode[1] == "Clamp" + + var FlagType = cc.Enum({ + Flag1: 1, + Flag2: 2, + Flag3: 4, + Flag4: 8, + }); + + var AtlasSizeList = cc.Enum({ + 128: 128, + 256: 256, + 512: 512, + 1024: 1024, + }); + + // TypeScript: + + // If used in TypeScript, just define a TypeScript enum: + enum Direction { + Up, + Down, + Left, + Right + } + + // If you need to inspect the enum in Properties panel, you can call cc.Enum: + const {ccclass, property} = cc._decorator; + + @ccclass + class NewScript extends cc.Component { + @property({ + default: Direction.Up, + type: cc.Enum(Direction) // call cc.Enum + }) + direction: Direction = Direction.Up; + } + + ``` + */ + export function Enum(obj: T): T; + /** + whether enable accelerometer event + @param isEnable isEnable + */ + export function setAccelerometerEnabled(isEnable: boolean): void; + /** + set accelerometer interval value + @param interval interval + */ + export function setAccelerometerInterval(interval: number): void; + /** + + @param touches touches + */ + export function handleTouchesBegin(touches: any[]): void; + /** + + @param touches touches + */ + export function handleTouchesMove(touches: any[]): void; + /** + + @param touches touches + */ + export function handleTouchesEnd(touches: any[]): void; + /** + + @param touches touches + */ + export function handleTouchesCancel(touches: any[]): void; + /** + + @param touches touches + */ + export function getSetOfTouchesEndOrCancel(touches: any[]): any[]; + /** + + @param element element + */ + export function getHTMLElementPosition(element: HTMLElement): any; + /** + + @param touch touch + */ + export function getPreTouch(touch: Touch): Touch; + /** + + @param touch touch + */ + export function setPreTouch(touch: Touch): void; + /** + + @param tx tx + @param ty ty + @param pos pos + */ + export function getTouchByXY(tx: number, ty: number, pos: Vec2): Touch; + /** + + @param location location + @param pos pos + @param eventType eventType + */ + export function getTouchByXY(location: Vec2, pos: Vec2, eventType: number): Event.EventMouse; + /** + + @param event event + @param pos pos + */ + export function getPointByEvent(event: Touch, pos: Vec2): Vec2; + /** + + @param event event + @param pos pos + */ + export function getTouchesByEvent(event: Touch, pos: Vec2): any[]; + /** + + @param element element + */ + export function registerSystemEvent(element: HTMLElement): void; + /** + + @param dt dt + */ + export function update(dt: number): void; + /** +

+ Linear interpolation between 2 numbers, the ratio sets how much it is biased to each end +

+ @param a number A + @param b number B + @param r ratio between 0 and 1 + + @example + ```js + ---- + lerp + cc.lerp(2,10,0.5)//returns 6 + cc.lerp(2,10,0.2)//returns 3.6 + + ``` + */ + export function lerp(a: number, b: number, r: number): void; + /** + get a random number from 0 to 0xffffff + */ + export function rand(): number; + /** + returns a random float between -1 and 1 + */ + export function randomMinus1To1(): number; + /** + returns a random float between 0 and 1, use Math.random directly + */ + export function random0To1(): number; + /** + converts degrees to radians + @param angle angle + */ + export function degreesToRadians(angle: number): number; + /** + converts radians to degrees + @param angle angle + */ + export function radiansToDegrees(angle: number): number; + /** + Helpful macro that setups the GL server state, the correct GL program and sets the Model View Projection matrix + @param node setup node + */ + export function nodeDrawSetup(node: Node): void; + /** +

+ Increments the GL Draws counts by one.
+ The number of calls per frame are displayed on the screen when the CCDirector's stats are enabled.
+

+ @param addNumber addNumber + */ + export function incrementGLDraws(addNumber: number): void; + /** + Check webgl error.Error will be shown in console if exists. + */ + export function checkGLErrorDebug(): void; + /** + !#en Checks whether the object is non-nil and not yet destroyed. + !#zh 检查该对象是否不为 null 并且尚未销毁。 + @param value value + + @example + ```js + cc.log(cc.isValid(target)); + ``` + */ + export function isValid(value: any): boolean; + /** Specify that the input value must be integer in Inspector. + Also used to indicates that the elements in array should be type integer. */ + export var Integer: string; + /** Indicates that the elements in array should be type double. */ + export var Float: string; + /** Indicates that the elements in array should be type boolean. */ + export var Boolean: string; + /** Indicates that the elements in array should be type string. */ + export var String: string; + /** + !#en Deserialize json to cc.Asset + !#zh 将 JSON 反序列化为对象实例。 + + 当指定了 target 选项时,如果 target 引用的其它 asset 的 uuid 不变,则不会改变 target 对 asset 的引用, + 也不会将 uuid 保存到 result 对象中。 + @param data the serialized cc.Asset json string or json object. + @param details additional loading result + @param options options + */ + export function deserialize(data: string|any, details?: Details, options?: any): any; + /** + !#en Clones the object `original` and returns the clone, or instantiate a node from the Prefab. + !#zh 克隆指定的任意类型的对象,或者从 Prefab 实例化出新节点。 + + (Instantiate 时,function 和 dom 等非可序列化对象会直接保留原有引用,Asset 会直接进行浅拷贝,可序列化类型会进行深拷贝。) + @param original An existing object that you want to make a copy of. + + @example + ```js + // instantiate node from prefab + var scene = cc.director.getScene(); + var node = cc.instantiate(prefabAsset); + node.parent = scene; + // clone node + var scene = cc.director.getScene(); + var node = cc.instantiate(targetNode); + node.parent = scene; + ``` + */ + export function instantiate(original: Prefab): Node; + export function instantiate(original: T): T; + /** + Finds a node by hierarchy path, the path is case-sensitive. + It will traverse the hierarchy by splitting the path using '/' character. + This function will still returns the node even if it is inactive. + It is recommended to not use this function every frame instead cache the result at startup. + @param path path + @param referenceNode referenceNode + */ + export function find(path: string, referenceNode?: Node): Node; + /** + !#en + The convenience method to create a new {{#crossLink "Color/Color:method"}}cc.Color{{/crossLink}} + Alpha channel is optional. Default value is 255. + + !#zh + 通过该方法来创建一个新的 {{#crossLink "Color/Color:method"}}cc.Color{{/crossLink}} 对象。 + Alpha 通道是可选的。默认值是 255。 + @param r r + @param g g + @param b b + @param a a + + @example + ```js + ----------------------- + // 1. All channels seperately as parameters + var color1 = new cc.Color(255, 255, 255, 255); + // 2. Convert a hex string to a color + var color2 = new cc.Color("#000000"); + // 3. An color object as parameter + var color3 = new cc.Color({r: 255, g: 255, b: 255, a: 255}); + + ``` + */ + export function color(r?: number, g?: number, b?: number, a?: number): Color; + /** + !#en returns true if both ccColor3B are equal. Otherwise it returns false. + !#zh 判断两个颜色对象的 RGB 部分是否相等,不比较透明度。 + @param color1 color1 + @param color2 color2 + + @example + ```js + cc.log(cc.colorEqual(cc.Color.RED, new cc.Color(255, 0, 0))); // true + ``` + */ + export function colorEqual(color1: Color, color2: Color): boolean; + /** + !#en + convert a string of color for style to Color. + e.g. "#ff06ff" to : cc.color(255,6,255)。 + !#zh 16 进制转换为 Color + @param hex hex + + @example + ```js + cc.hexToColor("#FFFF33"); // Color {r: 255, g: 255, b: 51, a: 255}; + ``` + */ + export function hexToColor(hex: string): Color; + /** + !#en + convert Color to a string of color for style. + e.g. cc.color(255,6,255) to : "#ff06ff" + !#zh Color 转换为 16进制。 + @param color color + + @example + ```js + var color = new cc.Color(255, 6, 255) + cc.colorToHex(color); // #ff06ff; + ``` + */ + export function colorToHex(color: Color): string; + /** + !#en Returns opposite of Vec2. + !#zh 返回相反的向量。 + @param point point + + @example + ```js + cc.pNeg(cc.v2(10, 10));// Vec2 {x: -10, y: -10}; + ``` + */ + export function pNeg(point: Vec2): Vec2; + /** + !#en Calculates sum of two points. + !#zh 返回两个向量的和。 + @param v1 v1 + @param v2 v2 + + @example + ```js + cc.pAdd(cc.v2(1, 1), cc.v2(2, 2));// Vec2 {x: 3, y: 3}; + ``` + */ + export function pAdd(v1: Vec2, v2: Vec2): Vec2; + /** + !#en Calculates difference of two points. + !#zh 返回两个向量的差。 + @param v1 v1 + @param v2 v2 + + @example + ```js + cc.pSub(cc.v2(20, 20), cc.v2(5, 5)); // Vec2 {x: 15, y: 15}; + ``` + */ + export function pSub(v1: Vec2, v2: Vec2): Vec2; + /** + !#en Returns point multiplied by given factor. + !#zh 向量缩放。 + @param point point + @param floatVar floatVar + + @example + ```js + cc.pMult(cc.v2(5, 5), 4); // Vec2 {x: 20, y: 20}; + ``` + */ + export function pMult(point: Vec2, floatVar: number): Vec2; + /** + !#en Calculates midpoint between two points. + !#zh 两个向量之间的中心点。 + @param v1 v1 + @param v2 v2 + + @example + ```js + cc.pMidpoint(cc.v2(10, 10), cc.v2(5, 5)); // Vec2 {x: 7.5, y: 7.5}; + ``` + */ + export function pMidpoint(v1: Vec2, v2: Vec2): Vec2; + /** + !#en Calculates dot product of two points. + !#zh 两个向量之间进行点乘。 + @param v1 v1 + @param v2 v2 + + @example + ```js + cc.pDot(cc.v2(20, 20), cc.v2(5, 5)); // 200; + ``` + */ + export function pDot(v1: Vec2, v2: Vec2): number; + /** + !#en Calculates cross product of two points. + !#zh 两个向量之间进行叉乘。 + @param v1 v1 + @param v2 v2 + + @example + ```js + cc.pCross(cc.v2(20, 20), cc.v2(5, 5)); // 0; + ``` + */ + export function pCross(v1: Vec2, v2: Vec2): number; + /** + !#en Calculates perpendicular of v, rotated 90 degrees counter-clockwise -- cross(v, perp(v)) greater than 0. + !#zh 返回逆时针旋转 90 度后的新向量。 + @param point point + + @example + ```js + cc.pPerp(cc.v2(20, 20)); // Vec2 {x: -20, y: 20}; + ``` + */ + export function pPerp(point: Vec2): Vec2; + /** + !#en Calculates perpendicular of v, rotated 90 degrees clockwise -- cross(v, rperp(v)) smaller than 0. + !#zh 将指定向量顺时针旋转 90 度并返回。 + @param point point + + @example + ```js + cc.pRPerp(cc.v2(20, 20)); // Vec2 {x: 20, y: -20}; + ``` + */ + export function pRPerp(point: Vec2): Vec2; + /** + !#en Calculates the projection of v1 over v2. + !#zh 返回 v1 在 v2 上的投影向量。 + @param v1 v1 + @param v2 v2 + + @example + ```js + var v1 = cc.v2(20, 20); + var v2 = cc.v2(5, 5); + cc.pProject(v1, v2); // Vec2 {x: 20, y: 20}; + ``` + */ + export function pProject(v1: Vec2, v2: Vec2): Vec2; + /** + !#en Calculates the square length of a cc.Vec2 (not calling sqrt() ). + !#zh 返回指定向量长度的平方。 + @param v v + + @example + ```js + cc.pLengthSQ(cc.v2(20, 20)); // 800; + ``` + */ + export function pLengthSQ(v: Vec2): number; + /** + !#en Calculates the square distance between two points (not calling sqrt() ). + !#zh 返回两个点之间距离的平方。 + @param point1 point1 + @param point2 point2 + + @example + ```js + var point1 = cc.v2(20, 20); + var point2 = cc.v2(5, 5); + cc.pDistanceSQ(point1, point2); // 450; + ``` + */ + export function pDistanceSQ(point1: Vec2, point2: Vec2): number; + /** + !#en Calculates distance between point an origin. + !#zh 返回指定向量的长度. + @param v v + + @example + ```js + cc.pLength(cc.v2(20, 20)); // 28.284271247461902; + ``` + */ + export function pLength(v: Vec2): number; + /** + !#en Calculates the distance between two points. + !#zh 返回指定 2 个向量之间的距离。 + @param v1 v1 + @param v2 v2 + + @example + ```js + var v1 = cc.v2(20, 20); + var v2 = cc.v2(5, 5); + cc.pDistance(v1, v2); // 21.213203435596427; + ``` + */ + export function pDistance(v1: Vec2, v2: Vec2): number; + /** + !#en Returns this vector with a magnitude of 1. + !#zh 返回一个长度为 1 的标准化过后的向量。 + @param v v + + @example + ```js + cc.pNormalize(cc.v2(20, 20)); // Vec2 {x: 0.7071067811865475, y: 0.7071067811865475}; + ``` + */ + export function pNormalize(v: Vec2): Vec2; + /** + !#en Converts radians to a normalized vector. + !#zh 将弧度转换为一个标准化后的向量,返回坐标 x = cos(a) , y = sin(a)。 + @param a a + + @example + ```js + cc.pForAngle(20); // Vec2 {x: 0.40808206181339196, y: 0.9129452507276277}; + ``` + */ + export function pForAngle(a: number): Vec2; + /** + !#en Converts a vector to radians. + !#zh 返回指定向量的弧度。 + @param v v + + @example + ```js + cc.pToAngle(cc.v2(20, 20)); // 0.7853981633974483; + ``` + */ + export function pToAngle(v: Vec2): number; + /** + !#en Clamp a value between from and to. + !#zh + 限定浮点数的最大最小值。
+ 数值大于 max_inclusive 则返回 max_inclusive。
+ 数值小于 min_inclusive 则返回 min_inclusive。
+ 否则返回自身。 + @param value value + @param min_inclusive min_inclusive + @param max_inclusive max_inclusive + + @example + ```js + var v1 = cc.clampf(20, 0, 20); // 20; + var v2 = cc.clampf(-1, 0, 20); // 0; + var v3 = cc.clampf(10, 0, 20); // 10; + ``` + */ + export function clampf(value: number, min_inclusive: number, max_inclusive: number): number; + /** + !#en Clamp a value between 0 and 1. + !#zh 限定浮点数的取值范围为 0 ~ 1 之间。 + @param value value + + @example + ```js + var v1 = cc.clampf(20); // 1; + var v2 = cc.clampf(-1); // 0; + var v3 = cc.clampf(0.5); // 0.5; + ``` + */ + export function clamp01(value: number): number; + /** + !#en Clamp a point between from and to. + !#zh + 返回指定限制区域后的向量。
+ 向量大于 max_inclusive 则返回 max_inclusive。
+ 向量小于 min_inclusive 则返回 min_inclusive。
+ 否则返回自身。 + @param p p + @param min_inclusive min_inclusive + @param max_inclusive max_inclusive + + @example + ```js + var min_inclusive = cc.v2(0, 0); + var max_inclusive = cc.v2(20, 20); + var v1 = cc.pClamp(cc.v2(20, 20), min_inclusive, max_inclusive); // Vec2 {x: 20, y: 20}; + var v2 = cc.pClamp(cc.v2(0, 0), min_inclusive, max_inclusive); // Vec2 {x: 0, y: 0}; + var v3 = cc.pClamp(cc.v2(10, 10), min_inclusive, max_inclusive); // Vec2 {x: 10, y: 10}; + ``` + */ + export function pClamp(p: Vec2, min_inclusive: Vec2, max_inclusive: Vec2): Vec2; + /** + !#en Quickly convert cc.Size to a cc.Vec2. + !#zh 快速转换 cc.Size 为 cc.Vec2。 + @param s s + + @example + ```js + cc.pFromSize(new cc.size(20, 20)); // Vec2 {x: 20, y: 20}; + ``` + */ + export function pFromSize(s: Size): Vec2; + /** + !#en + Run a math operation function on each point component
+ Math.abs, Math.fllor, Math.ceil, Math.round. + !#zh 通过运行指定的数学运算函数来计算指定的向量。 + @param p p + @param opFunc opFunc + + @example + ```js + cc.pCompOp(cc.p(-10, -10), Math.abs); // Vec2 {x: 10, y: 10}; + ``` + */ + export function pCompOp(p: Vec2, opFunc: Function): Vec2; + /** + !#en + Linear Interpolation between two points a and b.
+ alpha == 0 ? a
+ alpha == 1 ? b
+ otherwise a value between a..b. + !#zh + 两个点 A 和 B 之间的线性插值。
+ alpha == 0 ? a
+ alpha == 1 ? b
+ 否则这个数值在 a ~ b 之间。 + @param a a + @param b b + @param alpha alpha + + @example + ```js + cc.pLerp(cc.v2(20, 20), cc.v2(5, 5), 0.5); // Vec2 {x: 12.5, y: 12.5}; + ``` + */ + export function pLerp(a: Vec2, b: Vec2, alpha: number): Vec2; + /** + !#en TODO + !#zh + 近似判断两个点是否相等。
+ 判断 2 个向量是否在指定数值的范围之内,如果在则返回 true,反之则返回 false。 + @param a a + @param b b + @param variance variance + + @example + ```js + var a = cc.v2(20, 20); + var b = cc.v2(5, 5); + var b1 = cc.pFuzzyEqual(a, b, 10); // false; + var b2 = cc.pFuzzyEqual(a, b, 18); // true; + ``` + */ + export function pFuzzyEqual(a: Vec2, b: Vec2, variance: number): boolean; + /** + !#en Multiplies a nd b components, a.x*b.x, a.y*b.y. + !#zh 计算两个向量的每个分量的乘积, a.x * b.x, a.y * b.y。 + @param a a + @param b b + + @example + ```js + cc.pCompMult(acc.v2(20, 20), cc.v2(5, 5)); // Vec2 {x: 100, y: 100}; + ``` + */ + export function pCompMult(a: Vec2, b: Vec2): Vec2; + /** + !#en TODO + !#zh 返回两个向量之间带正负号的弧度。 + @param a a + @param b b + */ + export function pAngleSigned(a: Vec2, b: Vec2): number; + /** + !#en TODO + !#zh 获取当前向量与指定向量之间的弧度角。 + @param a a + @param b b + */ + export function pAngle(a: Vec2, b: Vec2): number; + /** + !#en Rotates a point counter clockwise by the angle around a pivot. + !#zh 返回给定向量围绕指定轴心顺时针旋转一定弧度后的结果。 + @param v v is the point to rotate + @param pivot pivot is the pivot, naturally + @param angle angle is the angle of rotation cw in radians + */ + export function pRotateByAngle(v: Vec2, pivot: Vec2, angle: number): Vec2; + /** + !#en + A general line-line intersection test + indicating successful intersection of a line
+ note that to truly test intersection for segments we have to make
+ sure that s & t lie within [0..1] and for rays, make sure s & t > 0
+ the hit point is p3 + t * (p4 - p3);
+ the hit point also is p1 + s * (p2 - p1); + !#zh + 返回 A 为起点 B 为终点线段 1 所在直线和 C 为起点 D 为终点线段 2 所在的直线是否相交,
+ 如果相交返回 true,反之则为 false,参数 retP 是返回交点在线段 1、线段 2 上的比例。 + @param A A is the startpoint for the first line P1 = (p1 - p2). + @param B B is the endpoint for the first line P1 = (p1 - p2). + @param C C is the startpoint for the second line P2 = (p3 - p4). + @param D D is the endpoint for the second line P2 = (p3 - p4). + @param retP retP.x is the range for a hitpoint in P1 (pa = p1 + s*(p2 - p1)),
+ retP.y is the range for a hitpoint in P3 (pa = p2 + t*(p4 - p3)). + */ + export function pLineIntersect(A: Vec2, B: Vec2, C: Vec2, D: Vec2, retP: Vec2): boolean; + /** + !#en ccpSegmentIntersect return YES if Segment A-B intersects with segment C-D. + !#zh 返回线段 A - B 和线段 C - D 是否相交。 + @param A A + @param B B + @param C C + @param D D + */ + export function pSegmentIntersect(A: Vec2, B: Vec2, C: Vec2, D: Vec2): boolean; + /** + !#en ccpIntersectPoint return the intersection point of line A-B, C-D. + !#zh 返回线段 A - B 和线段 C - D 的交点。 + @param A A + @param B B + @param C C + @param D D + */ + export function pIntersectPoint(A: Vec2, B: Vec2, C: Vec2, D: Vec2): Vec2; + /** + !#en check to see if both points are equal. + !#zh 检查指定的 2 个向量是否相等。 + @param A A ccp a + @param B B ccp b to be compared + */ + export function pSameAs(A: Vec2, B: Vec2): boolean; + /** + !#en sets the position of the point to 0. + !#zh 设置指定向量归 0。 + @param v v + */ + export function pZeroIn(v: Vec2): void; + /** + !#en copies the position of one point to another. + !#zh 令 v1 向量等同于 v2。 + @param v1 v1 + @param v2 v2 + */ + export function pIn(v1: Vec2, v2: Vec2): void; + /** + !#en multiplies the point with the given factor (inplace). + !#zh 向量缩放,结果保存到第一个向量。 + @param point point + @param floatVar floatVar + */ + export function pMultIn(point: Vec2, floatVar: number): void; + /** + !#en subtracts one point from another (inplace). + !#zh 向量减法,结果保存到第一个向量。 + @param v1 v1 + @param v2 v2 + */ + export function pSubIn(v1: Vec2, v2: Vec2): void; + /** + !#en adds one point to another (inplace). + !#zh 向量加法,结果保存到第一个向量。 + @param v1 v1 + @param v2 v2 + */ + export function pAddIn(v1: Vec2, v2: Vec2): void; + /** + !#en normalizes the point (inplace). + !#zh 规范化 v 向量,设置 v 向量长度为 1。 + @param v v + */ + export function pNormalizeIn(v: Vec2): void; + /** + !#en + The convenience method to create a new Rect. + see {{#crossLink "Rect/Rect:method"}}cc.Rect{{/crossLink}} + !#zh + 该方法用来快速创建一个新的矩形。{{#crossLink "Rect/Rect:method"}}cc.Rect{{/crossLink}} + @param x x + @param y y + @param w w + @param h h + + @example + ```js + var a = new cc.Rect(0 , 0, 10, 0); + ``` + */ + export function rect(x?: number, y?: number, w?: number, h?: number): Rect; + /** + !#en Check whether a rect's value equals to another. + !#zh 判断两个矩形是否相等。 + @param rect1 rect1 + @param rect2 rect2 + + @example + ```js + var a = new cc.Rect(0, 0, 10, 10); + var b = new cc.Rect(0, 0, 5, 5); + cc.rectEqualToRect(a, b); // false; + var c = new cc.Rect(0, 0, 5, 5); + cc.rectEqualToRect(b, c); // true; + ``` + */ + export function rectEqualToRect(rect1: Rect, rect2: Rect): boolean; + /** + !#en Check whether the rect1 contains rect2. + !#zh + 检查 rect1 矩形是否包含 rect2 矩形。
+ 注意:如果要允许 rect1 和 rect2 的边界重合,应该用 cc.rectOverlapsRect + @param rect1 rect1 + @param rect2 rect2 + + @example + ```js + var a = new cc.Rect(0, 0, 20, 20); + var b = new cc.Rect(10, 10, 20, 20); + cc.rectContainsRect(a, b); // true; + ``` + */ + export function rectContainsRect(rect1: Rect, rect2: Rect): boolean; + /** + !#en Returns the rightmost x-value of a rect. + !#zh 返回矩形在 x 轴上的最大值 + @param rect rect + + @example + ```js + var a = new cc.Rect(10, 0, 20, 20); + cc.rectGetMaxX(a); // 30; + ``` + */ + export function rectGetMaxX(rect: Rect): number; + /** + !#en Return the midpoint x-value of a rect. + !#zh 返回矩形在 x 轴上的中点。 + @param rect rect + + @example + ```js + var a = new cc.Rect(10, 0, 20, 20); + cc.rectGetMidX(a); // 20; + ``` + */ + export function rectGetMidX(rect: Rect): number; + /** + !#en Returns the leftmost x-value of a rect. + !#zh 返回矩形在 x 轴上的最小值。 + @param rect rect + + @example + ```js + var a = new cc.Rect(10, 0, 20, 20); + cc.rectGetMinX(a); // 10; + ``` + */ + export function rectGetMinX(rect: Rect): number; + /** + !#en Return the topmost y-value of a rect. + !#zh 返回矩形在 y 轴上的最大值。 + @param rect rect + + @example + ```js + var a = new cc.Rect(0, 10, 20, 20); + cc.rectGetMaxY(a); // 30; + ``` + */ + export function rectGetMaxY(rect: Rect): number; + /** + !#en Return the midpoint y-value of `rect'. + !#zh 返回矩形在 y 轴上的中点。 + @param rect rect + + @example + ```js + var a = new cc.Rect(0, 10, 20, 20); + cc.rectGetMidY(a); // 20; + ``` + */ + export function rectGetMidY(rect: Rect): number; + /** + !#en Return the bottommost y-value of a rect. + !#zh 返回矩形在 y 轴上的最小值。 + @param rect rect + + @example + ```js + var a = new cc.Rect(0, 10, 20, 20); + cc.rectGetMinY(a); // 10; + ``` + */ + export function rectGetMinY(rect: Rect): number; + /** + !#en Check whether a rect contains a point. + !#zh 检查一个矩形是否包含某个坐标点。 + @param rect rect + @param point point + + @example + ```js + var a = new cc.Rect(0, 10, 20, 20); + var b = new cc.Vec2(0, 10, 10, 10); + cc.rectContainsPoint(a, b); // true; + ``` + */ + export function rectContainsPoint(rect: Rect, point: Vec2): boolean; + /** + !#en Check whether a rect intersect with another. + !#zh 检查一个矩形是否与另一个相交。 + @param rectA rectA + @param rectB rectB + + @example + ```js + var a = new cc.Rect(0, 10, 20, 20); + var b = new cc.Rect(0, 10, 10, 10); + cc.rectIntersectsRect(a, b); // true; + ``` + */ + export function rectIntersectsRect(rectA: Rect, rectB: Rect): boolean; + /** + !#en Check whether a rect overlaps another. + !#zh 检查一个矩形是否重叠另一个。 + @param rectA rectA + @param rectB rectB + + @example + ```js + var a = new cc.Rect(0, 10, 20, 20); + var b = new cc.Rect(0, 10, 10, 10); + cc.rectOverlapsRect(a, b); // true; + ``` + */ + export function rectOverlapsRect(rectA: Rect, rectB: Rect): boolean; + /** + !#en Returns the smallest rectangle that contains the two source rectangles. + !#zh 返回一个包含两个指定矩形的最小矩形。 + @param rectA rectA + @param rectB rectB + + @example + ```js + var a = new cc.Rect(0, 10, 20, 20); + var b = new cc.Rect(0, 10, 10, 10); + cc.rectUnion(a, b); // Rect {x: 0, y: 10, width: 20, height: 20}; + ``` + */ + export function rectUnion(rectA: Rect, rectB: Rect): Rect; + /** + !#en Returns the overlapping portion of 2 rectangles. + !#zh 返回 2 个矩形重叠的部分。 + @param rectA rectA + @param rectB rectB + + @example + ```js + var a = new cc.Rect(0, 10, 20, 20); + var b = new cc.Rect(0, 10, 10, 10); + cc.rectIntersection(a, b); // Rect {x: 0, y: 10, width: 10, height: 10}; + ``` + */ + export function rectIntersection(rectA: Rect, rectB: Rect): Rect; + /** + !#en + Helper function that creates a cc.Size.
+ Please use cc.p or cc.v2 instead, it will soon replace cc.Size. + !#zh + 创建一个 cc.Size 对象的帮助函数。
+ 注意:可以使用 cc.p 或者是 cc.v2 代替,它们将很快取代 cc.Size。 + @param w width or a size object + @param h height + + @example + ```js + var size1 = cc.size(); + var size2 = cc.size(100,100); + var size3 = cc.size(size2); + var size4 = cc.size({width: 100, height: 100}); + + ``` + */ + export function size(w: number|Size, h?: number): Size; + /** + !#en Check whether a point's value equals to another. + !#zh 检查 Size 对象是否等于另一个。 + @param size1 size1 + @param size2 size2 + + @example + ```js + var a = new cc.size(10, 10); + var b = new cc.size(10, 10); + cc.sizeEqualToSize(a, b);// return true; + var b = new cc.size(5, 10); + cc.sizeEqualToSize(a, b);// return false; + ``` + */ + export function sizeEqualToSize(size1: Size, size2: Size): boolean; + export function V3F_C4B_T2F_QuadZero(): V3F_C4B_T2F_Quad; + /** + + @param sourceQuad sourceQuad + */ + export function V3F_C4B_T2F_QuadCopy(sourceQuad: V3F_C4B_T2F_Quad): V3F_C4B_T2F_Quad; + /** + + @param sourceQuads sourceQuads + */ + export function V3F_C4B_T2F_QuadsCopy(sourceQuads: any[]): any[]; + /** + !#en The convenience method to create a new {{#crossLink "Vec2"}}cc.Vec2{{/crossLink}}. + !#zh 通过该简便的函数进行创建 {{#crossLink "Vec2"}}cc.Vec2{{/crossLink}} 对象。 + @param x x + @param y y + + @example + ```js + var v1 = cc.v2(); + var v2 = cc.v2(0, 0); + var v3 = cc.v2(v2); + var v4 = cc.v2({x: 100, y: 100}); + ``` + */ + export function v2(x?: number|any, y?: number): Vec2; + /** + !#en The convenience method to creates a new {{#crossLink "Vec2"}}cc.Vec2{{/crossLink}}. + !#zh 通过该简便的函数进行创建 {{#crossLink "Vec2"}}cc.Vec2{{/crossLink}} 对象。 + @param x a Number or a size object + @param y y + + @example + ```js + var point1 = cc.p(); + var point2 = cc.p(100, 100); + var point3 = cc.p(point2); + var point4 = cc.p({x: 100, y: 100}); + ``` + */ + export function p(x?: number|any, y?: number): Vec2; + /** + !#en Check whether a point's value equals to another. + !#zh 判断两个向量是否相等。 + @param point1 point1 + @param point2 point2 + */ + export function pointEqualToPoint(point1: Vec2, point2: Vec2): boolean; + /** !#en Enum for debug modes. + !#zh 调试模式 */ + export enum DebugMode { + NONE = 0, + INFO = 0, + WARN = 0, + ERROR = 0, + INFO_FOR_WEB_PAGE = 0, + WARN_FOR_WEB_PAGE = 0, + ERROR_FOR_WEB_PAGE = 0, + } + /** !#en Base class cc.Action for action classes. + !#zh Action 类是所有动作类型的基类。 */ + export class Action { + /** + !#en + to copy object with deep copy. + returns a clone of action. + !#zh 返回一个克隆的动作。 + */ + clone(): Action; + /** + !#en + return true if the action has finished. + !#zh 如果动作已完成就返回 true。 + */ + isDone(): boolean; + /** + !#en get the target. + !#zh 获取当前目标节点。 + */ + getTarget(): Node; + /** + !#en The action will modify the target properties. + !#zh 设置目标节点。 + @param target target + */ + setTarget(target: Node): void; + /** + !#en get the original target. + !#zh 获取原始目标节点。 + */ + getOriginalTarget(): Node; + /** + !#en get tag number. + !#zh 获取用于识别动作的标签。 + */ + getTag(): number; + /** + !#en set tag number. + !#zh 设置标签,用于识别动作。 + @param tag tag + */ + setTag(tag: number): void; + /** !#en Default Action tag. + !#zh 默认动作标签。 */ + static TAG_INVALID: number; + } + /** !#en + Base class actions that do have a finite time duration.
+ Possible actions:
+ - An action with a duration of 0 seconds.
+ - An action with a duration of 35.5 seconds. + + Infinite time actions are valid + !#zh 有限时间动作,这种动作拥有时长 duration 属性。 */ + export class FiniteTimeAction extends Action { + /** + !#en get duration of the action. (seconds). + !#zh 获取动作以秒为单位的持续时间。 + */ + getDuration(): number; + /** + !#en set duration of the action. (seconds). + !#zh 设置动作以秒为单位的持续时间。 + @param duration duration + */ + setDuration(duration: number): void; + /** + !#en + Returns a reversed action.
+ For example:
+ - The action will be x coordinates of 0 move to 100.
+ - The reversed action will be x of 100 move to 0. + - Will be rewritten + !#zh 返回一个新的动作,执行与原动作完全相反的动作。 + */ + reverse(): void; + /** + !#en + to copy object with deep copy. + returns a clone of action. + !#zh 返回一个克隆的动作。 + */ + clone(): FiniteTimeAction; + } + /** !#en Base class for Easing actions. + !#zh 所有缓动动作基类,用于修饰 ActionInterval。 */ + export class ActionEase extends ActionInterval { + } + /** !#en Base class for Easing actions with rate parameters + !#zh 拥有速率属性的缓动动作基类。 */ + export class EaseRateAction extends ActionEase { + } + /** !#en Ease Elastic abstract class. + !#zh 弹性缓动动作基类。 */ + export class EaseElastic extends ActionEase { + } + /** !#en cc.EaseBounce abstract class. + !#zh 反弹缓动动作基类。 */ + export class EaseBounce extends ActionEase { + } + /** !#en Instant actions are immediate actions. They don't have a duration like the ActionInterval actions. + !#zh 即时动作,这种动作立即就会执行,继承自 FiniteTimeAction。 */ + export class ActionInstant extends FiniteTimeAction { + } + /** !#en +

An interval action is an action that takes place within a certain period of time.
+ It has an start time, and a finish time. The finish time is the parameter
+ duration plus the start time.

+ +

These CCActionInterval actions have some interesting properties, like:
+ - They can run normally (default)
+ - They can run reversed with the reverse method
+ - They can run with the time altered with the Accelerate, AccelDeccel and Speed actions.

+ +

For example, you can simulate a Ping Pong effect running the action normally and
+ then running it again in Reverse mode.

+ !#zh 时间间隔动作,这种动作在已定时间内完成,继承 FiniteTimeAction。 */ + export class ActionInterval extends FiniteTimeAction { + /** + !#en Implementation of ease motion. + !#zh 缓动运动。 + @param easeObj easeObj + + @example + ```js + action.easing(cc.easeIn(3.0)); + ``` + */ + easing(easeObj: any): ActionInterval; + /** + !#en + Repeats an action a number of times. + To repeat an action forever use the CCRepeatForever action. + !#zh 重复动作可以按一定次数重复一个动作,使用 RepeatForever 动作来永远重复一个动作。 + @param times times + */ + repeat(times: number): ActionInterval; + /** + !#en + Repeats an action for ever.
+ To repeat the an action for a limited number of times use the Repeat action.
+ !#zh 永远地重复一个动作,有限次数内重复一个动作请使用 Repeat 动作。 + */ + repeatForever(): ActionInterval; + } + /** !#en + cc.ActionManager is a class that can manage actions.
+ Normally you won't need to use this class directly. 99% of the cases you will use the CCNode interface, + which uses this class's singleton object. + But there are some cases where you might need to use this class.
+ Examples:
+ - When you want to run an action where the target is different from a CCNode.
+ - When you want to pause / resume the actions
+ !#zh + cc.ActionManager 是可以管理动作的单例类。
+ 通常你并不需要直接使用这个类,99%的情况您将使用 CCNode 的接口。
+ 但也有一些情况下,您可能需要使用这个类。
+ 例如: + - 当你想要运行一个动作,但目标不是 CCNode 类型时。
+ - 当你想要暂停/恢复动作时。
*/ + export class ActionManager { + /** + !#en + Adds an action with a target.
+ If the target is already present, then the action will be added to the existing target. + If the target is not present, a new instance of this target will be created either paused or not, and the action will be added to the newly created target. + When the target is paused, the queued actions won't be 'ticked'. + !#zh + 增加一个动作,同时还需要提供动作的目标对象,目标对象是否暂停作为参数。
+ 如果目标已存在,动作将会被直接添加到现有的节点中。
+ 如果目标不存在,将为这一目标创建一个新的实例,并将动作添加进去。
+ 当目标状态的 paused 为 true,动作将不会被执行 + @param action action + @param target target + @param paused paused + */ + addAction(action: Action, target: Node, paused: boolean): void; + /** + !#en Removes all actions from all the targets. + !#zh 移除所有对象的所有动作。 + */ + removeAllActions(): void; + /** + !#en + Removes all actions from a certain target.
+ All the actions that belongs to the target will be removed. + !#zh + 移除指定对象上的所有动作。
+ 属于该目标的所有的动作将被删除。 + @param target target + @param forceDelete forceDelete + */ + removeAllActionsFromTarget(target: Node, forceDelete: boolean): void; + /** + !#en Removes an action given an action reference. + !#zh 移除指定的动作。 + @param action action + */ + removeAction(action: Action): void; + /** + !#en Removes an action given its tag and the target. + !#zh 删除指定对象下特定标签的一个动作,将删除首个匹配到的动作。 + @param tag tag + @param target target + */ + removeActionByTag(tag: number, target: Node): void; + /** + !#en Gets an action given its tag an a target. + !#zh 通过目标对象和标签获取一个动作。 + @param tag tag + @param target target + */ + getActionByTag(tag: number, target: Node): Action; + /** + !#en + Returns the numbers of actions that are running in a certain target.
+ Composable actions are counted as 1 action.
+ Example:
+ - If you are running 1 Sequence of 7 actions, it will return 1.
+ - If you are running 7 Sequences of 2 actions, it will return 7. + !#zh + 返回指定对象下所有正在运行的动作数量。
+ 组合动作被算作一个动作。
+ 例如:
+ - 如果您正在运行 7 个动作组成的序列动作(Sequence),这个函数将返回 1。
+ - 如果你正在运行 2 个序列动作(Sequence)和 5 个普通动作,这个函数将返回 7。
+ @param target target + */ + getNumberOfRunningActionsInTarget(target: Node): number; + /** + !#en Pauses the target: all running actions and newly added actions will be paused. + !#zh 暂停指定对象:所有正在运行的动作和新添加的动作都将会暂停。 + @param target target + */ + pauseTarget(target: Node): void; + /** + !#en Resumes the target. All queued actions will be resumed. + !#zh 让指定目标恢复运行。在执行序列中所有被暂停的动作将重新恢复运行。 + @param target target + */ + resumeTarget(target: Node): void; + /** + !#en Pauses all running actions, returning a list of targets whose actions were paused. + !#zh 暂停所有正在运行的动作,返回一个包含了那些动作被暂停了的目标对象的列表。 + */ + pauseAllRunningActions(): any[]; + /** + !#en Resume a set of targets (convenience function to reverse a pauseAllRunningActions or pauseTargets call). + !#zh 让一组指定对象恢复运行(用来逆转 pauseAllRunningActions 效果的便捷函数)。 + @param targetsToResume targetsToResume + */ + resumeTargets(targetsToResume: any[]): void; + /** + !#en Pause a set of targets. + !#zh 暂停一组指定对象。 + @param targetsToPause targetsToPause + */ + pauseTargets(targetsToPause: any[]): void; + /** + !#en + purges the shared action manager. It releases the retained instance.
+ because it uses this, so it can not be static. + !#zh + 清除共用的动作管理器。它释放了持有的实例。
+ 因为它使用 this,因此它不能是静态的。 + */ + purgeSharedManager(): void; + /** + !#en The ActionManager update。 + !#zh ActionManager 主循环。 + @param dt delta time in seconds + */ + update(dt: number): void; + } + /** !#en Class for animation data handling. + !#zh 动画剪辑,用于存储动画数据。 */ + export class AnimationClip extends Asset { + /** !#en Duration of this animation. + !#zh 动画的持续时间。 */ + duration: number; + /** !#en FrameRate of this animation. + !#zh 动画的帧速率。 */ + sample: number; + /** !#en Speed of this animation. + !#zh 动画的播放速度。 */ + speed: number; + /** !#en WrapMode of this animation. + !#zh 动画的循环模式。 */ + wrapMode: WrapMode; + /** !#en Curve data. + !#zh 曲线数据。 */ + curveData: any; + /** !#en Event data. + !#zh 事件数据。 */ + events: {frame: number, func: string, params: string[]}[]; + /** + !#en Crate clip with a set of sprite frames + !#zh 使用一组序列帧图片来创建动画剪辑 + @param spriteFrames spriteFrames + @param sample sample + + @example + ```js + var clip = cc.AnimationClip.createWithSpriteFrames(spriteFrames, 10); + ``` + */ + static createWithSpriteFrames(spriteFrames: [SpriteFrame], sample: number): AnimationClip; + } + /** !#en + The AnimationState gives full control over animation playback process. + In most cases the Animation Component is sufficient and easier to use. Use the AnimationState if you need full control. + !#zh + AnimationState 完全控制动画播放过程。
+ 大多数情况下 动画组件 是足够和易于使用的。如果您需要更多的动画控制接口,请使用 AnimationState。 */ + export class AnimationState extends Playable { + /** + + @param clip clip + @param name name + */ + constructor(clip: AnimationClip, name?: string); + animator: AnimationAnimator; + /** !#en The curves list. + !#zh 曲线列表。 */ + curves: any[]; + /** !#en The start delay which represents the number of seconds from an animation's start time to the start of + the active interval. + !#zh 延迟多少秒播放。 */ + delay: number; + /** !#en The animation's iteration count property. + + A real number greater than or equal to zero (including positive infinity) representing the number of times + to repeat the animation node. + + Values less than zero and NaN values are treated as the value 1.0 for the purpose of timing model + calculations. + + !#zh 迭代次数,指动画播放多少次后结束, normalize time。 如 2.5(2次半) */ + repeatCount: number; + /** !#en The iteration duration of this animation in seconds. (length) + !#zh 单次动画的持续时间,秒。 */ + duration: number; + /** !#en The animation's playback speed. 1 is normal playback speed. + !#zh 播放速率。 */ + speed: number; + /** !#en + Wrapping mode of the playing animation. + Notice : dynamic change wrapMode will reset time and repeatCount property + !#zh + 动画循环方式。 + 需要注意的是,动态修改 wrapMode 时,会重置 time 以及 repeatCount */ + wrapMode: WrapMode; + /** !#en The current time of this animation in seconds. + !#zh 动画当前的时间,秒。 */ + time: number; + /** !#en The clip that is being played by this animation state. + !#zh 此动画状态正在播放的剪辑。 */ + clip: AnimationClip; + /** !#en The name of the playing animation. + !#zh 动画的名字 */ + name: string; + } + /** undefined */ + export class Playable { + /** !#en Is playing or paused in play mode? + !#zh 当前是否正在播放。 */ + isPlaying: boolean; + /** !#en Is currently paused? This can be true even if in edit mode(isPlaying == false). + !#zh 当前是否正在暂停 */ + isPaused: boolean; + /** + !#en Play this animation. + !#zh 播放动画。 + */ + play(): void; + /** + !#en Stop this animation. + !#zh 停止动画播放。 + */ + stop(): void; + /** + !#en Pause this animation. + !#zh 暂停动画。 + */ + pause(): void; + /** + !#en Resume this animation. + !#zh 重新播放动画。 + */ + resume(): void; + /** + !#en Perform a single frame step. + !#zh 执行一帧动画。 + */ + step(): void; + } + /** !#en Specifies how time is treated when it is outside of the keyframe range of an Animation. + !#zh 动画使用的循环模式。 */ + export enum WrapMode { + Default = 0, + Normal = 0, + Reverse = 0, + Loop = 0, + LoopReverse = 0, + PingPong = 0, + PingPongReverse = 0, + } + /** !#en cc.audioEngine is the singleton object, it provide simple audio APIs. + !#zh + cc.audioengine是单例对象。
+ 主要用来播放音频,播放的时候会返回一个 audioID,之后都可以通过这个 audioID 来操作这个音频对象。
+ 不使用的时候,请使用 cc.audioEngine.uncache(filePath); 进行资源释放
+ 注意:
+ 在 Android 系统浏览器上,不同浏览器,不同版本的效果不尽相同。
+ 比如说:大多数浏览器都需要用户物理交互才可以开始播放音效,有一些不支持 WebAudio,
+ 有一些不支持多音轨播放。总之如果对音乐依赖比较强,请做尽可能多的测试。 */ + export class audioEngine { + /** + !#en Play audio. + !#zh 播放音频 + @param filePath The path of the audio file without filename extension. + @param loop Whether the music loop or not. + @param volume Volume size. + + @example + ```js + var audioID = cc.audioEngine.play(path, false, 0.5); + ``` + */ + static play(filePath: string, loop: boolean, volume: number): number; + /** + !#en Set audio loop. + !#zh 设置音频是否循环。 + @param audioID audio id. + @param loop Whether cycle. + + @example + ```js + cc.audioEngine.setLoop(id, true); + ``` + */ + static setLoop(audioID: number, loop: boolean): void; + /** + !#en Get audio cycle state. + !#zh 获取音频的循环状态。 + @param audioID audio id. + + @example + ```js + cc.audioEngine.isLoop(id); + ``` + */ + static isLoop(audioID: number): boolean; + /** + !#en Set the volume of audio. + !#zh 设置音量(0.0 ~ 1.0)。 + @param audioID audio id. + @param volume Volume must be in 0.0~1.0 . + + @example + ```js + cc.audioEngine.setVolume(id, 0.5); + ``` + */ + static setVolume(audioID: number, volume: number): void; + /** + !#en The volume of the music max value is 1.0,the min value is 0.0 . + !#zh 获取音量(0.0 ~ 1.0)。 + @param audioID audio id. + + @example + ```js + var volume = cc.audioEngine.getVolume(id); + ``` + */ + static getVolume(audioID: number): boolean; + /** + !#en Set current time + !#zh 设置当前的音频时间。 + @param audioID audio id. + @param sec current time. + + @example + ```js + cc.audioEngine.setCurrentTime(id, 2); + ``` + */ + static setCurrentTime(audioID: number, sec: number): boolean; + /** + !#en Get current time + !#zh 获取当前的音频播放时间。 + @param audioID audio id. + + @example + ```js + var time = cc.audioEngine.getCurrentTime(id); + ``` + */ + static getCurrentTime(audioID: number): number; + /** + !#en Get audio duration + !#zh 获取音频总时长。 + @param audioID audio id. + + @example + ```js + var time = cc.audioEngine.getDuration(id); + ``` + */ + static getDuration(audioID: number): number; + /** + !#en Get audio state + !#zh 获取音频状态。 + @param audioID audio id. + + @example + ```js + var state = cc.audioEngine.getState(id); + ``` + */ + static getState(audioID: number): audioEngine.AudioState; + /** + !#en Set Audio finish callback + !#zh 设置一个音频结束后的回调 + @param audioID audio id. + @param callback loaded callback. + + @example + ```js + cc.audioEngine.setFinishCallback(id, function () {}); + ``` + */ + static setFinishCallback(audioID: number, callback: Function): void; + /** + !#en Pause playing audio. + !#zh 暂停正在播放音频。 + @param audioID The return value of function play. + + @example + ```js + cc.audioEngine.pause(audioID); + ``` + */ + static pause(audioID: number): void; + /** + !#en Pause all playing audio + !#zh 暂停现在正在播放的所有音频。 + + @example + ```js + cc.audioEngine.pauseAll(); + ``` + */ + static pauseAll(): void; + /** + !#en Resume playing audio. + !#zh 恢复播放指定的音频。 + @param audioID The return value of function play. + //example + cc.audioEngine.resume(audioID); + */ + static resume(audioID: number): void; + /** + !#en Resume all playing audio. + !#zh 恢复播放所有之前暂停的所有音频。 + + @example + ```js + cc.audioEngine.resumeAll(); + ``` + */ + static resumeAll(): void; + /** + !#en Stop playing audio. + !#zh 停止播放指定音频。 + @param audioID The return value of function play. + + @example + ```js + cc.audioEngine.stop(audioID); + ``` + */ + static stop(audioID: number): void; + /** + !#en Stop all playing audio. + !#zh 停止正在播放的所有音频。 + + @example + ```js + cc.audioEngine.stopAll(); + ``` + */ + static stopAll(): void; + /** + !#en Set up an audio can generate a few examples. + !#zh 设置一个音频可以设置几个实例 + @param num a number of instances to be created from within an audio + + @example + ```js + cc.audioEngine.setMaxAudioInstance(20); + ``` + */ + static setMaxAudioInstance(num: number): void; + /** + !#en Getting audio can produce several examples. + !#zh 获取一个音频可以设置几个实例 + + @example + ```js + cc.audioEngine.getMaxAudioInstance(); + ``` + */ + static getMaxAudioInstance(): number; + /** + !#en Unload the preloaded audio from internal buffer. + !#zh 卸载预加载的音频。 + @param filePath filePath + + @example + ```js + cc.audioEngine.uncache(filePath); + ``` + */ + static uncache(filePath: string): void; + /** + !#en Unload all audio from internal buffer. + !#zh 卸载所有音频。 + + @example + ```js + cc.audioEngine.uncacheAll(); + ``` + */ + static uncacheAll(): void; + /** + !#en Preload audio file. + !#zh 预加载一个音频 + @param filePath The file path of an audio. + @param callback The callback of an audio. + + @example + ```js + cc.audioEngine.preload(path); + ``` + */ + static preload(filePath: string, callback?: Function): void; + /** + !#en Set a size, the unit is KB. Over this size is directly resolved into DOM nodes. + !#zh 设置一个以 KB 为单位的尺寸,大于这个尺寸的音频在加载的时候会强制使用 dom 方式加载 + @param kb The file path of an audio. + + @example + ```js + cc.audioEngine.setMaxWebAudioSize(300); + ``` + */ + static setMaxWebAudioSize(kb: number): void; + } + /** !#en + cc.MotionStreak manages a Ribbon based on it's motion in absolute space.
+ You construct it with a fadeTime, minimum segment size, texture path, texture
+ length and color. The fadeTime controls how long it takes each vertex in
+ the streak to fade out, the minimum segment size it how many pixels the
+ streak will move before adding a new ribbon segment, and the texture
+ length is the how many pixels the texture is stretched across. The texture
+ is vertically aligned along the streak segment. + !#zh 运动轨迹,用于游戏对象的运动轨迹上实现拖尾渐隐效果。 */ + export class MotionStreak extends Component { + /** !#en + !#zh 在编辑器模式下预览拖尾效果。 */ + preview: boolean; + /** !#en The fade time to fade. + !#zh 拖尾的渐隐时间,以秒为单位。 */ + fadeTime: number; + /** !#en The minimum segment size. + !#zh 拖尾之间最小距离。 */ + minSeg: number; + /** !#en The stroke's width. + !#zh 拖尾的宽度。 */ + stroke: number; + /** !#en The texture of the MotionStreak. + !#zh 拖尾的贴图。 */ + texture: Texture2D; + /** !#en The color of the MotionStreak. + !#zh 拖尾的颜色 */ + color: Color; + /** !#en The fast Mode. + !#zh 是否启用了快速模式。当启用快速模式,新的点会被更快地添加,但精度较低。 */ + fastMode: boolean; + /** + !#en Remove all living segments of the ribbon. + !#zh 删除当前所有的拖尾片段。 + + @example + ```js + // stop particle system. + myParticleSystem.stopSystem(); + ``` + */ + reset(): void; + } + /** Particle System base class.
+ Attributes of a Particle System:
+ - emmision rate of the particles
+ - Gravity Mode (Mode A):
+ - gravity
+ - direction
+ - speed +- variance
+ - tangential acceleration +- variance
+ - radial acceleration +- variance
+ - Radius Mode (Mode B):
+ - startRadius +- variance
+ - endRadius +- variance
+ - rotate +- variance
+ - Properties common to all modes:
+ - life +- life variance
+ - start spin +- variance
+ - end spin +- variance
+ - start size +- variance
+ - end size +- variance
+ - start color +- variance
+ - end color +- variance
+ - life +- variance
+ - blending function
+ - texture
+
+ cocos2d also supports particles generated by Particle Designer (http://particledesigner.71squared.com/).
+ 'Radius Mode' in Particle Designer uses a fixed emit rate of 30 hz. Since that can't be guarateed in cocos2d,
+ cocos2d uses a another approach, but the results are almost identical.
+ cocos2d supports all the variables used by Particle Designer plus a bit more:
+ - spinning particles (supported when using ParticleSystem)
+ - tangential acceleration (Gravity mode)
+ - radial acceleration (Gravity mode)
+ - radius direction (Radius mode) (Particle Designer supports outwards to inwards direction only)
+ It is possible to customize any of the above mentioned properties in runtime. Example:
*/ + export class ParticleSystem extends _RendererUnderSG { + /** !#en Play particle in edit mode. + !#zh 在编辑器模式下预览粒子,启用后选中粒子时,粒子将自动播放。 */ + preview: boolean; + /** !#en + If set custom to true, then use custom properties insteadof read particle file. + !#zh 是否自定义粒子属性。 */ + custom: boolean; + /** !#en The plist file. + !#zh plist 格式的粒子配置文件。 */ + file: string; + /** . */ + texture: Texture2D; + /** !#en Current quantity of particles that are being simulated. + !#zh 当前播放的粒子数量。 */ + particleCount: number; + /** !#en Specify the source Blend Factor. + !#zh 指定原图混合模式。 */ + srcBlendFactor: BlendFactor; + /** !#en Specify the destination Blend Factor. + !#zh 指定目标的混合模式。 */ + dstBlendFactor: BlendFactor; + /** !#en If set to true, the particle system will automatically start playing on onLoad. + !#zh 如果设置为 true 运行时会自动发射粒子。 */ + playOnLoad: boolean; + /** !#en Indicate whether the owner node will be auto-removed when it has no particles left. + !#zh 粒子播放完毕后自动销毁所在的节点。 */ + autoRemoveOnFinish: boolean; + /** !#en Indicate whether the particle system is activated. + !#zh 是否激活粒子。 */ + active: boolean; + /** !#en Maximum particles of the system. + !#zh 粒子最大数量。 */ + totalParticles: number; + /** !#en How many seconds the emitter wil run. -1 means 'forever'. + !#zh 发射器生存时间,单位秒,-1表示持续发射。 */ + duration: number; + /** !#en Emission rate of the particles. + !#zh 每秒发射的粒子数目。 */ + emissionRate: number; + /** !#en Life of each particle setter. + !#zh 粒子的运行时间。 */ + life: number; + /** !#en Variation of life. + !#zh 粒子的运行时间变化范围。 */ + lifeVar: number; + /** !#en Start color of each particle. + !#zh 粒子初始颜色。 */ + startColor: Color; + /** !#en Variation of the start color. + !#zh 粒子初始颜色变化范围。 */ + startColorVar: Color; + /** !#en Ending color of each particle. + !#zh 粒子结束颜色。 */ + endColor: Color; + /** !#en Variation of the end color. + !#zh 粒子结束颜色变化范围。 */ + endColorVar: Color; + /** !#en Angle of each particle setter. + !#zh 粒子角度。 */ + angle: number; + /** !#en Variation of angle of each particle setter. + !#zh 粒子角度变化范围。 */ + angleVar: number; + /** !#en Start size in pixels of each particle. + !#zh 粒子的初始大小。 */ + startSize: number; + /** !#en Variation of start size in pixels. + !#zh 粒子初始大小的变化范围。 */ + startSizeVar: number; + /** !#en End size in pixels of each particle. + !#zh 粒子结束时的大小。 */ + endSize: number; + /** !#en Variation of end size in pixels. + !#zh 粒子结束大小的变化范围。 */ + endSizeVar: number; + /** !#en Start angle of each particle. + !#zh 粒子开始自旋角度。 */ + startSpin: number; + /** !#en Variation of start angle. + !#zh 粒子开始自旋角度变化范围。 */ + startSpinVar: number; + /** !#en End angle of each particle. + !#zh 粒子结束自旋角度。 */ + endSpin: number; + /** !#en Variation of end angle. + !#zh 粒子结束自旋角度变化范围。 */ + endSpinVar: number; + /** !#en Source position of the emitter. + !#zh 发射器位置。 */ + sourcePos: Vec2; + /** !#en Variation of source position. + !#zh 发射器位置的变化范围。(横向和纵向) */ + posVar: Vec2; + /** !#en Particles movement type. + !#zh 粒子位置类型。 */ + positionType: ParticleSystem.PositionType; + /** !#en Particles emitter modes. + !#zh 发射器类型。 */ + emitterMode: ParticleSystem.EmitterMode; + /** !#en Gravity of the emitter. + !#zh 重力。 */ + gravity: Vec2; + /** !#en Speed of the emitter. + !#zh 速度。 */ + speed: number; + /** !#en Variation of the speed. + !#zh 速度变化范围。 */ + speedVar: number; + /** !#en Tangential acceleration of each particle. Only available in 'Gravity' mode. + !#zh 每个粒子的切向加速度,即垂直于重力方向的加速度,只有在重力模式下可用。 */ + tangentialAccel: number; + /** !#en Variation of the tangential acceleration. + !#zh 每个粒子的切向加速度变化范围。 */ + tangentialAccelVar: number; + /** !#en Acceleration of each particle. Only available in 'Gravity' mode. + !#zh 粒子径向加速度,即平行于重力方向的加速度,只有在重力模式下可用。 */ + radialAccel: number; + /** !#en Variation of the radial acceleration. + !#zh 粒子径向加速度变化范围。 */ + radialAccelVar: number; + /** !#en Indicate whether the rotation of each particle equals to its direction. Only available in 'Gravity' mode. + !#zh 每个粒子的旋转是否等于其方向,只有在重力模式下可用。 */ + rotationIsDir: boolean; + /** !#en Starting radius of the particles. Only available in 'Radius' mode. + !#zh 初始半径,表示粒子出生时相对发射器的距离,只有在半径模式下可用。 */ + startRadius: number; + /** !#en Variation of the starting radius. + !#zh 初始半径变化范围。 */ + startRadiusVar: number; + /** !#en Ending radius of the particles. Only available in 'Radius' mode. + !#zh 结束半径,只有在半径模式下可用。 */ + endRadius: number; + /** !#en Variation of the ending radius. + !#zh 结束半径变化范围。 */ + endRadiusVar: number; + /** !#en Number of degress to rotate a particle around the source pos per second. Only available in 'Radius' mode. + !#zh 粒子每秒围绕起始点的旋转角度,只有在半径模式下可用。 */ + rotatePerS: number; + /** !#en Variation of the degress to rotate a particle around the source pos per second. + !#zh 粒子每秒围绕起始点的旋转角度变化范围。 */ + rotatePerSVar: number; + /** !#en The Particle emitter lives forever. + !#zh 表示发射器永久存在 */ + static DURATION_INFINITY: number; + /** !#en The starting size of the particle is equal to the ending size. + !#zh 表示粒子的起始大小等于结束大小。 */ + static START_SIZE_EQUAL_TO_END_SIZE: number; + /** !#en The starting radius of the particle is equal to the ending radius. + !#zh 表示粒子的起始半径等于结束半径。 */ + static START_RADIUS_EQUAL_TO_END_RADIUS: number; + /** + !#en Add a particle to the emitter. + !#zh 添加一个粒子到发射器中。 + */ + addParticle(): boolean; + /** + !#en Stop emitting particles. Running particles will continue to run until they die. + !#zh 停止发射器发射粒子,发射出去的粒子将继续运行,直至粒子生命结束。 + + @example + ```js + // stop particle system. + myParticleSystem.stopSystem(); + ``` + */ + stopSystem(): void; + /** + !#en Kill all living particles. + !#zh 杀死所有存在的粒子,然后重新启动粒子发射器。 + + @example + ```js + // play particle system. + myParticleSystem.resetSystem(); + ``` + */ + resetSystem(): void; + /** + !#en Whether or not the system is full. + !#zh 发射器中粒子是否大于等于设置的总粒子数量。 + */ + isFull(): boolean; + /** + !#en +

Sets a new CCSpriteFrame as particle.
+ WARNING: this method is experimental. Use setTextureWithRect instead. +

+ !#zh +

设置一个新的精灵帧为粒子。
+ 警告:这个函数只是试验,请使用 setTextureWithRect 实现。 +

+ @param spriteFrame spriteFrame + */ + setDisplayFrame(spriteFrame: SpriteFrame): void; + /** + !#en Sets a new texture with a rect. The rect is in texture position and size. + !#zh 设置一张新贴图和关联的矩形。 + @param texture texture + @param rect rect + */ + setTextureWithRect(texture: Texture2D, rect: Rect): void; + } + /** !#en Renders the TMX object. + !#zh 渲染 tmx object。 */ + export class TMXObject { + /** + !#en Get the name of object + !#zh 获取对象的名称 + */ + getObjectName(): string; + /** + !#en Get the property of object + !#zh 获取对象的属性 + */ + getProperty(): any; + /** + !#en Get the properties of object + !#zh 获取对象的属性 + */ + getProperties(): any; + /** + !#en Set the object name + !#zh 设置对象名称 + @param name name + */ + setObjectName(name: string): void; + /** + !#en Set the properties of the object + !#zh 设置对象的属性 + @param props props + */ + setProperties(props: any): void; + } + /** !#en Render the TMX layer. + !#zh 渲染 TMX layer。 */ + export class TiledLayer extends _SGComponent { + /** + !#en Gets the layer name. + !#zh 获取层的名称。 + + @example + ```js + var layerName = tiledLayer.getLayerName(); + cc.log(layerName); + ``` + */ + getLayerName(): string; + /** + !#en Set the layer name. + !#zh 设置层的名称 + @param layerName layerName + + @example + ```js + tiledLayer.setLayerName("New Layer"); + ``` + */ + SetLayerName(layerName: string): void; + /** + !#en Return the value for the specific property name. + !#zh 获取指定属性名的值。 + @param propertyName propertyName + + @example + ```js + var property = tiledLayer.getProperty("info"); + cc.log(property); + ``` + */ + getProperty(propertyName: string): any; + /** + !#en Returns the position in pixels of a given tile coordinate. + !#zh 获取指定 tile 的像素坐标。 + @param pos position or x + @param y y + + @example + ```js + var pos = tiledLayer.getPositionAt(cc.v2(0, 0)); + cc.log("Pos: " + pos); + var pos = tiledLayer.getPositionAt(0, 0); + cc.log("Pos: " + pos); + ``` + */ + getPositionAt(pos: Vec2|number, y?: number): Vec2; + /** + !#en Removes a tile at given tile coordinate. + !#zh 删除指定坐标上的 tile。 + @param pos position or x + @param y y + + @example + ```js + tiledLayer.removeTileAt(cc.v2(0, 0)); + tiledLayer.removeTileAt(0, 0); + ``` + */ + removeTileAt(pos: Vec2|number, y?: number): void; + /** + !#en + Sets the tile gid (gid = tile global id) at a given tile coordinate.
+ The Tile GID can be obtained by using the method "tileGIDAt" or by using the TMX editor . Tileset Mgr +1.
+ If a tile is already placed at that position, then it will be removed. + !#zh + 设置给定坐标的 tile 的 gid (gid = tile 全局 id), + tile 的 GID 可以使用方法 “tileGIDAt” 来获得。
+ 如果一个 tile 已经放在那个位置,那么它将被删除。 + @param gid gid + @param posOrX position or x + @param flagsOrY flags or y + @param flags flags + + @example + ```js + tiledLayer.setTileGID(1001, 10, 10, 1) + ``` + */ + setTileGID(gid: number, posOrX: Vec2|number, flagsOrY: number, flags?: number): void; + /** + !#en + Returns the tile gid at a given tile coordinate.
+ if it returns 0, it means that the tile is empty.
+ This method requires the the tile map has not been previously released (eg. don't call layer.releaseMap())
+ !#zh + 通过给定的 tile 坐标、flags(可选)返回 tile 的 GID.
+ 如果它返回 0,则表示该 tile 为空。
+ 该方法要求 tile 地图之前没有被释放过(如:没有调用过layer.releaseMap()). + @param pos or x + @param y y + + @example + ```js + var tileGid = tiledLayer.getTileGIDAt(0, 0); + ``` + */ + getTileGIDAt(pos: Vec2|number, y?: number): number; + /** + !#en + Returns the tile (_ccsg.Sprite) at a given a tile coordinate.
+ The returned _ccsg.Sprite will be already added to the _ccsg.TMXLayer. Don't add it again.
+ The _ccsg.Sprite can be treated like any other _ccsg.Sprite: rotated, scaled, translated, opacity, color, etc.
+ You can remove either by calling:
+ - layer.removeChild(sprite, cleanup);
+ - or layer.removeTileAt(ccp(x,y)); + !#zh + 通过指定的 tile 坐标获取对应的 tile(Sprite)。 返回的 tile(Sprite) 应是已经添加到 TMXLayer,请不要重复添加。
+ 这个 tile(Sprite) 如同其他的 Sprite 一样,可以旋转、缩放、翻转、透明化、设置颜色等。
+ 你可以通过调用以下方法来对它进行删除:
+ 1. layer.removeChild(sprite, cleanup);
+ 2. 或 layer.removeTileAt(cc.v2(x,y)); + @param pos or x + @param y y + + @example + ```js + var title = tiledLayer.getTileAt(100, 100); + cc.log(title); + ``` + */ + getTileAt(pos: Vec2|number, y?: number): _ccsg.Sprite; + /** + !#en + Dealloc the map that contains the tile position from memory.
+ Unless you want to know at runtime the tiles positions, you can safely call this method.
+ If you are going to call layer.getTileGIDAt() then, don't release the map. + !#zh + 从内存中释放包含 tile 位置信息的地图。
+ 除了在运行时想要知道 tiles 的位置信息外,你都可安全的调用此方法。
+ 如果你之后还要调用 layer.tileGIDAt(), 请不要释放地图. + + @example + ```js + tiledLayer.releaseMap(); + ``` + */ + releaseMap(): void; + /** + !#en Sets the untransformed size of the _ccsg.TMXLayer. + !#zh 设置未转换的 layer 大小。 + @param size The untransformed size of the _ccsg.TMXLayer or The untransformed size's width of the TMXLayer. + @param height The untransformed size's height of the _ccsg.TMXLayer. + + @example + ```js + tiledLayer.setContentSize(100, 100); + ``` + */ + setContentSize(size: Size|number, height?: number): void; + /** + !#en Return texture of cc.SpriteBatchNode. + !#zh 获取纹理。 + + @example + ```js + var texture = tiledLayer.getTexture(); + cc.log("Texture: " + texture); + ``` + */ + getTexture(): Texture2D; + /** + !#en Set the texture of cc.SpriteBatchNode. + !#zh 设置纹理。 + @param texture texture + + @example + ```js + tiledLayer.setTexture(texture); + ``` + */ + setTexture(texture: Texture2D): void; + /** + !#en Set the opacity of all tiles + !#zh 设置所有 Tile 的透明度 + @param opacity opacity + + @example + ```js + tiledLayer.setTileOpacity(128); + ``` + */ + setTileOpacity(opacity: number): void; + /** + !#en Gets layer size. + !#zh 获得层大小。 + + @example + ```js + var size = tiledLayer.getLayerSize(); + cc.log("layer size: " + size); + ``` + */ + getLayerSize(): Size; + /** + !#en Set layer size. + !#zh 设置层大小。 + @param layerSize layerSize + + @example + ```js + tiledLayer.setLayerSize(new cc.size(5, 5)); + ``` + */ + setLayerSize(layerSize: Size): void; + /** + !#en Size of the map's tile (could be different from the tile's size). + !#zh 获取 tile 的大小( tile 的大小可能会有所不同)。 + + @example + ```js + var mapTileSize = tiledLayer.getMapTileSize(); + cc.log("MapTile size: " + mapTileSize); + ``` + */ + getMapTileSize(): Size; + /** + !#en Set the map tile size. + !#zh 设置 tile 的大小。 + @param tileSize tileSize + + @example + ```js + tiledLayer.setMapTileSize(new cc.size(10, 10)); + ``` + */ + setMapTileSize(tileSize: Size): void; + /** + !#en Pointer to the map of tiles. + !#zh 获取地图 tiles。 + + @example + ```js + var tiles = tiledLayer.getTiles(); + ``` + */ + getTiles(): any[]; + /** + !#en Pointer to the map of tiles. + !#zh 设置地图 tiles + @param tiles tiles + + @example + ```js + tiledLayer.setTiles(tiles); + ``` + */ + setTiles(tiles: any[]): void; + /** + !#en Tile set information for the layer. + !#zh 获取 layer 的 Tileset 信息。 + + @example + ```js + var tileset = tiledLayer.getTileSet(); + ``` + */ + getTileSet(): TMXTilesetInfo; + /** + !#en Tile set information for the layer. + !#zh 设置 layer 的 Tileset 信息。 + @param tileset tileset + + @example + ```js + tiledLayer.setTileSet(tileset); + ``` + */ + setTileSet(tileset: TMXTilesetInfo): void; + /** + !#en Layer orientation, which is the same as the map orientation. + !#zh 获取 Layer 方向(同地图方向)。 + + @example + ```js + var orientation = tiledLayer.getLayerOrientation(); + cc.log("Layer Orientation: " + orientation); + ``` + */ + getLayerOrientation(): number; + /** + !#en Layer orientation, which is the same as the map orientation. + !#zh 设置 Layer 方向(同地图方向)。 + @param orientation orientation + + @example + ```js + tiledLayer.setLayerOrientation(TiledMap.Orientation.ORTHO); + ``` + */ + setLayerOrientation(orientation: TiledMap.Orientation): void; + /** + !#en properties from the layer. They can be added using Tiled. + !#zh 获取 layer 的属性,可以使用 Tiled 编辑器添加属性。 + + @example + ```js + var properties = tiledLayer.getProperties(); + cc.log("Properties: " + properties); + ``` + */ + getProperties(): any[]; + /** + !#en properties from the layer. They can be added using Tiled. + !#zh 设置层属性。 + @param properties properties + + @example + ```js + tiledLayer.setLayerOrientation(properties); + ``` + */ + setProperties(properties: any[]): void; + } + /** !#en Renders a TMX Tile Map in the scene. + !#zh 在场景中渲染一个 tmx 格式的 Tile Map。 */ + export class TiledMap extends Component { + /** !#en The TiledMap Asset. + !#zh TiledMap 资源。 */ + tmxAsset: TiledMapAsset; + /** + !#en Gets the map size. + !#zh 获取地图大小。 + + @example + ```js + var mapSize = tiledMap.getMapSize(); + cc.log("Map Size: " + mapSize); + ``` + */ + getMapSize(): Size; + /** + !#en Set the map size. + !#zh 设置地图大小。 + @param mapSize mapSize + + @example + ```js + tiledMap.setMapSize(new cc.size(960, 640)); + ``` + */ + setMapSize(mapSize: Size): void; + /** + !#en Gets the tile size. + !#zh 获取地图背景中 tile 元素的大小。 + + @example + ```js + var tileSize = tiledMap.getTileSize(); + cc.log("Tile Size: " + tileSize); + ``` + */ + getTileSize(): Size; + /** + !#en Set the tile size. + !#zh 设置地图背景中 tile 元素的大小。 + @param tileSize tileSize + + @example + ```js + tiledMap.setTileSize(new cc.size(10, 10)); + ``` + */ + setTileSize(tileSize: Size): void; + /** + !#en map orientation. + !#zh 获取地图方向。 + + @example + ```js + var mapOrientation = tiledMap.getMapOrientation(); + cc.log("Map Orientation: " + mapOrientation); + ``` + */ + getMapOrientation(): number; + /** + !#en map orientation. + !#zh 设置地图方向。 + @param orientation orientation + + @example + ```js + tiledMap.setMapOrientation(TiledMap.Orientation.ORTHO); + ``` + */ + setMapOrientation(orientation: TiledMap.Orientation): void; + /** + !#en object groups. + !#zh 获取所有的对象层。 + + @example + ```js + var objGroups = titledMap.getObjectGroups(); + for (var i = 0; i < objGroups.length; ++i) { + cc.log("obj: " + objGroups[i]); + } + ``` + */ + getObjectGroups(): TiledObjectGroup[]; + /** + !#en Gets the map properties. + !#zh 获取地图的属性。 + + @example + ```js + var properties = titledMap.getProperties(); + for (var i = 0; i < properties.length; ++i) { + cc.log("Properties: " + properties[i]); + } + ``` + */ + getProperties(): any[]; + /** + !#en Set the map properties. + !#zh 设置地图的属性。 + @param properties properties + + @example + ```js + titledMap.setProperties(properties); + ``` + */ + setProperties(properties: any[]): void; + /** + !#en Return All layers array. + !#zh 返回包含所有 layer 的数组。 + + @example + ```js + var layers = titledMap.allLayers(); + for (var i = 0; i < layers.length; ++i) { + cc.log("Layers: " + layers[i]); + } + ``` + */ + allLayers(): TiledLayer[]; + /** + !#en return the cc.TiledLayer for the specific layer. + !#zh 获取指定名称的 layer。 + @param layerName layerName + + @example + ```js + var layer = titledMap.getLayer("Player"); + cc.log(layer); + ``` + */ + getLayer(layerName: string): TiledLayer; + /** + !#en Return the TMXObjectGroup for the specific group. + !#zh 获取指定的 TMXObjectGroup。 + @param groupName groupName + + @example + ```js + var group = titledMap.getObjectGroup("Players"); + cc.log("ObjectGroup: " + group); + ``` + */ + getObjectGroup(groupName: string): TiledObjectGroup; + /** + !#en Return the value for the specific property name. + !#zh 通过属性名称,获取指定的属性。 + @param propertyName propertyName + + @example + ```js + var property = titledMap.getProperty("info"); + cc.log("Property: " + property); + ``` + */ + getProperty(propertyName: string): string; + /** + !#en Return properties dictionary for tile GID. + !#zh 通过 GID ,获取指定的属性。 + @param GID GID + + @example + ```js + var properties = titledMap.getPropertiesForGID(GID); + cc.log("Properties: " + properties); + ``` + */ + getPropertiesForGID(GID: number): any; + } + /** !#en Renders the TMX object group. + !#zh 渲染 tmx object group。 */ + export class TiledObjectGroup extends _SGComponent { + /** + !#en Offset position of child objects. + !#zh 获取子对象的偏移位置。 + + @example + ```js + var offset = tMXObjectGroup.getPositionOffset(); + ``` + */ + getPositionOffset(): Vec2; + /** + !#en Offset position of child objects. + !#zh 设置子对象的偏移位置。 + @param offset offset + + @example + ```js + tMXObjectGroup.setPositionOffset(cc.v2(5, 5)); + ``` + */ + setPositionOffset(offset: Vec2): void; + /** + !#en List of properties stored in a dictionary. + !#zh 以映射的形式获取属性列表。 + + @example + ```js + var offset = tMXObjectGroup.getProperties(); + ``` + */ + getProperties(): any; + /** + !#en Set the properties of the object group. + !#zh 设置属性列表。 + @param Var Var + + @example + ```js + tMXObjectGroup.setProperties(obj); + ``` + */ + setProperties(Var: any): void; + /** + !#en Gets the Group name. + !#zh 获取组名称。 + + @example + ```js + var groupName = tMXObjectGroup.getGroupName; + ``` + */ + getGroupName(): string; + /** + !#en Set the Group name. + !#zh 设置组名称。 + @param groupName groupName + + @example + ```js + tMXObjectGroup.setGroupName("New Group"); + ``` + */ + setGroupName(groupName: string): void; + /** + !#en + Return the object for the specific object name.
+ It will return the 1st object found on the array for the given name. + !#zh 获取指定的对象。 + @param objectName objectName + + @example + ```js + var object = tMXObjectGroup.getObject("Group"); + ``` + */ + getObject(objectName: string): any; + /** + !#en Gets the objects. + !#zh 获取对象数组。 + + @example + ```js + var objects = tMXObjectGroup.getObjects(); + ``` + */ + getObjects(): any[]; + } + /** Class for tiled map asset handling. */ + export class TiledMapAsset extends Asset { + } + /** !#en +

+ ATTENTION: USE cc.director INSTEAD OF cc.Director.
+ cc.director is a singleton object which manage your game's logic flow.
+ Since the cc.director is a singleton, you don't need to call any constructor or create functions,
+ the standard way to use it is by calling:
+ - cc.director.methodName();
+ + It creates and handle the main Window and manages how and when to execute the Scenes.
+
+ The cc.director is also responsible for:
+ - initializing the OpenGL context
+ - setting the OpenGL pixel format (default on is RGB565)
+ - setting the OpenGL buffer depth (default on is 0-bit)
+ - setting the color for clear screen (default one is BLACK)
+ - setting the projection (default one is 3D)
+ - setting the orientation (default one is Portrait)
+
+
+ The cc.director also sets the default OpenGL context:
+ - GL_TEXTURE_2D is enabled
+ - GL_VERTEX_ARRAY is enabled
+ - GL_COLOR_ARRAY is enabled
+ - GL_TEXTURE_COORD_ARRAY is enabled
+

+

+ cc.director also synchronizes timers with the refresh rate of the display.
+ Features and Limitations:
+ - Scheduled timers & drawing are synchronizes with the refresh rate of the display
+ - Only supports animation intervals of 1/60 1/30 & 1/15
+

+ + !#zh +

+ 注意:用 cc.director 代替 cc.Director。
+ cc.director 一个管理你的游戏的逻辑流程的单例对象。
+ 由于 cc.director 是一个单例,你不需要调用任何构造函数或创建函数,
+ 使用它的标准方法是通过调用:
+ - cc.director.methodName(); +
+ 它创建和处理主窗口并且管理什么时候执行场景。
+
+ cc.director 还负责:
+ - 初始化 OpenGL 环境。
+ - 设置OpenGL像素格式。(默认是 RGB565)
+ - 设置OpenGL缓冲区深度 (默认是 0-bit)
+ - 设置空白场景的颜色 (默认是 黑色)
+ - 设置投影 (默认是 3D)
+ - 设置方向 (默认是 Portrait)
+
+ cc.director 设置了 OpenGL 默认环境
+ - GL_TEXTURE_2D 启用。
+ - GL_VERTEX_ARRAY 启用。
+ - GL_COLOR_ARRAY 启用。
+ - GL_TEXTURE_COORD_ARRAY 启用。
+

+

+ cc.director 也同步定时器与显示器的刷新速率。 +
+ 特点和局限性:
+ - 将计时器 & 渲染与显示器的刷新频率同步。
+ - 只支持动画的间隔 1/60 1/30 & 1/15。
+

*/ + export class Director extends EventTarget { + /** + !#en + Converts an OpenGL coordinate to a view coordinate
+ Useful to convert node points to window points for calls such as glScissor
+ Implementation can be found in CCDirectorWebGL. + !#zh 将触摸点的 WebGL View 坐标转换为屏幕坐标。 + @param glPoint glPoint + */ + convertToUI(glPoint: Vec2): Vec2; + /** + !#en + Returns the size of the WebGL view in points.
+ It takes into account any possible rotation (device orientation) of the window. + !#zh 获取视图的大小,以点为单位。 + */ + getWinSize(): Size; + /** + !#en + Returns the size of the OpenGL view in pixels.
+ It takes into account any possible rotation (device orientation) of the window.
+ On Mac winSize and winSizeInPixels return the same value. + !#zh 获取视图大小,以像素为单位。 + */ + getWinSizeInPixels(): Size; + /** + !#en Returns the visible size of the running scene. + !#zh 获取运行场景的可见大小。 + */ + getVisibleSize(): Size; + /** + !#en Returns the visible origin of the running scene. + !#zh 获取视图在游戏内容中的坐标原点。 + */ + getVisibleOrigin(): Vec2; + /** + !#en Pause the director's ticker, only involve the game logic execution. + It won't pause the rendering process nor the event manager. + If you want to pause the entier game including rendering, audio and event, + please use {{#crossLink "Game.pause"}}cc.game.pause{{/crossLink}} + !#zh 暂停正在运行的场景,该暂停只会停止游戏逻辑执行,但是不会停止渲染和 UI 响应。 + 如果想要更彻底得暂停游戏,包含渲染,音频和事件,请使用 {{#crossLink "Game.pause"}}cc.game.pause{{/crossLink}}。 + */ + pause(): void; + /** + !#en + Run a scene. Replaces the running scene with a new one or enter the first scene.
+ The new scene will be launched immediately. + !#zh 立刻切换指定场景。 + @param scene The need run scene. + @param onBeforeLoadScene The function invoked at the scene before loading. + @param onLaunched The function invoked at the scene after launch. + */ + runSceneImmediate(scene: Scene, onBeforeLoadScene?: Function, onLaunched?: Function): void; + /** + !#en Loads the scene by its name. + !#zh 通过场景名称进行加载场景。 + @param sceneName The name of the scene to load. + @param onLaunched callback, will be called after scene launched. + */ + loadScene(sceneName: string, onLaunched?: Function): boolean; + /** + !#en + Preloads the scene to reduces loading time. You can call this method at any time you want. + After calling this method, you still need to launch the scene by `cc.director.loadScene`. + It will be totally fine to call `cc.director.loadScene` at any time even if the preloading is not + yet finished, the scene will be launched after loaded automatically. + !#zh 预加载场景,你可以在任何时候调用这个方法。 + 调用完后,你仍然需要通过 `cc.director.loadScene` 来启动场景,因为这个方法不会执行场景加载操作。 + 就算预加载还没完成,你也可以直接调用 `cc.director.loadScene`,加载完成后场景就会启动。 + @param sceneName The name of the scene to preload. + @param onLoaded callback, will be called after scene loaded. + */ + preloadScene(sceneName: string, onLoaded?: (error: Error) => void): void; + /** + !#en Resume game logic execution after pause, if the current scene is not paused, nothing will happen. + !#zh 恢复暂停场景的游戏逻辑,如果当前场景没有暂停将没任何事情发生。 + */ + resume(): void; + /** + !#en + Enables or disables WebGL depth test.
+ Implementation can be found in CCDirectorCanvas.js/CCDirectorWebGL.js + !#zh 启用/禁用深度测试(在 Canvas 渲染模式下不会生效)。 + @param on on + */ + setDepthTest(on: boolean): void; + /** + !#en + Set color for clear screen.
+ (Implementation can be found in CCDirectorCanvas.js/CCDirectorWebGL.js) + !#zh + 设置场景的默认擦除颜色。
+ 支持全透明,但不支持透明度为中间值。要支持全透明需手工开启 cc.macro.ENABLE_TRANSPARENT_CANVAS。 + @param clearColor clearColor + */ + setClearColor(clearColor: Color): void; + /** + !#en + Sets an OpenGL projection.
+ Implementation can be found in CCDirectorCanvas.js/CCDirectorWebGL.js. + !#zh 设置 OpenGL 投影。 + @param projection projection + */ + setProjection(projection: number): void; + /** + !#en + Update the view port.
+ Implementation can be found in CCDirectorCanvas.js/CCDirectorWebGL.js. + !#zh 设置视窗(请不要主动调用这个接口,除非你知道你在做什么)。 + */ + setViewport(): void; + /** + !#en + Sets an OpenGL projection.
+ Implementation can be found in CCDirectorCanvas.js/CCDirectorWebGL.js. + !#zh 获取 OpenGL 投影。 + */ + getProjection(): number; + /** + !#en + Enables/disables OpenGL alpha blending.
+ Implementation can be found in CCDirectorCanvas.js/CCDirectorWebGL.js. + !#zh 启用/禁用 透明度融合。 + @param on on + */ + setAlphaBlending(on: boolean): void; + /** + !#en + Returns whether or not the replaced scene will receive the cleanup message.
+ If the new scene is pushed, then the old scene won't receive the "cleanup" message.
+ If the new scene replaces the old one, the it will receive the "cleanup" message. + !#zh + 更换场景时是否接收清理消息。
+ 如果新场景是采用 push 方式进入的,那么旧的场景将不会接收到 “cleanup” 消息。
+ 如果新场景取代旧的场景,它将会接收到 “cleanup” 消息。
+ */ + isSendCleanupToScene(): boolean; + /** + !#en Returns current logic Scene. + !#zh 获取当前逻辑场景。 + + @example + ```js + // This will help you to get the Canvas node in scene + cc.director.getScene().getChildByName('Canvas'); + ``` + */ + getScene(): Scene; + /** + !#en Returns the FPS value. + !#zh 获取单位帧执行时间。 + */ + getAnimationInterval(): number; + /** + !#en Returns whether or not to display the FPS informations. + !#zh 获取是否显示 FPS 信息。 + */ + isDisplayStats(): boolean; + /** + !#en Sets whether display the FPS on the bottom-left corner. + !#zh 设置是否在左下角显示 FPS。 + @param displayStats displayStats + */ + setDisplayStats(displayStats: boolean): void; + /** + !#en Returns whether next delta time equals to zero. + !#zh 返回下一个 “delta time” 是否等于零。 + */ + isNextDeltaTimeZero(): boolean; + /** + !#en Returns whether or not the Director is paused. + !#zh 是否处于暂停状态。 + */ + isPaused(): boolean; + /** + !#en Returns how many frames were called since the director started. + !#zh 获取 director 启动以来游戏运行的总帧数。 + */ + getTotalFrames(): number; + /** + !#en Returns the cc.Scheduler associated with this director. + !#zh 获取和 director 相关联的 cc.Scheduler。 + */ + getScheduler(): Scheduler; + /** + !#en Sets the cc.Scheduler associated with this director. + !#zh 设置和 director 相关联的 cc.Scheduler。 + @param scheduler scheduler + */ + setScheduler(scheduler: Scheduler): void; + /** + !#en Returns the cc.ActionManager associated with this director. + !#zh 获取和 director 相关联的 cc.ActionManager(动作管理器)。 + */ + getActionManager(): ActionManager; + /** + !#en Sets the cc.ActionManager associated with this director. + !#zh 设置和 director 相关联的 cc.ActionManager(动作管理器)。 + @param actionManager actionManager + */ + setActionManager(actionManager: ActionManager): void; + /** + Returns the cc.CollisionManager associated with this director. + */ + getCollisionManager(): CollisionManager; + /** + Returns the cc.PhysicsManager associated with this director. + */ + getPhysicsManager(): PhysicsManager; + /** + !#en Returns the delta time since last frame. + !#zh 获取上一帧的 “delta time”。 + */ + getDeltaTime(): number; + /** !#en The event projection changed of cc.Director. + !#zh cc.Director 投影变化的事件。 */ + static EVENT_PROJECTION_CHANGED: string; + /** !#en The event which will be triggered before loading a new scene. + !#zh 加载新场景之前所触发的事件。 */ + static EVENT_BEFORE_SCENE_LOADING: string; + /** !#en The event which will be triggered before launching a new scene. + !#zh 运行新场景之前所触发的事件。 */ + static EVENT_BEFORE_SCENE_LAUNCH: string; + /** !#en The event which will be triggered after launching a new scene. + !#zh 运行新场景之后所触发的事件。 */ + static EVENT_AFTER_SCENE_LAUNCH: string; + /** !#en The event which will be triggered at the beginning of every frame. + !#zh 每个帧的开始时所触发的事件。 */ + static EVENT_BEFORE_UPDATE: string; + /** !#en The event which will be triggered after engine and components update logic. + !#zh 将在引擎和组件 “update” 逻辑之后所触发的事件。 */ + static EVENT_AFTER_UPDATE: string; + /** !#en The event which will be triggered before visiting the rendering scene graph. + !#zh 访问渲染场景树之前所触发的事件。 */ + static EVENT_BEFORE_VISIT: string; + /** !#en + The event which will be triggered after visiting the rendering scene graph, + the render queue is ready but not rendered at this point. + !#zh + 访问渲染场景图之后所触发的事件,渲染队列已准备就绪,但在这一时刻还没有呈现在画布上。 */ + static EVENT_AFTER_VISIT: string; + /** !#en The event which will be triggered after the rendering process. + !#zh 渲染过程之后所触发的事件。 */ + static EVENT_AFTER_DRAW: string; + /** Constant for 2D projection (orthogonal projection) */ + static PROJECTION_2D: number; + /** Constant for 3D projection with a fovy=60, znear=0.5f and zfar=1500. */ + static PROJECTION_3D: number; + /** Constant for custom projection, if cc.Director's projection set to it, it calls "updateProjection" on the projection delegate. */ + static PROJECTION_CUSTOM: number; + /** Constant for default projection of cc.Director, default projection is 2D projection */ + static PROJECTION_DEFAULT: number; + } + /** !#en cc.game is the singleton object for game related functions. + !#zh cc.game 是 Game 的实例,用来驱动整个游戏。 */ + export class Game extends EventTarget { + /** !#en Event triggered when game hide to background. + Please note that this event is not 100% guaranteed to be fired on Web platform, + on native platforms, it corresponds to enter background event, os status bar or notification center may not trigger this event. + !#zh 游戏进入后台时触发的事件。 + 请注意,在 WEB 平台,这个事件不一定会 100% 触发,这完全取决于浏览器的回调行为。 + 在原生平台,它对应的是应用被切换到后台事件,下拉菜单和上拉状态栏等不一定会触发这个事件,这取决于系统行为。 */ + EVENT_HIDE: string; + /** Event triggered when game back to foreground + Please note that this event is not 100% guaranteed to be fired on Web platform, + on native platforms, it corresponds to enter foreground event. + !#zh 游戏进入前台运行时触发的事件。 + 请注意,在 WEB 平台,这个事件不一定会 100% 触发,这完全取决于浏览器的回调行为。 + 在原生平台,它对应的是应用被切换到前台事件。 */ + EVENT_SHOW: string; + /** Event triggered after game inited, at this point all engine objects and game scripts are loaded */ + EVENT_GAME_INITED: string; + /** Event triggered after renderer inited, at this point you will be able to use the render context */ + EVENT_RENDERER_INITED: string; + /** Key of config */ + CONFIG_KEY: any; + /** !#en The outer frame of the game canvas, parent of cc.container. + !#zh 游戏画布的外框,cc.container 的父类。 */ + frame: any; + /** !#en The container of game canvas, equals to cc.container. + !#zh 游戏画布的容器。 */ + container: HTMLDivElement; + /** !#en The canvas of the game, equals to cc._canvas. + !#zh 游戏的画布。 */ + canvas: HTMLCanvasElement; + /** !#en + The current game configuration, including:
+ 1. debugMode
+ "debugMode" possible values :
+ 0 - No message will be printed.
+ 1 - cc.error, cc.assert, cc.warn, cc.log will print in console.
+ 2 - cc.error, cc.assert, cc.warn will print in console.
+ 3 - cc.error, cc.assert will print in console.
+ 4 - cc.error, cc.assert, cc.warn, cc.log will print on canvas, available only on web.
+ 5 - cc.error, cc.assert, cc.warn will print on canvas, available only on web.
+ 6 - cc.error, cc.assert will print on canvas, available only on web.
+ 2. showFPS
+ Left bottom corner fps information will show when "showFPS" equals true, otherwise it will be hide.
+ 3. exposeClassName
+ Expose class name to chrome debug tools, the class intantiate performance is a little bit slower when exposed.
+ 4. frameRate
+ "frameRate" set the wanted frame rate for your game, but the real fps depends on your game implementation and the running environment.
+ 5. id
+ "gameCanvas" sets the id of your canvas element on the web page, it's useful only on web.
+ 6. renderMode
+ "renderMode" sets the renderer type, only useful on web :
+ 0 - Automatically chosen by engine
+ 1 - Forced to use canvas renderer
+ 2 - Forced to use WebGL renderer, but this will be ignored on mobile browsers
+ 7. scenes
+ "scenes" include available scenes in the current bundle.
+
+ Please DO NOT modify this object directly, it won't have any effect.
+ !#zh + 当前的游戏配置,包括:
+ 1. debugMode(debug 模式,但是在浏览器中这个选项会被忽略)
+ "debugMode" 各种设置选项的意义。
+ 0 - 没有消息被打印出来。
+ 1 - cc.error,cc.assert,cc.warn,cc.log 将打印在 console 中。
+ 2 - cc.error,cc.assert,cc.warn 将打印在 console 中。
+ 3 - cc.error,cc.assert 将打印在 console 中。
+ 4 - cc.error,cc.assert,cc.warn,cc.log 将打印在 canvas 中(仅适用于 web 端)。
+ 5 - cc.error,cc.assert,cc.warn 将打印在 canvas 中(仅适用于 web 端)。
+ 6 - cc.error,cc.assert 将打印在 canvas 中(仅适用于 web 端)。
+ 2. showFPS(显示 FPS)
+ 当 showFPS 为 true 的时候界面的左下角将显示 fps 的信息,否则被隐藏。
+ 3. exposeClassName
+ 暴露类名让 Chrome DevTools 可以识别,如果开启会稍稍降低类的创建过程的性能,但对对象构造没有影响。
+ 4. frameRate (帧率)
+ “frameRate” 设置想要的帧率你的游戏,但真正的FPS取决于你的游戏实现和运行环境。
+ 5. id
+ "gameCanvas" Web 页面上的 Canvas Element ID,仅适用于 web 端。
+ 6. renderMode(渲染模式)
+ “renderMode” 设置渲染器类型,仅适用于 web 端:
+ 0 - 通过引擎自动选择。
+ 1 - 强制使用 canvas 渲染。 + 2 - 强制使用 WebGL 渲染,但是在部分 Android 浏览器中这个选项会被忽略。
+ 7. scenes
+ “scenes” 当前包中可用场景。
+
+ 注意:请不要直接修改这个对象,它不会有任何效果。 */ + config: any; + /** + !#en Callback when the scripts of engine have been load. + !#zh 当引擎完成启动后的回调函数。 + */ + onStart(): void; + /** + !#en Set frameRate of game. + !#zh 设置游戏帧率。 + @param frameRate frameRate + */ + setFrameRate(frameRate: number): void; + /** + !#en Run the game frame by frame. + !#zh 执行一帧游戏循环。 + */ + step(): void; + /** + !#en Pause the game main loop. This will pause: + game logic execution, rendering process, event manager, background music and all audio effects. + This is different with cc.director.pause which only pause the game logic execution. + !#zh 暂停游戏主循环。包含:游戏逻辑,渲染,事件处理,背景音乐和所有音效。这点和只暂停游戏逻辑的 cc.director.pause 不同。 + */ + pause(): void; + /** + !#en Resume the game from pause. This will resume: + game logic execution, rendering process, event manager, background music and all audio effects. + !#zh 恢复游戏主循环。包含:游戏逻辑,渲染,事件处理,背景音乐和所有音效。 + */ + resume(): void; + /** + !#en Check whether the game is paused. + !#zh 判断游戏是否暂停。 + */ + isPaused(): boolean; + /** + !#en Restart game. + !#zh 重新开始游戏 + */ + restart(): void; + /** + !#en End game, it will close the game window + !#zh 退出游戏 + */ + end(): void; + /** + !#en Prepare game. + !#zh 准备引擎,请不要直接调用这个函数。 + @param cb cb + */ + prepare(cb: Function): void; + /** + !#en Run game with configuration object and onStart function. + !#zh 运行游戏,并且指定引擎配置和 onStart 的回调。 + @param config Pass configuration object or onStart function + @param onStart function to be executed after game initialized + */ + run(config?: any|Function, onStart?: Function): void; + /** + !#en + Add a persistent root node to the game, the persistent node won't be destroyed during scene transition.
+ The target node must be placed in the root level of hierarchy, otherwise this API won't have any effect. + !#zh + 声明常驻根节点,该节点不会被在场景切换中被销毁。
+ 目标节点必须位于为层级的根节点,否则无效。 + @param node The node to be made persistent + */ + addPersistRootNode(node: Node): void; + /** + !#en Remove a persistent root node. + !#zh 取消常驻根节点。 + @param node The node to be removed from persistent node list + */ + removePersistRootNode(node: Node): void; + /** + !#en Check whether the node is a persistent root node. + !#zh 检查节点是否是常驻根节点。 + @param node The node to be checked + */ + isPersistRootNode(node: Node): boolean; + } + /** !#en + Class of all entities in Cocos Creator scenes.
+ Node also inherits from {{#crossLink "EventTarget"}}Event Target{{/crossLink}}, it permits Node to dispatch events. + For events supported by Node, please refer to {{#crossLink "Node.EventType"}}{{/crossLink}} + !#zh + Cocos Creator 场景中的所有节点类。节点也继承了 {{#crossLink "EventTarget"}}EventTarget{{/crossLink}},它允许节点发送事件。
+ 支持的节点事件,请参阅 {{#crossLink "Node.EventType"}}{{/crossLink}}。 */ + export class Node extends _BaseNode { + /** !#en + Group index of node.
+ Which Group this node belongs to will resolve that this node's collision components can collide with which other collision componentns.
+ !#zh + 节点的分组索引。
+ 节点的分组将关系到节点的碰撞组件可以与哪些碰撞组件相碰撞。
*/ + groupIndex: number; + /** !#en + Group of node.
+ Which Group this node belongs to will resolve that this node's collision components can collide with which other collision componentns.
+ !#zh + 节点的分组。
+ 节点的分组将关系到节点的碰撞组件可以与哪些碰撞组件相碰撞。
*/ + group: string; + /** !#en The position (x, y) of the node in its parent's coordinates. + !#zh 节点在父节点坐标系中的位置(x, y)。 */ + position: Vec2; + /** !#en x axis position of node. + !#zh 节点 X 轴坐标。 */ + x: number; + /** !#en y axis position of node. + !#zh 节点 Y 轴坐标。 */ + y: number; + /** !#en Rotation of node. + !#zh 该节点旋转角度。 */ + rotation: number; + /** !#en Rotation on x axis. + !#zh 该节点 X 轴旋转角度。 */ + rotationX: number; + /** !#en Rotation on y axis. + !#zh 该节点 Y 轴旋转角度。 */ + rotationY: number; + /** !#en Scale on x axis. + !#zh 节点 X 轴缩放。 */ + scaleX: number; + /** !#en Scale on y axis. + !#zh 节点 Y 轴缩放。 */ + scaleY: number; + /** !#en Skew x + !#zh 该节点 Y 轴倾斜角度。 */ + skewX: number; + /** !#en Skew y + !#zh 该节点 X 轴倾斜角度。 */ + skewY: number; + /** !#en Opacity of node, default value is 255. + !#zh 节点透明度,默认值为 255。 */ + opacity: number; + /** !#en Indicate whether node's opacity value affect its child nodes, default value is true. + !#zh 节点的不透明度值是否影响其子节点,默认值为 true。 */ + cascadeOpacity: boolean; + /** !#en Color of node, default value is white: (255, 255, 255). + !#zh 节点颜色。默认为白色,数值为:(255,255,255)。 */ + color: Color; + /** !#en Anchor point's position on x axis. + !#zh 节点 X 轴锚点位置。 */ + anchorX: number; + /** !#en Anchor point's position on y axis. + !#zh 节点 Y 轴锚点位置。 */ + anchorY: number; + /** !#en Width of node. + !#zh 节点宽度。 */ + width: number; + /** !#en Height of node. + !#zh 节点高度。 */ + height: number; + /** !#en Z order in depth which stands for the drawing order. + !#zh 该节点渲染排序的 Z 轴深度。 */ + zIndex: number; + /** + + @param name name + */ + constructor(name?: string); + /** + !#en + Register a callback of a specific event type on Node.
+ Use this method to register touch or mouse event permit propagation based on scene graph, + you can propagate the event to the parents or swallow it by calling stopPropagation on the event.
+ It's the recommended way to register touch/mouse event for Node, + please do not use cc.eventManager directly for Node. + !#zh + 在节点上注册指定类型的回调函数,也可以设置 target 用于绑定响应函数的 this 对象。
+ 同时您可以将事件派发到父节点或者通过调用 stopPropagation 拦截它。
+ 推荐使用这种方式来监听节点上的触摸或鼠标事件,请不要在节点上直接使用 cc.eventManager。 + @param type A string representing the event type to listen for.
+ See {{#crossLink "Node/position-changed:event"}}Node Events{{/crossLink}} for all builtin events. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + this.node.on(cc.Node.EventType.TOUCH_START, this.memberFunction, this); // if "this" is component and the "memberFunction" declared in CCClass. + node.on(cc.Node.EventType.TOUCH_START, callback, this.node); + node.on(cc.Node.EventType.TOUCH_MOVE, callback, this.node); + node.on(cc.Node.EventType.TOUCH_END, callback, this.node); + node.on(cc.Node.EventType.TOUCH_CANCEL, callback, this.node); + node.on("anchor-changed", callback, this); + ``` + */ + on(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + on(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Removes the callback previously registered with the same type, callback, target and or useCapture. + This method is merely an alias to removeEventListener. + !#zh 删除之前与同类型,回调,目标或 useCapture 注册的回调。 + @param type A string representing the event type being removed. + @param callback The callback to remove. + @param target The target (this object) to invoke the callback, if it's not given, only callback without target will be removed + @param useCapture Specifies whether the callback being removed was registered as a capturing callback or not. + If not specified, useCapture defaults to false. If a callback was registered twice, + one with capture and one without, each must be removed separately. Removal of a capturing callback + does not affect a non-capturing version of the same listener, and vice versa. + + @example + ```js + this.node.off(cc.Node.EventType.TOUCH_START, this.memberFunction, this); + node.off(cc.Node.EventType.TOUCH_START, callback, this.node); + node.off("anchor-changed", callback, this); + ``` + */ + off(type: string, callback: Function, target?: any, useCapture?: boolean): void; + /** + !#en Removes all callbacks previously registered with the same target. + !#zh 移除目标上的所有注册事件。 + @param target The target to be searched for all related callbacks + + @example + ```js + node.targetOff(target); + ``` + */ + targetOff(target: any): void; + /** + !#en Pause node related system events registered with the current Node. Node system events includes touch and mouse events. + If recursive is set to true, then this API will pause the node system events for the node and all nodes in its sub node tree. + Reference: http://cocos2d-x.org/docs/editors_and_tools/creator-chapters/scripting/internal-events/ + !#zh 暂停当前节点上注册的所有节点系统事件,节点系统事件包含触摸和鼠标事件。 + 如果传递 recursive 为 true,那么这个 API 将暂停本节点和它的子树上所有节点的节点系统事件。 + 参考:http://cocos.com/docs/creator/scripting/internal-events.html + @param recursive Whether to pause node system events on the sub node tree. + + @example + ```js + node.pauseSystemEvents(true); + ``` + */ + pauseSystemEvents(recursive: boolean): void; + /** + !#en Resume node related system events registered with the current Node. Node system events includes touch and mouse events. + If recursive is set to true, then this API will resume the node system events for the node and all nodes in its sub node tree. + Reference: http://cocos2d-x.org/docs/editors_and_tools/creator-chapters/scripting/internal-events/ + !#zh 恢复当前节点上注册的所有节点系统事件,节点系统事件包含触摸和鼠标事件。 + 如果传递 recursive 为 true,那么这个 API 将恢复本节点和它的子树上所有节点的节点系统事件。 + 参考:http://cocos.com/docs/creator/scripting/internal-events.html + @param recursive Whether to resume node system events on the sub node tree. + + @example + ```js + node.resumeSystemEvents(true); + ``` + */ + resumeSystemEvents(recursive: boolean): void; + /** + !#en + Executes an action, and returns the action that is executed.
+ The node becomes the action's target. Refer to cc.Action's getTarget()
+ Calling runAction while the node is not active won't have any effect.
+ Note:You shouldn't modify the action after runAction, that won't take any effect.
+ if you want to modify, when you define action plus. + !#zh + 执行并返回该执行的动作。该节点将会变成动作的目标。
+ 调用 runAction 时,节点自身处于不激活状态将不会有任何效果。
+ 注意:你不应该修改 runAction 后的动作,将无法发挥作用,如果想进行修改,请在定义 action 时加入。 + @param action action + + @example + ```js + var action = cc.scaleTo(0.2, 1, 0.6); + node.runAction(action); + node.runAction(action).repeatForever(); // fail + node.runAction(action.repeatForever()); // right + ``` + */ + runAction(action: Action): Action; + /** + !#en Pause all actions running on the current node. Equals to `cc.director.getActionManager().pauseTarget(node)`. + !#zh 暂停本节点上所有正在运行的动作。和 `cc.director.getActionManager().pauseTarget(node);` 等价。 + + @example + ```js + node.pauseAllActions(); + ``` + */ + pauseAllActions(): void; + /** + !#en Resume all paused actions on the current node. Equals to `cc.director.getActionManager().resumeTarget(node)`. + !#zh 恢复运行本节点上所有暂停的动作。和 `cc.director.getActionManager().resumeTarget(node);` 等价。 + + @example + ```js + node.resumeAllActions(); + ``` + */ + resumeAllActions(): void; + /** + !#en Stops and removes all actions from the running action list . + !#zh 停止并且移除所有正在运行的动作列表。 + + @example + ```js + node.stopAllActions(); + ``` + */ + stopAllActions(): void; + /** + !#en Stops and removes an action from the running action list. + !#zh 停止并移除指定的动作。 + @param action An action object to be removed. + + @example + ```js + var action = cc.scaleTo(0.2, 1, 0.6); + node.stopAction(action); + ``` + */ + stopAction(action: Action): void; + /** + !#en Removes an action from the running action list by its tag. + !#zh 停止并且移除指定标签的动作。 + @param tag A tag that indicates the action to be removed. + + @example + ```js + node.stopAction(1); + ``` + */ + stopActionByTag(tag: number): void; + /** + !#en Returns an action from the running action list by its tag. + !#zh 通过标签获取指定动作。 + @param tag tag + + @example + ```js + var action = node.getActionByTag(1); + ``` + */ + getActionByTag(tag: number): Action; + /** + !#en + Returns the numbers of actions that are running plus the ones that are schedule to run (actions in actionsToAdd and actions arrays).
+ Composable actions are counted as 1 action. Example:
+ If you are running 1 Sequence of 7 actions, it will return 1.
+ If you are running 7 Sequences of 2 actions, it will return 7.

+ !#zh + 获取运行着的动作加上正在调度运行的动作的总数。
+ 例如:
+ - 如果你正在运行 7 个动作中的 1 个 Sequence,它将返回 1。
+ - 如果你正在运行 2 个动作中的 7 个 Sequence,它将返回 7。
+ + @example + ```js + var count = node.getNumberOfRunningActions(); + cc.log("Running Action Count: " + count); + ``` + */ + getNumberOfRunningActions(): number; + /** + !#en Returns a copy of the position (x, y) of the node in its parent's coordinates. + !#zh 获取节点在父节点坐标系中的位置(x, y)。 + + @example + ```js + cc.log("Node Position: " + node.getPosition()); + ``` + */ + getPosition(): Vec2; + /** + !#en + Sets the position (x, y) of the node in its parent's coordinates.
+ Usually we use cc.v2(x, y) to compose cc.Vec2 object.
+ and Passing two numbers (x, y) is more efficient than passing cc.Vec2 object. + !#zh + 设置节点在父节点坐标系中的位置。
+ 可以通过两种方式设置坐标点:
+ 1. 传入 2 个数值 x 和 y。
+ 2. 传入 cc.v2(x, y) 类型为 cc.Vec2 的对象。 + @param newPosOrX X coordinate for position or the position (x, y) of the node in coordinates + @param y Y coordinate for position + + @example + ```js + node.setPosition(cc.v2(0, 0)); + node.setPosition(0, 0); + + ``` + */ + setPosition(newPosOrX: Vec2|number, y?: number): void; + /** + !#en + Returns the scale factor of the node. + Assertion will fail when _scaleX != _scaleY. + !#zh 获取节点的缩放。当 X 轴和 Y 轴有相同的缩放数值时。 + + @example + ```js + cc.log("Node Scale: " + node.getScale()); + ``` + */ + getScale(): number; + /** + !#en Sets the scale factor of the node. 1.0 is the default scale factor. This function can modify the X and Y scale at the same time. + !#zh 设置节点的缩放比例,默认值为 1.0。这个函数可以在同一时间修改 X 和 Y 缩放。 + @param scaleX scaleX or scale + @param scaleY scaleY + + @example + ```js + node.setScale(cc.v2(1, 1)); + node.setScale(1, 1); + ``` + */ + setScale(scaleX: number|Vec2, scaleY?: number): void; + /** + !#en + Returns a copy the untransformed size of the node.
+ The contentSize remains the same no matter the node is scaled or rotated.
+ All nodes has a size. Layer and Scene has the same size of the screen by default.
+ !#zh 获取节点自身大小,不受该节点是否被缩放或者旋转的影响。 + @param ignoreSizeProvider true if you need to get the original size of the node + + @example + ```js + cc.log("Content Size: " + node.getContentSize()); + ``` + */ + getContentSize(ignoreSizeProvider?: boolean): Size; + /** + !#en + Sets the untransformed size of the node.
+ The contentSize remains the same no matter the node is scaled or rotated.
+ All nodes has a size. Layer and Scene has the same size of the screen. + !#zh 设置节点原始大小,不受该节点是否被缩放或者旋转的影响。 + @param size The untransformed size of the node or The untransformed size's width of the node. + @param height The untransformed size's height of the node. + + @example + ```js + node.setContentSize(cc.size(100, 100)); + node.setContentSize(100, 100); + ``` + */ + setContentSize(size: Size|number, height?: number): void; + /** + !#en + Set whether color should be changed with the opacity value, + useless in ccsg.Node, but this function is override in some class to have such behavior. + !#zh 设置更改透明度时是否修改RGB值, + @param opacityValue opacityValue + + @example + ```js + node.setOpacityModifyRGB(true); + ``` + */ + setOpacityModifyRGB(opacityValue: boolean): void; + /** + !#en Get whether color should be changed with the opacity value. + !#zh 更改透明度时是否修改RGB值。 + + @example + ```js + var hasChange = node.isOpacityModifyRGB(); + ``` + */ + isOpacityModifyRGB(): boolean; + /** + !#en + Returns a copy of the anchor point.
+ Anchor point is the point around which all transformations and positioning manipulations take place.
+ It's like a pin in the node where it is "attached" to its parent.
+ The anchorPoint is normalized, like a percentage. (0,0) means the bottom-left corner and (1,1) means the top-right corner.
+ But you can use values higher than (1,1) and lower than (0,0) too.
+ The default anchor point is (0.5,0.5), so it starts at the center of the node. + !#zh + 获取节点锚点,用百分比表示。
+ 锚点应用于所有变换和坐标点的操作,它就像在节点上连接其父节点的大头针。
+ 锚点是标准化的,就像百分比一样。(0,0) 表示左下角,(1,1) 表示右上角。
+ 但是你可以使用比(1,1)更高的值或者比(0,0)更低的值。
+ 默认的锚点是(0.5,0.5),因此它开始于节点的中心位置。
+ 注意:Creator 中的锚点仅用于定位所在的节点,子节点的定位不受影响。 + + @example + ```js + cc.log("Node AnchorPoint: " + node.getAnchorPoint()); + ``` + */ + getAnchorPoint(): Vec2; + /** + !#en + Sets the anchor point in percent.
+ anchor point is the point around which all transformations and positioning manipulations take place.
+ It's like a pin in the node where it is "attached" to its parent.
+ The anchorPoint is normalized, like a percentage. (0,0) means the bottom-left corner and (1,1) means the top-right corner.
+ But you can use values higher than (1,1) and lower than (0,0) too.
+ The default anchor point is (0.5,0.5), so it starts at the center of the node. + !#zh + 设置锚点的百分比。
+ 锚点应用于所有变换和坐标点的操作,它就像在节点上连接其父节点的大头针。
+ 锚点是标准化的,就像百分比一样。(0,0) 表示左下角,(1,1) 表示右上角。
+ 但是你可以使用比(1,1)更高的值或者比(0,0)更低的值。
+ 默认的锚点是(0.5,0.5),因此它开始于节点的中心位置。
+ 注意:Creator 中的锚点仅用于定位所在的节点,子节点的定位不受影响。 + @param point The anchor point of node or The x axis anchor of node. + @param y The y axis anchor of node. + + @example + ```js + node.setAnchorPoint(cc.v2(1, 1)); + node.setAnchorPoint(1, 1); + ``` + */ + setAnchorPoint(point: Vec2|number, y?: number): void; + /** + !#en + Returns a copy of the anchor point in absolute pixels.
+ you can only read it. If you wish to modify it, use setAnchorPoint. + !#zh + 返回锚点的绝对像素位置。
+ 你只能读它。如果您要修改它,使用 setAnchorPoint。 + + @example + ```js + cc.log("AnchorPointInPoints: " + node.getAnchorPointInPoints()); + ``` + */ + getAnchorPointInPoints(): Vec2; + /** + !#en + Returns the displayed opacity of Node, + the difference between displayed opacity and opacity is that displayed opacity is calculated based on opacity and parent node's opacity when cascade opacity enabled. + !#zh + 获取节点显示透明度, + 显示透明度和透明度之间的不同之处在于当启用级连透明度时, + 显示透明度是基于自身透明度和父节点透明度计算的。 + + @example + ```js + var displayOpacity = node.getDisplayedOpacity(); + ``` + */ + getDisplayedOpacity(): number; + /** + !#en + Returns the displayed color of Node, + the difference between displayed color and color is that displayed color is calculated based on color and parent node's color when cascade color enabled. + !#zh + 获取节点的显示透明度, + 显示透明度和透明度之间的不同之处在于显示透明度是基于透明度和父节点透明度启用级连透明度时计算的。 + + @example + ```js + var displayColor = node.getDisplayedColor(); + ``` + */ + getDisplayedColor(): Color; + /** + !#en + Returns the matrix that transform the node's (local) space coordinates into the parent's space coordinates.
+ The matrix is in Pixels.
+ This method is AR (Anchor Relative). + !#zh + 返回这个将节点(局部)的空间坐标系转换成父节点的空间坐标系的矩阵。
+ 这个矩阵以像素为单位。
+ 该方法基于节点坐标。 + + @example + ```js + var affineTransform = node.getNodeToParentTransformAR(); + ``` + */ + getNodeToParentTransformAR(): AffineTransform; + /** + !#en + Returns a "local" axis aligned bounding box of the node.
+ The returned box is relative only to its parent. + !#zh 返回父节坐标系下的轴向对齐的包围盒。 + + @example + ```js + var boundingBox = node.getBoundingBox(); + ``` + */ + getBoundingBox(): Rect; + /** + !#en + Returns a "world" axis aligned bounding box of the node.
+ The bounding box contains self and active children's world bounding box. + !#zh + 返回节点在世界坐标系下的对齐轴向的包围盒(AABB)。
+ 该边框包含自身和已激活的子节点的世界边框。 + + @example + ```js + var newRect = node.getBoundingBoxToWorld(); + ``` + */ + getBoundingBoxToWorld(): Rect; + /** + !#en + Returns the matrix that transform the node's (local) space coordinates into the parent's space coordinates.
+ The matrix is in Pixels. + !#zh 返回这个将节点(局部)的空间坐标系转换成父节点的空间坐标系的矩阵。这个矩阵以像素为单位。 + + @example + ```js + var affineTransform = node.getNodeToParentTransform(); + ``` + */ + getNodeToParentTransform(): AffineTransform; + /** + !#en Returns the world affine transform matrix. The matrix is in Pixels. + !#zh 返回节点到世界坐标系的仿射变换矩阵。矩阵单位是像素。 + + @example + ```js + var affineTransform = node.getNodeToWorldTransform(); + ``` + */ + getNodeToWorldTransform(): AffineTransform; + /** + !#en + Returns the world affine transform matrix. The matrix is in Pixels.
+ This method is AR (Anchor Relative). + !#zh + 返回节点到世界坐标仿射变换矩阵。矩阵单位是像素。
+ 该方法基于节点坐标。 + + @example + ```js + var mat = node.getNodeToWorldTransformAR(); + ``` + */ + getNodeToWorldTransformAR(): AffineTransform; + /** + !#en + Returns the matrix that transform parent's space coordinates to the node's (local) space coordinates.
+ The matrix is in Pixels. The returned transform is readonly and cannot be changed. + !#zh + 返回将父节点的坐标系转换成节点(局部)的空间坐标系的矩阵。
+ 该矩阵以像素为单位。返回的矩阵是只读的,不能更改。 + + @example + ```js + var affineTransform = node.getParentToNodeTransform(); + ``` + */ + getParentToNodeTransform(): AffineTransform; + /** + !#en Returns the inverse world affine transform matrix. The matrix is in Pixels. + !#en 返回世界坐标系到节点坐标系的逆矩阵。 + + @example + ```js + var affineTransform = node.getWorldToNodeTransform(); + ``` + */ + getWorldToNodeTransform(): AffineTransform; + /** + !#en Converts a Point to node (local) space coordinates. The result is in Vec2. + !#zh 将一个点转换到节点 (局部) 坐标系。结果以 Vec2 为单位。 + @param worldPoint worldPoint + + @example + ```js + var newVec2 = node.convertToNodeSpace(cc.v2(100, 100)); + ``` + */ + convertToNodeSpace(worldPoint: Vec2): Vec2; + /** + !#en Converts a Point to world space coordinates. The result is in Points. + !#zh 将一个点转换到世界空间坐标系。结果以 Vec2 为单位。 + @param nodePoint nodePoint + + @example + ```js + var newVec2 = node.convertToWorldSpace(cc.v2(100, 100)); + ``` + */ + convertToWorldSpace(nodePoint: Vec2): Vec2; + /** + !#en + Converts a Point to node (local) space coordinates. The result is in Points.
+ treating the returned/received node point as anchor relative. + !#zh + 将一个点转换到节点 (局部) 空间坐标系。结果以 Vec2 为单位。
+ 返回值将基于节点坐标。 + @param worldPoint worldPoint + + @example + ```js + var newVec2 = node.convertToNodeSpaceAR(cc.v2(100, 100)); + ``` + */ + convertToNodeSpaceAR(worldPoint: Vec2): Vec2; + /** + !#en + Converts a local Point to world space coordinates.The result is in Points.
+ treating the returned/received node point as anchor relative. + !#zh + 将一个点转换到世界空间坐标系。结果以 Vec2 为单位。
+ 返回值将基于世界坐标。 + @param nodePoint nodePoint + + @example + ```js + var newVec2 = node.convertToWorldSpaceAR(cc.v2(100, 100)); + ``` + */ + convertToWorldSpaceAR(nodePoint: Vec2): Vec2; + /** + !#en convenience methods which take a cc.Touch instead of cc.Vec2. + !#zh 将触摸点转换成本地坐标系中位置。 + @param touch The touch object + + @example + ```js + var newVec2 = node.convertTouchToNodeSpace(touch); + ``` + */ + convertTouchToNodeSpace(touch: Touch): Vec2; + /** + !#en converts a cc.Touch (world coordinates) into a local coordinate. This method is AR (Anchor Relative). + !#zh 转换一个 cc.Touch(世界坐标)到一个局部坐标,该方法基于节点坐标。 + @param touch The touch object + + @example + ```js + var newVec2 = node.convertTouchToNodeSpaceAR(touch); + ``` + */ + convertTouchToNodeSpaceAR(touch: Touch): Vec2; + /** + !#en + Adds a child to the node with z order and tag. + !#zh + 添加子节点,并且可以修改该节点的 局部 Z 顺序和标签。 + @param child A child node + @param localZOrder Z order for drawing priority. Please refer to setZOrder(int) + @param tag An integer or a name to identify the node easily. Please refer to setTag(int) and setName(string) + + @example + ```js + node.addChild(newNode, 1, 1001); + ``` + */ + addChild(child: Node, localZOrder?: number, tag?: number|string): void; + /** + !#en Stops all running actions and schedulers. + !#zh 停止所有正在播放的动作和计时器。 + + @example + ```js + node.cleanup(); + ``` + */ + cleanup(): void; + /** + !#en Sorts the children array depends on children's zIndex and arrivalOrder, + normally you won't need to invoke this function. + !#zh 根据子节点的 zIndex 和 arrivalOrder 进行排序,正常情况下开发者不需要手动调用这个函数。 + */ + sortAllChildren(): void; + /** !#en The local scale relative to the parent. + !#zh 节点相对父节点的缩放。 */ + scale: number; + /** + !#en Returns the x axis position of the node in cocos2d coordinates. + !#zh 获取节点 X 轴坐标。 + + @example + ```js + var posX = node.getPositionX(); + ``` + */ + getPositionX(): number; + /** + !#en Sets the x axis position of the node in cocos2d coordinates. + !#zh 设置节点 X 轴坐标。 + @param x x + + @example + ```js + node.setPositionX(1); + ``` + */ + setPositionX(x: number): void; + /** + !#en Returns the y axis position of the node in cocos2d coordinates. + !#zh 获取节点 Y 轴坐标。 + + @example + ```js + var posY = node.getPositionY(); + ``` + */ + getPositionY(): number; + /** + !#en Sets the y axis position of the node in cocos2d coordinates. + !#zh 设置节点 Y 轴坐标。 + @param y The new position in y axis + + @example + ```js + node.setPositionY(100); + ``` + */ + setPositionY(y: number): void; + /** + !#en Returns the local Z order of this node. + !#zh 获取节点局部 Z 轴顺序。 + + @example + ```js + var localZorder = node.getLocalZOrder(); + ``` + */ + getLocalZOrder(): number; + /** + !#en + LocalZOrder is the 'key' used to sort the node relative to its siblings.
+
+ The Node's parent will sort all its children based ont the LocalZOrder value.
+ If two nodes have the same LocalZOrder, then the node that was added first to the children's array
+ will be in front of the other node in the array.
+ Also, the Scene Graph is traversed using the "In-Order" tree traversal algorithm ( http://en.wikipedia.org/wiki/Tree_traversal#In-order )
+ And Nodes that have LocalZOder values smaller than 0 are the "left" subtree
+ While Nodes with LocalZOder greater than 0 are the "right" subtree. + !#zh + LocalZOrder 是 “key” (关键)来分辨节点和它兄弟节点的相关性。 + 父节点将会通过 LocalZOrder 的值来分辨所有的子节点。 + 如果两个节点有同样的 LocalZOrder,那么先加入子节点数组的节点将会显示在后加入的节点的前面。 + 同样的,场景图使用 “In-Order(按顺序)” 遍历数算法来遍历 + ( http://en.wikipedia.org/wiki/Tree_traversal#In-order ) 并且拥有小于 0 的 LocalZOrder 的值的节点是 “ left ” 子树(左子树) + 所以拥有大于 0 的 LocalZOrder 的值得节点是 “ right ”子树(右子树)。 + @param localZOrder localZOrder + + @example + ```js + node.setLocalZOrder(1); + ``` + */ + setLocalZOrder(localZOrder: number): void; + /** + !#en Returns whether node's opacity value affect its child nodes. + !#zh 返回节点的不透明度值是否影响其子节点。 + + @example + ```js + cc.log(node.isCascadeOpacityEnabled()); + ``` + */ + isCascadeOpacityEnabled(): boolean; + /** + !#en Enable or disable cascade opacity, if cascade enabled, child nodes' opacity will be the multiplication of parent opacity and its own opacity. + !#zh 启用或禁用级连不透明度,如果级连启用,子节点的不透明度将是父不透明度乘上它自己的不透明度。 + @param cascadeOpacityEnabled cascadeOpacityEnabled + + @example + ```js + node.setCascadeOpacityEnabled(true); + ``` + */ + setCascadeOpacityEnabled(cascadeOpacityEnabled: boolean): void; + } + /** !#en + cc.Scene is a subclass of cc.Node that is used only as an abstract concept.
+ cc.Scene and cc.Node are almost identical with the difference that users can not modify cc.Scene manually. + !#zh + cc.Scene 是 cc.Node 的子类,仅作为一个抽象的概念。
+ cc.Scene 和 cc.Node 有点不同,用户不应直接修改 cc.Scene。 */ + export class Scene extends Node { + /** !#en Indicates whether all (directly or indirectly) static referenced assets of this scene are releasable by default after scene unloading. + !#zh 指示该场景中直接或间接静态引用到的所有资源是否默认在场景切换后自动释放。 */ + autoReleaseAssets: boolean; + } + /** !#en + Scheduler is responsible of triggering the scheduled callbacks.
+ You should not use NSTimer. Instead use this class.
+
+ There are 2 different types of callbacks (selectors):
+ - update callback: the 'update' callback will be called every frame. You can customize the priority.
+ - custom callback: A custom callback will be called every frame, or with a custom interval of time
+
+ The 'custom selectors' should be avoided when possible. It is faster, + and consumes less memory to use the 'update callback'. * + !#zh + Scheduler 是负责触发回调函数的类。
+ 通常情况下,建议使用 cc.director.getScheduler() 来获取系统定时器。
+ 有两种不同类型的定时器:
+ - update 定时器:每一帧都会触发。您可以自定义优先级。
+ - 自定义定时器:自定义定时器可以每一帧或者自定义的时间间隔触发。
+ 如果希望每帧都触发,应该使用 update 定时器,使用 update 定时器更快,而且消耗更少的内存。 */ + export class Scheduler { + /** + !#en + Modifies the time of all scheduled callbacks.
+ You can use this property to create a 'slow motion' or 'fast forward' effect.
+ Default is 1.0. To create a 'slow motion' effect, use values below 1.0.
+ To create a 'fast forward' effect, use values higher than 1.0.
+ Note:It will affect EVERY scheduled selector / action. + !#zh + 设置时间间隔的缩放比例。
+ 您可以使用这个方法来创建一个 “slow motion(慢动作)” 或 “fast forward(快进)” 的效果。
+ 默认是 1.0。要创建一个 “slow motion(慢动作)” 效果,使用值低于 1.0。
+ 要使用 “fast forward(快进)” 效果,使用值大于 1.0。
+ 注意:它影响该 Scheduler 下管理的所有定时器。 + @param timeScale timeScale + */ + setTimeScale(timeScale: number): void; + /** + !#en Returns time scale of scheduler. + !#zh 获取时间间隔的缩放比例。 + */ + getTimeScale(): number; + /** + !#en 'update' the scheduler. (You should NEVER call this method, unless you know what you are doing.) + !#zh update 调度函数。(不应该直接调用这个方法,除非完全了解这么做的结果) + @param dt delta time + */ + update(dt: number): void; + /** + !#en +

+ The scheduled method will be called every 'interval' seconds.
+ If paused is YES, then it won't be called until it is resumed.
+ If 'interval' is 0, it will be called every frame, but if so, it recommended to use 'scheduleUpdateForTarget:' instead.
+ If the callback function is already scheduled, then only the interval parameter will be updated without re-scheduling it again.
+ repeat let the action be repeated repeat + 1 times, use cc.macro.REPEAT_FOREVER to let the action run continuously
+ delay is the amount of time the action will wait before it'll start
+

+ !#zh + 指定回调函数,调用对象等信息来添加一个新的定时器。
+ 当时间间隔达到指定值时,设置的回调函数将会被调用。
+ 如果 paused 值为 true,那么直到 resume 被调用才开始计时。
+ 如果 interval 值为 0,那么回调函数每一帧都会被调用,但如果是这样, + 建议使用 scheduleUpdateForTarget 代替。
+ 如果回调函数已经被定时器使用,那么只会更新之前定时器的时间间隔参数,不会设置新的定时器。
+ repeat 值可以让定时器触发 repeat + 1 次,使用 cc.macro.REPEAT_FOREVER + 可以让定时器一直循环触发。
+ delay 值指定延迟时间,定时器会在延迟指定的时间之后开始计时。 + @param target target + @param callback_fn callback_fn + @param interval interval + @param repeat repeat + @param delay delay + @param paused paused + + @example + ```js + //register a schedule to scheduler + var scheduler = cc.director.getScheduler(); + scheduler.scheduleCallbackForTarget(this, function, interval, repeat, delay, !this._isRunning); + + ``` + */ + scheduleCallbackForTarget(target: any, callback: Function, interval: number, repeat: number, delay: number, paused?: boolean): void; + scheduleCallbackForTarget(target: any, callback: Function, interval: number, paused?: boolean): void; + /** + !#en The schedule + !#zh 定时器 + @param callback callback + @param target target + @param interval interval + @param repeat repeat + @param delay delay + @param paused paused + + @example + ```js + //register a schedule to scheduler + cc.director.getScheduler().schedule(callback, this, interval, !this._isRunning); + + ``` + */ + schedule(callback: Function, target: any, interval: number, repeat: number, delay: number, paused?: boolean): void; + schedule(callback: Function, target: any, interval: number, paused?: boolean): void; + /** + !#en + Schedules the update callback for a given target, + the callback will be invoked every frame after schedule started. + !#zh + 使用指定的优先级为指定的对象设置 update 定时器。 + update 定时器每一帧都会被触发。优先级的值越低,定时器被触发的越早。 + @param target target + @param priority priority + @param paused paused + @param updateFunc updateFunc + */ + scheduleUpdate(target: any, priority: number, paused: boolean, updateFunc: Function): void; + /** + !#en + Unschedules a callback for a callback and a given target. + If you want to unschedule the "update", use `unscheduleUpdate()` + !#zh + 根据指定的回调函数和调用对象。 + 如果需要取消 update 定时器,请使用 unscheduleUpdate()。 + @param callback The callback to be unscheduled + @param target The target bound to the callback. + */ + unschedule(callback: Function, target: any): void; + /** + !#en Unschedules the update callback for a given target. + !#zh 取消指定对象的 update 定时器。 + @param target The target to be unscheduled. + */ + unscheduleUpdate(target: any): void; + /** + !#en + Unschedules all scheduled callbacks for a given target. + This also includes the "update" callback. + !#zh 取消指定对象的所有定时器,包括 update 定时器。 + @param target The target to be unscheduled. + */ + unscheduleAllForTarget(target: any): void; + /** + !#en + Unschedules all scheduled callbacks from all targets including the system callbacks.
+ You should NEVER call this method, unless you know what you are doing. + !#zh + 取消所有对象的所有定时器,包括系统定时器。
+ 不用调用此函数,除非你确定你在做什么。 + */ + unscheduleAll(): void; + /** + !#en + Unschedules all callbacks from all targets with a minimum priority.
+ You should only call this with `PRIORITY_NON_SYSTEM_MIN` or higher. + !#zh + 取消所有优先级的值大于指定优先级的定时器。
+ 你应该只取消优先级的值大于 PRIORITY_NON_SYSTEM_MIN 的定时器。 + @param minPriority The minimum priority of selector to be unscheduled. Which means, all selectors which + priority is higher than minPriority will be unscheduled. + */ + unscheduleAllWithMinPriority(minPriority: number): void; + /** + !#en Checks whether a callback for a given target is scheduled. + !#zh 检查指定的回调函数和回调对象组合是否存在定时器。 + @param callback The callback to check. + @param target The target of the callback. + */ + isScheduled(callback: Function, target: any): boolean; + /** + !#en + Pause all selectors from all targets.
+ You should NEVER call this method, unless you know what you are doing. + !#zh + 暂停所有对象的所有定时器。
+ 不要调用这个方法,除非你知道你正在做什么。 + */ + pauseAllTargets(): void; + /** + !#en + Pause all selectors from all targets with a minimum priority.
+ You should only call this with kCCPriorityNonSystemMin or higher. + !#zh + 暂停所有优先级的值大于指定优先级的定时器。
+ 你应该只暂停优先级的值大于 PRIORITY_NON_SYSTEM_MIN 的定时器。 + @param minPriority minPriority + */ + pauseAllTargetsWithMinPriority(minPriority: number): void; + /** + !#en + Resume selectors on a set of targets.
+ This can be useful for undoing a call to pauseAllCallbacks. + !#zh + 恢复指定数组中所有对象的定时器。
+ 这个函数是 pauseAllCallbacks 的逆操作。 + @param targetsToResume targetsToResume + */ + resumeTargets(targetsToResume: any[]): void; + /** + !#en + Pauses the target.
+ All scheduled selectors/update for a given target won't be 'ticked' until the target is resumed.
+ If the target is not present, nothing happens. + !#zh + 暂停指定对象的定时器。
+ 指定对象的所有定时器都会被暂停。
+ 如果指定的对象没有定时器,什么也不会发生。 + @param target target + */ + pauseTarget(target: any): void; + /** + !#en + Resumes the target.
+ The 'target' will be unpaused, so all schedule selectors/update will be 'ticked' again.
+ If the target is not present, nothing happens. + !#zh + 恢复指定对象的所有定时器。
+ 指定对象的所有定时器将继续工作。
+ 如果指定的对象没有定时器,什么也不会发生。 + @param target target + */ + resumeTarget(target: any): void; + /** + !#en Returns whether or not the target is paused. + !#zh 返回指定对象的定时器是否暂停了。 + @param target target + */ + isTargetPaused(target: any): boolean; + /** + !#en + Schedules the 'update' callback_fn for a given target with a given priority.
+ The 'update' callback_fn will be called every frame.
+ The lower the priority, the earlier it is called. + !#zh + 为指定对象设置 update 定时器。
+ update 定时器每一帧都会被调用。
+ 优先级的值越低,越早被调用。 + @param target target + @param priority priority + @param paused paused + + @example + ```js + //register this object to scheduler + var scheduler = cc.director.getScheduler(); + scheduler.scheduleUpdateForTarget(this, priority, !this._isRunning ); + + ``` + */ + scheduleUpdateForTarget(target: any, priority: number, paused: boolean): void; + /** + !#en + Unschedule a callback function for a given target.
+ If you want to unschedule the "update", use unscheduleUpdateForTarget. + !#zh + 根据指定的回调函数和调用对象对象取消相应的定时器。
+ 如果需要取消 update 定时器,请使用 unscheduleUpdateForTarget()。 + @param target target + @param callback callback[Function] or key[String] + + @example + ```js + //unschedule a callback of target + var scheduler = cc.director.getScheduler(); + scheduler.unscheduleCallbackForTarget(this, callback); + + ``` + */ + unscheduleCallbackForTarget(target: any, callback: Function): void; + /** + !#en Unschedules the update callback function for a given target. + !#zh 取消指定对象的所有定时器。 + @param target target + + @example + ```js + //unschedules the "update" method. + var scheduler = cc.director.getScheduler(); + scheduler.unscheduleUpdateForTarget(this); + + ``` + */ + unscheduleUpdateForTarget(target: any): void; + /** + !#en + Unschedules all function callbacks for a given target.
+ This also includes the "update" callback function. + !#zh 取消指定对象的所有定时器,包括 update 定时器。 + @param target target + */ + unscheduleAllCallbacksForTarget(target: any): void; + /** + !#en + Unschedules all function callbacks from all targets.
+ You should NEVER call this method, unless you know what you are doing. + !#zh + 取消所有对象的所有定时器。
+ 不要调用这个方法,除非你知道你正在做什么。 + */ + unscheduleAllCallbacks(): void; + /** + !#en + Unschedules all function callbacks from all targets with a minimum priority.
+ You should only call this with kCCPriorityNonSystemMin or higher. + !#zh + 取消所有优先级的值大于指定优先级的所有对象的所有定时器。
+ 你应该只暂停优先级的值大于 PRIORITY_NON_SYSTEM_MIN 的定时器。 + @param minPriority minPriority + */ + unscheduleAllCallbacksWithMinPriority(minPriority: number): void; + /** !#en Priority level reserved for system services. + !#zh 系统服务的优先级。 */ + static PRIORITY_SYSTEM: number; + /** !#en Minimum priority level for user scheduling. + !#zh 用户调度最低优先级。 */ + static PRIORITY_NON_SYSTEM: number; + } + /** !#en + cc.NodePool is the cache pool designed for node type.
+ It can helps you to improve your game performance for objects which need frequent release and recreate operations
+ + It's recommended to create cc.NodePool instances by node type, the type corresponds to node type in game design, not the class, + for example, a prefab is a specific node type.
+ When you create a node pool, you can pass a Component which contains `unuse`, `reuse` functions to control the content of node.
+ + Some common use case is :
+ 1. Bullets in game (die very soon, massive creation and recreation, no side effect on other objects)
+ 2. Blocks in candy crash (massive creation and recreation)
+ etc... + !#zh + cc.NodePool 是用于管理节点对象的对象缓存池。
+ 它可以帮助您提高游戏性能,适用于优化对象的反复创建和销毁
+ 以前 cocos2d-x 中的 cc.pool 和新的节点事件注册系统不兼容,因此请使用 cc.NodePool 来代替。 + + 新的 NodePool 需要实例化之后才能使用,每种不同的节点对象池需要一个不同的对象池实例,这里的种类对应于游戏中的节点设计,一个 prefab 相当于一个种类的节点。
+ 在创建缓冲池时,可以传入一个包含 unuse, reuse 函数的组件类型用于节点的回收和复用逻辑。
+ + 一些常见的用例是:
+ 1.在游戏中的子弹(死亡很快,频繁创建,对其他对象无副作用)
+ 2.糖果粉碎传奇中的木块(频繁创建)。 + 等等.... */ + export class NodePool { + /** + !#en + Constructor for creating a pool for a specific node template (usually a prefab). You can pass a component (type or name) argument for handling event for reusing and recycling node. + !#zh + 使用构造函数来创建一个节点专用的对象池,您可以传递一个组件类型或名称,用于处理节点回收和复用时的事件逻辑。 + @param poolHandlerComp !#en The constructor or the class name of the component to control the unuse/reuse logic. !#zh 处理节点回收和复用事件逻辑的组件类型或名称。 + + @example + ```js + properties: { + template: cc.Prefab + }, + onLoad () { + // MyTemplateHandler is a component with 'unuse' and 'reuse' to handle events when node is reused or recycled. + this.myPool = new cc.NodePool('MyTemplateHandler'); + } + ``` + */ + constructor(poolHandlerComp?: {prototype: Component}|string); + /** !#en The pool handler component, it could be the class name or the constructor. + !#zh 缓冲池处理组件,用于节点的回收和复用逻辑,这个属性可以是组件类名或组件的构造函数。 */ + poolHandlerComp: Function|string; + /** + !#en The current available size in the pool + !#zh 获取当前缓冲池的可用对象数量 + */ + size(): number; + /** + !#en Destroy all cached nodes in the pool + !#zh 销毁对象池中缓存的所有节点 + */ + clear(): void; + /** + !#en Put a new Node into the pool. + It will automatically remove the node from its parent without cleanup. + It will also invoke unuse method of the poolHandlerComp if exist. + !#zh 向缓冲池中存入一个不再需要的节点对象。 + 这个函数会自动将目标节点从父节点上移除,但是不会进行 cleanup 操作。 + 这个函数会调用 poolHandlerComp 的 unuse 函数,如果组件和函数都存在的话。 + @param obj obj + + @example + ```js + let myNode = cc.instantiate(this.template); + this.myPool.put(myNode); + ``` + */ + put(obj: Node): void; + /** + !#en Get a obj from pool, if no available object in pool, null will be returned. + This function will invoke the reuse function of poolHandlerComp if exist. + !#zh 获取对象池中的对象,如果对象池没有可用对象,则返回空。 + 这个函数会调用 poolHandlerComp 的 reuse 函数,如果组件和函数都存在的话。 + @param params !#en Params to pass to 'reuse' method in poolHandlerComp !#zh 向 poolHandlerComp 中的 'reuse' 函数传递的参数 + + @example + ```js + let newNode = this.myPool.get(); + ``` + */ + get(...params: any[]): Node; + } + /** !#en + Attention: In creator, it's strongly not recommended to use cc.pool to manager cc.Node. + We provided {{#crossLink "NodePool"}}cc.NodePool{{/crossLink}} instead. + + cc.pool is a singleton object serves as an object cache pool.
+ It can helps you to improve your game performance for objects which need frequent release and recreate operations
+ !#zh + 首先请注意,在 Creator 中我们强烈不建议使用 cc.pool 来管理 cc.Node 节点对象,请使用 {{#crossLink "NodePool"}}cc.NodePool{{/crossLink}} 代替 + 因为 cc.pool 是面向类来设计的,而 cc.Node 中使用 Component 来进行组合,它的类永远都一样,实际却千差万别。 + + cc.pool 是一个单例对象,用作为对象缓存池。
+ 它可以帮助您提高游戏性能,适用于优化对象的反复创建和销毁
*/ + export class pool { + /** + !#en Put the obj in pool. + !#zh 加入对象到对象池中。 + @param obj The need put in pool object. + + @example + ```js + --------------------------------- + var sp = new _ccsg.Sprite("a.png"); + this.addChild(sp); + cc.pool.putInPool(sp); + cc.pool.getFromPool(_ccsg.Sprite, "a.png"); + + ``` + */ + putInPool(obj: any): void; + /** + !#en Check if this kind of obj has already in pool. + !#zh 检查对象池中是否有指定对象的存在。 + @param objClass The check object class. + */ + hasObject(objClass: any): boolean; + /** + !#en Remove the obj if you want to delete it. + !#zh 移除在对象池中指定的对象。 + */ + removeObject(): void; + /** + !#en Get the obj from pool. + !#zh 获取对象池中的指定对象。 + */ + getFromPool(): any; + /** + !#en Remove all objs in pool and reset the pool. + !#zh 移除对象池中的所有对象,并且重置对象池。 + */ + drainAllPools(): void; + } + /** !#en + Camera is usefull when making reel game or other games which need scroll screen. + Using camera will be more efficient than moving node to scroll screen. + Camera + !#zh + 摄像机在制作卷轴或是其他需要移动屏幕的游戏时比较有用,使用摄像机将会比移动节点来移动屏幕更加高效。 */ + export class Camera extends _RendererUnderSG { + /** !#en + The camera zoom ratio. + !#zh + 摄像机缩放比率 */ + zoomRatio: number; + /** !#en + Current active camera, the scene should only have one active camera at the same time. + !#zh + 当前激活的摄像机,场景中在同一时间内只能有一个激活的摄像机。 */ + static main: Camera; + /** + !#en + Add the specified target to camera. + !#zh + 将指定的节点添加到摄像机中。 + @param target target + */ + addTarget(target: Node): void; + /** + !#en + Remove the specified target from camera. + !#zh + 将指定的节点从摄像机中移除。 + @param target target + */ + removeTarget(target: Node): void; + /** + !#en + Get all camera targets. + !#zh + 获取所有摄像机目标节点。 + */ + getTargets(): [Node]; + /** + !#en + Returns the matrix that transform the node's (local) space coordinates into the camera's space coordinates. + !#zh + 返回一个将节点坐标系转换到摄像机坐标系下的矩阵 + @param node the node which should transform + */ + getNodeToCameraTransform(node: Node): AffineTransform; + /** + !#en + Conver a camera coordinates point to world coordinates. + !#zh + 将一个摄像机坐标系下的点转换到世界坐标系下。 + @param point the point which should transform + */ + getCameraToWorldPoint(point: Node): Vec2; + /** + !#en + Check whether the node is in the camera. + !#zh + 检测节点是否被此摄像机影响 + @param node the node which need to check + */ + containsNode(node: Node): boolean; + } + /** !#en + Base class for handling assets used in Fireball. This class can be instantiate. + + You may want to override:
+ - createNode
+ - cc.Object._serialize
+ - cc.Object._deserialize
+ !#zh + 资源基类,该类可以被实例化。
+ + 您可能需要重写:
+ - createNode
+ - cc.Object._serialize
+ - cc.Object._deserialize
*/ + export class Asset extends RawAsset { + /** !#en + Returns the url of this asset's first raw file, if none of rawFile exists, + it will returns an empty string. + !#zh 返回该资源的原始文件的 URL,如果不支持 RAW 文件,它将返回一个空字符串。 */ + rawUrl: string; + /** !#en + Returns the url of this asset's raw files, if none of rawFile exists, + it will returns an empty array. + !#zh 返回该资源的原文件的 URL 数组,如果不支持 RAW 文件,它将返回一个空数组。 */ + rawUrls: string[]; + /** !#en Indicates whether its dependent raw assets can support deferred load if the owner scene (or prefab) is marked as `asyncLoadAssets`. + !#zh 当场景或 Prefab 被标记为 `asyncLoadAssets`,禁止延迟加载该资源所依赖的其它 RawAsset。 */ + static preventDeferredLoadDependents: boolean; + /** + !#en + Create a new node using this asset in the scene.
+ If this type of asset dont have its corresponding node type, this method should be null. + !#zh + 使用该资源在场景中创建一个新节点。
+ 如果这类资源没有相应的节点类型,该方法应该是空的。 + @param callback callback + */ + createNode(callback: (error: string, node: any) => void): void; + } + /** !#en Class for audio data handling. + !#zh 音频资源类。 */ + export class AudioClip extends RawAsset { + } + /** !#en Class for BitmapFont handling. + !#zh 位图字体资源类。 */ + export class BitmapFont extends RawAsset { + } + /** !#en Class for Font handling. + !#zh 字体资源类。 */ + export class Font extends RawAsset { + } + /** !#en Class for prefab handling. + !#zh 预制资源类。 */ + export class Prefab extends Asset { + /** the main cc.Node in the prefab */ + data: Node; + /** !#en Indicates the raw assets of this prefab can be load after prefab loaded. + !#zh 指示该 Prefab 依赖的资源可否在 Prefab 加载后再延迟加载。 */ + asyncLoadAssets: boolean; + /** + Dynamically translation prefab data into minimized code.
+ This method will be called automatically before the first time the prefab being instantiated, + but you can re-call to refresh the create function once you modified the original prefab data in script. + */ + compileCreateFunction(): void; + } + /** !#en Class for LabelAtlas handling. + !#zh 艺术数字字体资源类。 */ + export class LabelAtlas extends BitmapFont { + } + /** !#en + The base class for registering asset types. + + You may want to override: + - createNode (static) + !#zh + 注册用的资源基类。
+ 你可能要重写:
+ - createNode (static) */ + export class RawAsset extends Object { + /** + !#en + Create a new node in the scene.
+ If this type of asset dont have its corresponding node type, this method should be null. + !#zh + 在场景中创建一个新节点。
+ 如果这类资源没有相应的节点类型,该方法应该是空的。 + @param Info Info + @param callback callback + */ + static createNodeByInfo(Info: any, callback: (error: string, node: any) => void): void; + } + /** !#en Class for scene handling. + !#zh 场景资源类。 */ + export class SceneAsset extends Asset { + scene: Scene; + /** !#en Indicates the raw assets of this scene can be load after scene launched. + !#zh 指示该场景依赖的资源可否在场景切换后再延迟加载。 */ + asyncLoadAssets: boolean; + } + /** !#en Class for script handling. + !#zh Script 资源类。 */ + export class _Script extends Asset { + } + /** !#en Class for JavaScript handling. + !#zh JavaScript 资源类。 */ + export class _JavaScript extends Asset { + } + /** !#en Class for coffeescript handling. + !#zh CoffeeScript 资源类。 */ + export class CoffeeScript extends Asset { + } + /** !#en Class for TypeScript handling. + !#zh TypeScript 资源类。 */ + export class TypeScript extends Asset { + } + /** !#en Class for sprite atlas handling. + !#zh 精灵图集资源类。 */ + export class SpriteAtlas extends RawAsset { + /** + Returns the texture of the sprite atlas + */ + getTexture(): Texture2D; + /** + Returns the sprite frame correspond to the given key in sprite atlas. + @param key key + */ + getSpriteFrame(key: string): SpriteFrame; + /** + Returns the sprite frames in sprite atlas. + */ + getSpriteFrames(): [SpriteFrame]; + } + /** !#en Class for TTFFont handling. + !#zh TTF 字体资源类。 */ + export class TTFFont extends Asset { + } + /** !#en Class for text file. + !#zh 文本资源类。 */ + export class TextAsset extends Asset { + } + /** !#en Box Collider. + !#zh 包围盒碰撞组件 */ + export class BoxCollider extends Collider implements Collider.Box { + /** !#en Position offset + !#zh 位置偏移量 */ + offset: Vec2; + /** !#en Box size + !#zh 包围盒大小 */ + size: Size; + } + /** !#en Circle Collider. + !#zh 圆形碰撞组件 */ + export class CircleCollider extends Collider implements Collider.Circle { + /** !#en Position offset + !#zh 位置偏移量 */ + offset: Vec2; + /** !#en Circle radius + !#zh 圆形半径 */ + radius: number; + } + /** !#en Collider component base class. + !#zh 碰撞组件基类 */ + export class Collider extends Component { + /** !#en Tag. If a node has several collider components, you can judge which type of collider is collided according to the tag. + !#zh 标签。当一个节点上有多个碰撞组件时,在发生碰撞后,可以使用此标签来判断是节点上的哪个碰撞组件被碰撞了。 */ + tag: number; + } + /** !#en + A simple collision manager class. + It will calculate whether the collider collides other colliders, if collides then call the callbacks. + !#zh + 一个简单的碰撞组件管理类,用于处理节点之间的碰撞组件是否产生了碰撞,并调用相应回调函数。 */ + export class CollisionManager implements EventTarget { + /** !#en + !#zh + 是否开启碰撞管理,默认为不开启 */ + enabled: boolean; + /** !#en + !#zh + 是否绘制碰撞组件的包围盒,默认为不绘制 */ + enabledDrawBoundingBox: boolean; + /** !#en + !#zh + 是否绘制碰撞组件的形状,默认为不绘制 */ + enabledDebugDraw: boolean; + /** + !#en + Register an callback of a specific event type on the EventTarget. + !#zh + 注册事件目标的特定事件类型回调。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + on(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + on(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Removes the listeners previously registered with the same type, callback, target and or useCapture, + if only type is passed as parameter, all listeners registered with that type will be removed. + !#zh + 删除之前用同类型,回调,目标或 useCapture 注册的事件监听器,如果只传递 type,将会删除 type 类型的所有事件监听器。 + @param type A string representing the event type being removed. + @param callback The callback to remove. + @param target The target (this object) to invoke the callback, if it's not given, only callback without target will be removed + @param useCapture Specifies whether the callback being removed was registered as a capturing callback or not. + If not specified, useCapture defaults to false. If a callback was registered twice, + one with capture and one without, each must be removed separately. Removal of a capturing callback + does not affect a non-capturing version of the same listener, and vice versa. + + @example + ```js + // register touchEnd eventListener + var touchEnd = node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + // remove touch end event listener + node.off(cc.Node.EventType.TOUCH_END, touchEnd, node); + // remove all touch end event listeners + node.off(cc.Node.EventType.TOUCH_END); + ``` + */ + off(type: string, callback?: Function, target?: any, useCapture?: boolean): void; + /** + !#en Removes all callbacks previously registered with the same target (passed as parameter). + This is not for removing all listeners in the current event target, + and this is not for removing all listeners the target parameter have registered. + It's only for removing all listeners (callback and target couple) registered on the current event target by the target parameter. + !#zh 在当前 EventTarget 上删除指定目标(target 参数)注册的所有事件监听器。 + 这个函数无法删除当前 EventTarget 的所有事件监听器,也无法删除 target 参数所注册的所有事件监听器。 + 这个函数只能删除 target 参数在当前 EventTarget 上注册的所有事件监听器。 + @param target The target to be searched for all related listeners + */ + targetOff(target: any): void; + /** + !#en + Register an callback of a specific event type on the EventTarget, + the callback will remove itself after the first time it is triggered. + !#zh + 注册事件目标的特定事件类型回调,回调会在第一时间被触发后删除自身。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.once(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + once(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + once(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Dispatches an event into the event flow. + The event target is the EventTarget object upon which the dispatchEvent() method is called. + !#zh 分发事件到事件流中。 + @param event The Event object that is dispatched into the event flow + */ + dispatchEvent(event: Event): void; + /** + !#en + Send an event to this object directly, this method will not propagate the event to any other objects. + The event will be created from the supplied message, you can get the "detail" argument from event.detail. + !#zh + 该对象直接发送事件, 这种方法不会对事件传播到任何其他对象。 + @param message the message to send + @param detail whatever argument the message needs + */ + emit(message: string, detail?: any): void; + } + /** !#en Intersection helper class + !#zh 辅助类,用于测试形状与形状是否相交 */ + export class Intersection { + /** + !#en Test line and line + !#zh 测试线段与线段是否相交 + @param a1 The start point of the first line + @param a2 The end point of the first line + @param b1 The start point of the second line + @param b2 The end point of the second line + */ + static lineLine(a1: Vec2, a2: Vec2, b1: Vec2, b2: Vec2): boolean; + /** + !#en Test line and rect + !#zh 测试线段与矩形是否相交 + @param a1 The start point of the line + @param a2 The end point of the line + @param b The rect + */ + static lineRect(a1: Vec2, a2: Vec2, b: Rect): boolean; + /** + !#en Test line and polygon + !#zh 测试线段与多边形是否相交 + @param a1 The start point of the line + @param a2 The end point of the line + @param b The polygon, a set of points + */ + static linePolygon(a1: Vec2, a2: Vec2, b: Vec2[]): boolean; + /** + !#en Test rect and rect + !#zh 测试矩形与矩形是否相交 + @param a The first rect + @param b The second rect + */ + static rectRect(a: Rect, b: Rect): boolean; + /** + !#en Test rect and polygon + !#zh 测试矩形与多边形是否相交 + @param a The rect + @param b The polygon, a set of points + */ + static rectPolygon(a: Rect, b: Vec2[]): boolean; + /** + !#en Test polygon and polygon + !#zh 测试多边形与多边形是否相交 + @param a The first polygon, a set of points + @param b The second polygon, a set of points + */ + static polygonPolygon(a: Vec2[], b: Vec2[]): boolean; + /** + !#en Test circle and circle + !#zh 测试圆形与圆形是否相交 + @param a Object contains position and radius + @param b Object contains position and radius + */ + static circleCircle(a: {position: Vec2, radius: number}, b: {position: Vec2, radius: number}): boolean; + /** + !#en Test polygon and circle + !#zh 测试矩形与圆形是否相交 + @param polygon The Polygon, a set of points + @param circle Object contains position and radius + */ + static polygonCircle(polygon: Vec2[], circle: {position: Vec2, radius: number}): boolean; + /** + !#en Test whether the point is in the polygon + !#zh 测试一个点是否在一个多边形中 + @param point The point + @param polygon The polygon, a set of points + */ + static pointInPolygon(point: Vec2, polygon: Vec2[]): boolean; + /** + !#en Calculate the distance of point to line. + !#zh 计算点到直线的距离。如果这是一条线段并且垂足不在线段内,则会计算点到线段端点的距离。 + @param point The point + @param start The start point of line + @param end The end point of line + @param isSegment whether this line is a segment + */ + static pointLineDistance(point: Vec2, start: Vec2, end: Vec2, isSegment: boolean): boolean; + } + /** !#en Polygon Collider. + !#zh 多边形碰撞组件 */ + export class PolygonCollider extends Collider implements Collider.Polygon { + /** !#en Position offset + !#zh 位置偏移量 */ + offset: Vec2; + /** !#en Polygon points + !#zh 多边形顶点数组 */ + points: [Vec2]; + } + /** !#en The animation component is used to play back animations. + + Animation provide several events to register: + - play : Emit when begin playing animation + - stop : Emit when stop playing animation + - pause : Emit when pause animation + - resume : Emit when resume animation + - lastframe : If animation repeat count is larger than 1, emit when animation play to the last frame + - finished : Emit when finish playing animation + + !#zh Animation 组件用于播放动画。 + + Animation 提供了一系列可注册的事件: + - play : 开始播放时 + - stop : 停止播放时 + - pause : 暂停播放时 + - resume : 恢复播放时 + - lastframe : 假如动画循环次数大于 1,当动画播放到最后一帧时 + - finished : 动画播放完成时 */ + export class Animation extends Component implements EventTarget { + /** !#en Animation will play the default clip when start game. + !#zh 在勾选自动播放或调用 play() 时默认播放的动画剪辑。 */ + defaultClip: AnimationClip; + /** !#en Current played clip. + !#zh 当前播放的动画剪辑。 */ + currentClip: AnimationClip; + /** !#en Whether the animation should auto play the default clip when start game. + !#zh 是否在运行游戏后自动播放默认动画剪辑。 */ + playOnLoad: boolean; + /** + !#en Get all the clips used in this animation. + !#zh 获取动画组件上的所有动画剪辑。 + */ + getClips(): AnimationClip[]; + /** + !#en Plays an animation and stop other animations. + !#zh 播放指定的动画,并且停止当前正在播放动画。如果没有指定动画,则播放默认动画。 + @param name The name of animation to play. If no name is supplied then the default animation will be played. + @param startTime play an animation from startTime + + @example + ```js + var animCtrl = this.node.getComponent(cc.Animation); + animCtrl.play("linear"); + ``` + */ + play(name?: string, startTime?: number): AnimationState; + /** + !#en + Plays an additive animation, it will not stop other animations. + If there are other animations playing, then will play several animations at the same time. + !#zh 播放指定的动画(将不会停止当前播放的动画)。如果没有指定动画,则播放默认动画。 + @param name The name of animation to play. If no name is supplied then the default animation will be played. + @param startTime play an animation from startTime + + @example + ```js + // linear_1 and linear_2 at the same time playing. + var animCtrl = this.node.getComponent(cc.Animation); + animCtrl.playAdditive("linear_1"); + animCtrl.playAdditive("linear_2"); + ``` + */ + playAdditive(name?: string, startTime?: number): AnimationState; + /** + !#en Stops an animation named name. If no name is supplied then stops all playing animations that were started with this Animation.
+ Stopping an animation also Rewinds it to the Start. + !#zh 停止指定的动画。如果没有指定名字,则停止当前正在播放的动画。 + @param name The animation to stop, if not supplied then stops all playing animations. + */ + stop(name?: string): void; + /** + !#en Pauses an animation named name. If no name is supplied then pauses all playing animations that were started with this Animation. + !#zh 暂停当前或者指定的动画。如果没有指定名字,则暂停当前正在播放的动画。 + @param name The animation to pauses, if not supplied then pauses all playing animations. + */ + pause(name?: string): void; + /** + !#en Resumes an animation named name. If no name is supplied then resumes all paused animations that were started with this Animation. + !#zh 重新播放指定的动画,如果没有指定名字,则重新播放当前正在播放的动画。 + @param name The animation to resumes, if not supplied then resumes all paused animations. + */ + resume(name?: string): void; + /** + !#en Make an animation named name go to the specified time. If no name is supplied then make all animations go to the specified time. + !#zh 设置指定动画的播放时间。如果没有指定名字,则设置当前播放动画的播放时间。 + @param time The time to go to + @param name Specified animation name, if not supplied then make all animations go to the time. + */ + setCurrentTime(time?: number, name?: string): void; + /** + !#en Returns the animation state named name. If no animation with the specified name, the function will return null. + !#zh 获取当前或者指定的动画状态,如果未找到指定动画剪辑则返回 null。 + @param name name + */ + getAnimationState(name: string): AnimationState; + /** + !#en Adds a clip to the animation with name newName. If a clip with that name already exists it will be replaced with the new clip. + !#zh 添加动画剪辑,并且可以重新设置该动画剪辑的名称。 + @param clip the clip to add + @param newName newName + */ + addClip(clip: AnimationClip, newName?: string): AnimationState; + /** + !#en + Remove clip from the animation list. This will remove the clip and any animation states based on it. + If there are animation states depand on the clip are playing or clip is defaultClip, it will not delete the clip. + But if force is true, then will always remove the clip and any animation states based on it. If clip is defaultClip, defaultClip will be reset to null + !#zh + 从动画列表中移除指定的动画剪辑,
+ 如果依赖于 clip 的 AnimationState 正在播放或者 clip 是 defaultClip 的话,默认是不会删除 clip 的。 + 但是如果 force 参数为 true,则会强制停止该动画,然后移除该动画剪辑和相关的动画。这时候如果 clip 是 defaultClip,defaultClip 将会被重置为 null。 + @param clip clip + @param force If force is true, then will always remove the clip and any animation states based on it. + */ + removeClip(clip: AnimationClip, force?: boolean): void; + /** + !#en + Samples animations at the current state.
+ This is useful when you explicitly want to set up some animation state, and sample it once. + !#zh 对指定或当前动画进行采样。你可以手动将动画设置到某一个状态,然后采样一次。 + @param name name + */ + sample(name: string): void; + /** + !#en + Register animation event callback. + The event arguments will provide the AnimationState which emit the event. + When play an animation, will auto register the event callback to the AnimationState, and unregister the event callback from the AnimationState when animation stopped. + !#zh + 注册动画事件回调。 + 回调的事件里将会附上发送事件的 AnimationState。 + 当播放一个动画时,会自动将事件注册到对应的 AnimationState 上,停止播放时会将事件从这个 AnimationState 上取消注册。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + onPlay: function (event) { + var state = event.detail; // state instanceof cc.AnimationState + var type = event.type; // type === 'play'; + } + + // register event to all animation + animation.on('play', this.onPlay, this); + ``` + */ + on(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + on(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Unregister animation event callback. + !#zh + 取消注册动画事件回调。 + @param type A string representing the event type being removed. + @param callback The callback to remove. + @param target The target (this object) to invoke the callback, if it's not given, only callback without target will be removed + @param useCapture Specifies whether the callback being removed was registered as a capturing callback or not. + If not specified, useCapture defaults to false. If a callback was registered twice, + one with capture and one without, each must be removed separately. Removal of a capturing callback + does not affect a non-capturing version of the same listener, and vice versa. + + @example + ```js + // unregister event to all animation + animation.off('play', this.onPlay, this); + ``` + */ + off(type: string, callback: Function, target?: any, useCapture?: boolean): void; + /** + !#en Removes all callbacks previously registered with the same target (passed as parameter). + This is not for removing all listeners in the current event target, + and this is not for removing all listeners the target parameter have registered. + It's only for removing all listeners (callback and target couple) registered on the current event target by the target parameter. + !#zh 在当前 EventTarget 上删除指定目标(target 参数)注册的所有事件监听器。 + 这个函数无法删除当前 EventTarget 的所有事件监听器,也无法删除 target 参数所注册的所有事件监听器。 + 这个函数只能删除 target 参数在当前 EventTarget 上注册的所有事件监听器。 + @param target The target to be searched for all related listeners + */ + targetOff(target: any): void; + /** + !#en + Register an callback of a specific event type on the EventTarget, + the callback will remove itself after the first time it is triggered. + !#zh + 注册事件目标的特定事件类型回调,回调会在第一时间被触发后删除自身。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.once(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + once(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + once(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Dispatches an event into the event flow. + The event target is the EventTarget object upon which the dispatchEvent() method is called. + !#zh 分发事件到事件流中。 + @param event The Event object that is dispatched into the event flow + */ + dispatchEvent(event: Event): void; + /** + !#en + Send an event to this object directly, this method will not propagate the event to any other objects. + The event will be created from the supplied message, you can get the "detail" argument from event.detail. + !#zh + 该对象直接发送事件, 这种方法不会对事件传播到任何其他对象。 + @param message the message to send + @param detail whatever argument the message needs + */ + emit(message: string, detail?: any): void; + } + /** !#en Audio Source. + !#zh 音频源组件,能对音频剪辑。 */ + export class AudioSource extends Component { + /** !#en + Is the audio source playing (Read Only).
+ Note: isPlaying is not supported for Native platforms. + !#zh + 该音频剪辑是否正播放(只读)。
+ 注意:Native 平台暂时不支持 isPlaying。 */ + isPlaying: boolean; + /** !#en The clip of the audio source. + !#zh 默认要播放的音频剪辑。 */ + clip: AudioClip; + /** !#en The volume of the audio source. + !#zh 音频源的音量(0.0 ~ 1.0)。 */ + volume: number; + /** !#en Is the audio source mute? + !#zh 是否静音音频源。Mute 是设置音量为 0,取消静音是恢复原来的音量。 */ + mute: boolean; + /** !#en Is the audio source looping? + !#zh 音频源是否循环播放? */ + loop: boolean; + /** !#en If set to true, the audio source will automatically start playing on onLoad. + !#zh 如果设置为true,音频源将在 onLoad 时自动播放。 */ + playOnLoad: boolean; + /** + !#en Plays the clip. + !#zh 播放音频剪辑。 + */ + play(): void; + /** + !#en Stops the clip. + !#zh 停止当前音频剪辑。 + */ + stop(): void; + /** + !#en Pause the clip. + !#zh 暂停当前音频剪辑。 + */ + pause(): void; + /** + !#en Resume the clip. + !#zh 恢复播放。 + */ + resume(): void; + /** + !#en Rewind playing music. + !#zh 从头开始播放。 + */ + rewind(): void; + /** + !#en Get current time + !#zh 获取当前的播放时间 + */ + getCurrentTime(): void; + /** + !#en Set current time + !#zh 设置当前的播放时间 + @param time time + */ + setCurrentTime(time: number): void; + /** + !#en Get audio duration + !#zh 获取当前音频的长度 + */ + getDuration(): void; + } + /** !#en + This component will block all input events (mouse and touch) within the bounding box of the node, preventing the input from penetrating into the underlying node, typically for the background of the top UI.
+ This component does not have any API interface and can be added directly to the scene to take effect. + !#zh + 该组件将拦截所属节点 bounding box 内的所有输入事件(鼠标和触摸),防止输入穿透到下层节点,一般用于上层 UI 的背景。
+ 该组件没有任何 API 接口,直接添加到场景即可生效。 */ + export class BlockInputEvents extends Component { + } + /** !#en + Button has 4 Transition types + When Button state changed: + If Transition type is Button.Transition.NONE, Button will do nothing + If Transition type is Button.Transition.COLOR, Button will change target's color + If Transition type is Button.Transition.SPRITE, Button will change target Sprite's sprite + If Transition type is Button.Transition.SCALE, Button will change target node's scale + + Button will trigger 5 events: + Button.EVENT_TOUCH_DOWN + Button.EVENT_TOUCH_UP + Button.EVENT_HOVER_IN + Button.EVENT_HOVER_MOVE + Button.EVENT_HOVER_OUT + + !#zh + 按钮组件。可以被按下,或者点击。
+ + 按钮可以通过修改 Transition 来设置按钮状态过渡的方式:
+ -Button.Transition.NONE // 不做任何过渡
+ -Button.Transition.COLOR // 进行颜色之间过渡
+ -Button.Transition.SPRITE // 进行精灵之间过渡
+ -Button.Transition.SCALE // 进行缩放过渡
+ + 按钮可以绑定事件(但是必须要在按钮的 Node 上才能绑定事件):
+ // 以下事件可以在全平台上都触发
+ -cc.Node.EventType.TOUCH_START // 按下时事件
+ -cc.Node.EventType.TOUCH_Move // 按住移动后事件
+ -cc.Node.EventType.TOUCH_END // 按下后松开后事件
+ -cc.Node.EventType.TOUCH_CANCEL // 按下取消事件
+ // 以下事件只在 PC 平台上触发
+ -cc.Node.EventType.MOUSE_DOWN // 鼠标按下时事件
+ -cc.Node.EventType.MOUSE_MOVE // 鼠标按住移动后事件
+ -cc.Node.EventType.MOUSE_ENTER // 鼠标进入目标事件
+ -cc.Node.EventType.MOUSE_LEAVE // 鼠标离开目标事件
+ -cc.Node.EventType.MOUSE_UP // 鼠标松开事件
+ -cc.Node.EventType.MOUSE_WHEEL // 鼠标滚轮事件
*/ + export class Button extends Component { + /** !#en + Whether the Button is disabled. + If true, the Button will trigger event and do transition. + !#zh + 按钮事件是否被响应,如果为 false,则按钮将被禁用。 */ + interactable: boolean; + /** !#en When this flag is true, Button target sprite will turn gray when interactable is false. + !#zh 如果这个标记为 true,当 button 的 interactable 属性为 false 的时候,会使用内置 shader 让 button 的 target 节点的 sprite 组件变灰 */ + enableAutoGrayEffect: boolean; + /** !#en Transition type + !#zh 按钮状态改变时过渡方式。 */ + transition: Button.Transition; + /** !#en Normal state color. + !#zh 普通状态下按钮所显示的颜色。 */ + normalColor: Color; + /** !#en Pressed state color + !#zh 按下状态时按钮所显示的颜色。 */ + pressedColor: Color; + /** !#en Hover state color + !#zh 悬停状态下按钮所显示的颜色。 */ + hoverColor: Color; + /** !#en Disabled state color + !#zh 禁用状态下按钮所显示的颜色。 */ + disabledColor: Color; + /** !#en Color and Scale transition duration + !#zh 颜色过渡和缩放过渡时所需时间 */ + duration: number; + /** !#en When user press the button, the button will zoom to a scale. + The final scale of the button equals (button original scale * zoomScale) + !#zh 当用户点击按钮后,按钮会缩放到一个值,这个值等于 Button 原始 scale * zoomScale */ + zoomScale: number; + /** !#en Normal state sprite + !#zh 普通状态下按钮所显示的 Sprite 。 */ + normalSprite: SpriteFrame; + /** !#en Pressed state sprite + !#zh 按下状态时按钮所显示的 Sprite 。 */ + pressedSprite: SpriteFrame; + /** !#en Hover state sprite + !#zh 悬停状态下按钮所显示的 Sprite 。 */ + hoverSprite: SpriteFrame; + /** !#en Disabled state sprite + !#zh 禁用状态下按钮所显示的 Sprite 。 */ + disabledSprite: SpriteFrame; + /** !#en + Transition target. + When Button state changed: + If Transition type is Button.Transition.NONE, Button will do nothing + If Transition type is Button.Transition.COLOR, Button will change target's color + If Transition type is Button.Transition.SPRITE, Button will change target Sprite's sprite + !#zh + 需要过渡的目标。 + 当前按钮状态改变规则: + -如果 Transition type 选择 Button.Transition.NONE,按钮不做任何过渡。 + -如果 Transition type 选择 Button.Transition.COLOR,按钮会对目标颜色进行颜色之间的过渡。 + -如果 Transition type 选择 Button.Transition.Sprite,按钮会对目标 Sprite 进行 Sprite 之间的过渡。 */ + target: Node; + /** !#en If Button is clicked, it will trigger event's handler + !#zh 按钮的点击事件列表。 */ + clickEvents: Component.EventHandler[]; + } + /** !#zh: 作为 UI 根节点,为所有子节点提供视窗四边的位置信息以供对齐,另外提供屏幕适配策略接口,方便从编辑器设置。 + 注:由于本节点的尺寸会跟随屏幕拉伸,所以 anchorPoint 只支持 (0.5, 0.5),否则适配不同屏幕时坐标会有偏差。 */ + export class Canvas extends Component { + /** !#en Current active canvas, the scene should only have one active canvas at the same time. + !#zh 当前激活的画布组件,场景同一时间只能有一个激活的画布。 */ + static instance: Canvas; + /** !#en The desigin resolution for current scene. + !#zh 当前场景设计分辨率。 */ + designResolution: Size; + /** !#en TODO + !#zh: 是否优先将设计分辨率高度撑满视图高度。 */ + fitHeight: boolean; + /** !#en TODO + !#zh: 是否优先将设计分辨率宽度撑满视图宽度。 */ + fitWidth: boolean; + } + /** !#en + Base class for everything attached to Node(Entity).
+
+ NOTE: Not allowed to use construction parameters for Component's subclasses, + because Component is created by the engine. + !#zh + 所有附加到节点的基类。
+
+ 注意:不允许使用组件的子类构造参数,因为组件是由引擎创建的。 */ + export class Component extends Object { + /** !#en The node this component is attached to. A component is always attached to a node. + !#zh 该组件被附加到的节点。组件总会附加到一个节点。 */ + node: Node; + /** !#en The uuid for editor. + !#zh 组件的 uuid,用于编辑器。 */ + uuid: string; + /** !#en indicates whether this component is enabled or not. + !#zh 表示该组件自身是否启用。 */ + enabled: boolean; + /** !#en indicates whether this component is enabled and its node is also active in the hierarchy. + !#zh 表示该组件是否被启用并且所在的节点也处于激活状态。 */ + enabledInHierarchy: boolean; + /** !#en Returns a value which used to indicate the onLoad get called or not. + !#zh 返回一个值用来判断 onLoad 是否被调用过,不等于 0 时调用过,等于 0 时未调用。 */ + _isOnLoadCalled: number; + /** + !#en Update is called every frame, if the Component is enabled. + !#zh 如果该组件启用,则每帧调用 update。 + @param dt the delta time in seconds it took to complete the last frame + */ + protected update(dt: number): void; + /** + !#en LateUpdate is called every frame, if the Component is enabled. + !#zh 如果该组件启用,则每帧调用 LateUpdate。 + */ + protected lateUpdate(): void; + /** + !#en + When attaching to an active node or its node first activated. + onLoad is always called before any start functions, this allows you to order initialization of scripts. + !#zh + 当附加到一个激活的节点上或者其节点第一次激活时候调用。onLoad 总是会在任何 start 方法调用前执行,这能用于安排脚本的初始化顺序。 + */ + protected onLoad(): void; + /** + !#en + Called before all scripts' update if the Component is enabled the first time. + Usually used to initialize some logic which need to be called after all components' `onload` methods called. + !#zh + 如果该组件第一次启用,则在所有组件的 update 之前调用。通常用于需要在所有组件的 onLoad 初始化完毕后执行的逻辑。 + */ + protected start(): void; + /** + !#en Called when this component becomes enabled and its node is active. + !#zh 当该组件被启用,并且它的节点也激活时。 + */ + protected onEnable(): void; + /** + !#en Called when this component becomes disabled or its node becomes inactive. + !#zh 当该组件被禁用或节点变为无效时调用。 + */ + protected onDisable(): void; + /** + !#en Called when this component will be destroyed. + !#zh 当该组件被销毁时调用 + */ + protected onDestroy(): void; + protected onFocusInEditor(): void; + protected onLostFocusInEditor(): void; + /** + !#en Called to initialize the component or node’s properties when adding the component the first time or when the Reset command is used. This function is only called in editor. + !#zh 用来初始化组件或节点的一些属性,当该组件被第一次添加到节点上或用户点击了它的 Reset 菜单时调用。这个回调只会在编辑器下调用。 + */ + protected resetInEditor(): void; + /** + !#en Adds a component class to the node. You can also add component to node by passing in the name of the script. + !#zh 向节点添加一个组件类,你还可以通过传入脚本的名称来添加组件。 + @param typeOrClassName the constructor or the class name of the component to add + + @example + ```js + var sprite = node.addComponent(cc.Sprite); + var test = node.addComponent("Test"); + ``` + */ + addComponent(type: {new(): T}): T; + addComponent(className: string): any; + /** + !#en + Returns the component of supplied type if the node has one attached, null if it doesn't.
+ You can also get component in the node by passing in the name of the script. + !#zh + 获取节点上指定类型的组件,如果节点有附加指定类型的组件,则返回,如果没有则为空。
+ 传入参数也可以是脚本的名称。 + @param typeOrClassName typeOrClassName + + @example + ```js + // get sprite component. + var sprite = node.getComponent(cc.Sprite); + // get custom test calss. + var test = node.getComponent("Test"); + ``` + */ + getComponent(type: {prototype: T}): T; + getComponent(className: string): any; + /** + !#en Returns all components of supplied Type in the node. + !#zh 返回节点上指定类型的所有组件。 + @param typeOrClassName typeOrClassName + + @example + ```js + var sprites = node.getComponents(cc.Sprite); + var tests = node.getComponents("Test"); + ``` + */ + getComponents(type: {prototype: T}): T[]; + getComponents(className: string): any[]; + /** + !#en Returns the component of supplied type in any of its children using depth first search. + !#zh 递归查找所有子节点中第一个匹配指定类型的组件。 + @param typeOrClassName typeOrClassName + + @example + ```js + var sprite = node.getComponentInChildren(cc.Sprite); + var Test = node.getComponentInChildren("Test"); + ``` + */ + getComponentInChildren(type: {prototype: T}): T; + getComponentInChildren(className: string): any; + /** + !#en Returns the components of supplied type in self or any of its children using depth first search. + !#zh 递归查找自身或所有子节点中指定类型的组件 + @param typeOrClassName typeOrClassName + + @example + ```js + var sprites = node.getComponentsInChildren(cc.Sprite); + var tests = node.getComponentsInChildren("Test"); + ``` + */ + getComponentsInChildren(type: {prototype: T}): T[]; + getComponentsInChildren(className: string): any[]; + /** + !#en + If the component's bounding box is different from the node's, you can implement this method to supply + a custom axis aligned bounding box (AABB), so the editor's scene view can perform hit test properly. + !#zh + 如果组件的包围盒与节点不同,您可以实现该方法以提供自定义的轴向对齐的包围盒(AABB), + 以便编辑器的场景视图可以正确地执行点选测试。 + @param out_rect the Rect to receive the bounding box + */ + _getLocalBounds(out_rect: Rect): void; + /** + !#en + onRestore is called after the user clicks the Reset item in the Inspector's context menu or performs + an undo operation on this component.
+
+ If the component contains the "internal state", short for "temporary member variables which not included
+ in its CCClass properties", then you may need to implement this function.
+
+ The editor will call the getset accessors of your component to record/restore the component's state
+ for undo/redo operation. However, in extreme cases, it may not works well. Then you should implement
+ this function to manually synchronize your component's "internal states" with its public properties.
+ Once you implement this function, all the getset accessors of your component will not be called when
+ the user performs an undo/redo operation. Which means that only the properties with default value
+ will be recorded or restored by editor.
+
+ Similarly, the editor may failed to reset your component correctly in extreme cases. Then if you need
+ to support the reset menu, you should manually synchronize your component's "internal states" with its
+ properties in this function. Once you implement this function, all the getset accessors of your component
+ will not be called during reset operation. Which means that only the properties with default value
+ will be reset by editor. + + This function is only called in editor mode. + !#zh + onRestore 是用户在检查器菜单点击 Reset 时,对此组件执行撤消操作后调用的。
+
+ 如果组件包含了“内部状态”(不在 CCClass 属性中定义的临时成员变量),那么你可能需要实现该方法。
+
+ 编辑器执行撤销/重做操作时,将调用组件的 get set 来录制和还原组件的状态。 + 然而,在极端的情况下,它可能无法良好运作。
+ 那么你就应该实现这个方法,手动根据组件的属性同步“内部状态”。 + 一旦你实现这个方法,当用户撤销或重做时,组件的所有 get set 都不会再被调用。 + 这意味着仅仅指定了默认值的属性将被编辑器记录和还原。
+
+ 同样的,编辑可能无法在极端情况下正确地重置您的组件。
+ 于是如果你需要支持组件重置菜单,你需要在该方法中手工同步组件属性到“内部状态”。
+ 一旦你实现这个方法,组件的所有 get set 都不会在重置操作时被调用。 + 这意味着仅仅指定了默认值的属性将被编辑器重置。 +
+ 此方法仅在编辑器下会被调用。 + */ + onRestore(): void; + /** + !#en + Schedules a custom selector.
+ If the selector is already scheduled, then the interval parameter will be updated without scheduling it again. + !#zh + 调度一个自定义的回调函数。
+ 如果回调函数已调度,那么将不会重复调度它,只会更新时间间隔参数。 + @param callback The callback function + @param interval Tick interval in seconds. 0 means tick every frame. If interval = 0, it's recommended to use scheduleUpdate() instead. + @param repeat The selector will be executed (repeat + 1) times, you can use kCCRepeatForever for tick infinitely. + @param delay The amount of time that the first tick will wait before execution. + + @example + ```js + var timeCallback = function (dt) { + cc.log("time: " + dt); + } + this.schedule(timeCallback, 1); + ``` + */ + schedule(callback: Function, interval?: number, repeat?: number, delay?: number): void; + /** + !#en Schedules a callback function that runs only once, with a delay of 0 or larger. + !#zh 调度一个只运行一次的回调函数,可以指定 0 让回调函数在下一帧立即执行或者在一定的延时之后执行。 + @param callback A function wrapped as a selector + @param delay The amount of time that the first tick will wait before execution. + + @example + ```js + var timeCallback = function (dt) { + cc.log("time: " + dt); + } + this.scheduleOnce(timeCallback, 2); + ``` + */ + scheduleOnce(callback: Function, delay?: number): void; + /** + !#en Unschedules a custom callback function. + !#zh 取消调度一个自定义的回调函数。 + @param callback_fn A function wrapped as a selector + + @example + ```js + this.unschedule(_callback); + ``` + */ + unschedule(callback_fn: Function): void; + /** + !#en + unschedule all scheduled callback functions: custom callback functions, and the 'update' callback function.
+ Actions are not affected by this method. + !#zh 取消调度所有已调度的回调函数:定制的回调函数以及 'update' 回调函数。动作不受此方法影响。 + + @example + ```js + this.unscheduleAllCallbacks(); + ``` + */ + unscheduleAllCallbacks(): void; + } + /** !#en cc.EditBox is a component for inputing text, you can use it to gather small amounts of text from users. + !#zh EditBox 组件,用于获取用户的输入文本。 */ + export class EditBox extends _RendererUnderSG { + /** !#en Input string of EditBox. + !#zh 输入框的初始输入内容,如果为空则会显示占位符的文本。 */ + string: string; + /** !#en The background image of EditBox. + !#zh 输入框的背景图片 */ + backgroundImage: SpriteFrame; + /** !#en + The return key type of EditBox. + Note: it is meaningless for web platforms and desktop platforms. + !#zh + 指定移动设备上面回车按钮的样式。 + 注意:这个选项对 web 平台与 desktop 平台无效。 */ + returnType: EditBox.KeyboardReturnType; + /** !#en Set the input flags that are to be applied to the EditBox. + !#zh 指定输入标志位,可以指定输入方式为密码或者单词首字母大写。 */ + inputFlag: EditBox.InputFlag; + /** !#en + Set the input mode of the edit box. + If you pass ANY, it will create a multiline EditBox. + !#zh + 指定输入模式: ANY表示多行输入,其它都是单行输入,移动平台上还可以指定键盘样式。 */ + inputMode: EditBox.InputMode; + /** !#en Font size of the input text. + !#zh 输入框文本的字体大小 */ + fontSize: number; + /** !#en Change the lineHeight of displayed text. + !#zh 输入框文本的行高。 */ + lineHeight: number; + /** !#en Font color of the input text. + !#zh 输入框文本的颜色。 */ + fontColor: Color; + /** !#en The display text of placeholder. + !#zh 输入框占位符的文本内容。 */ + placeholder: string; + /** !#en The font size of placeholder. + !#zh 输入框占位符的字体大小。 */ + placeholderFontSize: number; + /** !#en The font color of placeholder. + !#zh 输入框最大允许输入的字符个数。 */ + placeholderFontColor: Color; + /** !#en The maximize input length of EditBox. + - If pass a value less than 0, it won't limit the input number of characters. + - If pass 0, it doesn't allow input any characters. + !#zh 输入框最大允许输入的字符个数。 + - 如果值为小于 0 的值,则不会限制输入字符个数。 + - 如果值为 0,则不允许用户进行任何输入。 */ + maxLength: number; + /** !#en The input is always visible and be on top of the game view. + !zh 输入框总是可见,并且永远在游戏视图的上面 + Note: only available on Web at the moment. */ + stayOnTop: boolean; + /** !#en Set the tabIndex of the DOM input element, only useful on Web. + !#zh 修改 DOM 输入元素的 tabIndex,这个属性只有在 Web 上面修改有意义。 */ + tabIndex: number; + /** !#en The event handler to be called when EditBox began to edit text. + !#zh 开始编辑文本输入框触发的事件回调。 */ + editingDidBegan: Component.EventHandler[]; + /** !#en The event handler to be called when EditBox text changes. + !#zh 编辑文本输入框时触发的事件回调。 */ + textChanged: Component.EventHandler[]; + /** !#en The event handler to be called when EditBox edit ends. + !#zh 结束编辑文本输入框时触发的事件回调。 */ + editingDidEnded: Component.EventHandler[]; + /** !#en The event handler to be called when return key is pressed. Windows is not supported. + !#zh 当用户按下回车按键时的事件回调,目前不支持 windows 平台 */ + editingReturn: Component.EventHandler[]; + /** + !#en Let the EditBox get focus, only valid when stayOnTop is true. + !#zh 让当前 EditBox 获得焦点,只有在 stayOnTop 为 true 的时候设置有效 + Note: only available on Web at the moment. + */ + setFocus(): void; + /** + !#en Determine whether EditBox is getting focus or not. + !#zh 判断 EditBox 是否获得了焦点 + Note: only available on Web at the moment. + */ + isFocused(): void; + /** + !#en if you don't need the EditBox and it isn't in any running Scene, you should + call the destroy method on this component or the associated node explicitly. + Otherwise, the created DOM element won't be removed from web page. + !#zh + 如果你不再使用 EditBox,并且组件未添加到场景中,那么你必须手动对组件或所在节点调用 destroy。 + 这样才能移除网页上的 DOM 节点,避免 Web 平台内存泄露。 + + @example + ```js + editbox.node.parent = null; // or editbox.node.removeFromParent(false); + // when you don't need editbox anymore + editbox.node.destroy(); + ``` + */ + destroy(): boolean; + } + /** !#en The Label Component. + !#zh 文字标签组件 */ + export class Label extends _RendererUnderSG { + /** !#en Content string of label. + !#zh 标签显示的文本内容。 */ + string: string; + /** !#en Horizontal Alignment of label. + !#zh 文本内容的水平对齐方式。 */ + horizontalAlign: Label.HorizontalAlign; + /** !#en Vertical Alignment of label. + !#zh 文本内容的垂直对齐方式。 */ + verticalAlign: Label.VerticalAlign; + /** !#en The actual rendering font size in shrink mode + !#zh SHRINK 模式下面文本实际渲染的字体大小 */ + actualFontSize: number; + /** !#en Font size of label. + !#zh 文本字体大小。 */ + fontSize: number; + /** !#en Font family of label, only take effect when useSystemFont property is true. + !#zh 文本字体名称, 只在 useSystemFont 属性为 true 的时候生效。 */ + fontFamily: string; + /** !#en Line Height of label. + !#zh 文本行高。 */ + lineHeight: number; + /** !#en Overflow of label. + !#zh 文字显示超出范围时的处理方式。 */ + overflow: Label.Overflow; + /** !#en Whether auto wrap label when string width is large than label width. + !#zh 是否自动换行。 */ + enableWrapText: boolean; + /** !#en The font of label. + !#zh 文本字体。 */ + font: Font; + /** !#en Whether use system font name or not. + !#zh 是否使用系统字体。 */ + isSystemFontUsed: boolean; + } + /** !#en Outline effect used to change the display, only used for TTF font + !#zh 描边效果组件,用于字体描边,只能用于系统字体 */ + export class LabelOutline extends Component { + /** !#en Change the outline color + !#zh 改变描边的颜色 */ + color: Color; + /** !#en Change the outline width + !#zh 改变描边的宽度 */ + width: number; + } + /** !#en + The Layout is a container component, use it to arrange child elements easily.
+ Note:
+ 1.Scaling and rotation of child nodes are not considered.
+ 2.After setting the Layout, the results need to be updated until the next frame, + unless you manually call {{#crossLink "Layout/updateLayout:method"}}{{/crossLink}}。 + !#zh + Layout 组件相当于一个容器,能自动对它的所有子节点进行统一排版。
+ 注意:
+ 1.不会考虑子节点的缩放和旋转。
+ 2.对 Layout 设置后结果需要到下一帧才会更新,除非你设置完以后手动调用 {{#crossLink "Layout/updateLayout:method"}}{{/crossLink}}。 */ + export class Layout extends Component { + /** !#en The layout type. + !#zh 布局类型 */ + type: Layout.Type; + /** !#en + The are three resize modes for Layout. + None, resize Container and resize children. + !#zh 缩放模式 */ + resizeMode: Layout.ResizeMode; + /** !#en The cell size for grid layout. + !#zh 每个格子的大小,只有布局类型为 GRID 的时候才有效。 */ + cellSize: Size; + /** !#en + The start axis for grid layout. If you choose horizontal, then children will layout horizontally at first, + and then break line on demand. Choose vertical if you want to layout vertically at first . + !#zh 起始轴方向类型,可进行水平和垂直布局排列,只有布局类型为 GRID 的时候才有效。 */ + startAxis: Layout.AxisDirection; + /** !#en The left padding of layout, it only effect the layout in one direction. + !#zh 容器内左边距,只会在一个布局方向上生效。 */ + paddingLeft: number; + /** !#en The right padding of layout, it only effect the layout in one direction. + !#zh 容器内右边距,只会在一个布局方向上生效。 */ + paddingRight: number; + /** !#en The top padding of layout, it only effect the layout in one direction. + !#zh 容器内上边距,只会在一个布局方向上生效。 */ + paddingTop: number; + /** !#en The bottom padding of layout, it only effect the layout in one direction. + !#zh 容器内下边距,只会在一个布局方向上生效。 */ + paddingBottom: number; + /** !#en The distance in x-axis between each element in layout. + !#zh 子节点之间的水平间距。 */ + spacingX: number; + /** !#en The distance in y-axis between each element in layout. + !#zh 子节点之间的垂直间距。 */ + spacingY: number; + /** !#en + Only take effect in Vertical layout mode. + This option changes the start element's positioning. + !#zh 垂直排列子节点的方向。 */ + verticalDirection: Layout.VerticalDirection; + /** !#en + Only take effect in Horizontal layout mode. + This option changes the start element's positioning. + !#zh 水平排列子节点的方向。 */ + horizontalDirection: Layout.HorizontalDirection; + /** + !#en Perform the layout update + !#zh 立即执行更新布局 + + @example + ```js + layout.type = cc.Layout.HORIZONTAL; + layout.node.addChild(childNode); + cc.log(childNode.x); // not yet changed + layout.updateLayout(); + cc.log(childNode.x); // changed + ``` + */ + updateLayout(): void; + /** !#en The padding of layout, it effects the layout in four direction. + !#zh 容器内边距,该属性会在四个布局方向上生效。 */ + padding: number; + } + /** !#en The Mask Component + !#zh 遮罩组件 */ + export class Mask extends _RendererInSG { + /** !#en The mask type. + !#zh 遮罩类型 */ + type: Mask.Type; + /** !#en The mask image + !#zh 遮罩所需要的贴图 */ + spriteFrame: SpriteFrame; + /** !#en + The alpha threshold.(Not supported Canvas Mode)
+ The content is drawn only where the stencil have pixel with alpha greater than the alphaThreshold.
+ Should be a float between 0 and 1.
+ This default to 1 (so alpha test is disabled). + !#zh + Alpha 阈值(不支持 Canvas 模式)
+ 只有当模板的像素的 alpha 大于 alphaThreshold 时,才会绘制内容。
+ 该数值 0 ~ 1 之间的浮点数,默认值为 1(因此禁用 alpha) */ + alphaThreshold: number; + /** !#en Reverse mask (Not supported Canvas Mode) + !#zh 反向遮罩(不支持 Canvas 模式) */ + inverted: boolean; + /** !#en The segements for ellipse mask. + !#zh 椭圆遮罩的曲线细分数 */ + segements: number; + } + /** !#en The PageView control + !#zh 页面视图组件 */ + export class PageView extends ScrollView { + /** !#en Specify the size type of each page in PageView. + !#zh 页面视图中每个页面大小类型 */ + sizeMode: PageView.SizeMode; + /** !#en The page view direction + !#zh 页面视图滚动类型 */ + direction: PageView.Direction; + /** !#en + The scroll threshold value, when drag exceeds this value, + release the next page will automatically scroll, less than the restore + !#zh 滚动临界值,默认单位百分比,当拖拽超出该数值时,松开会自动滚动下一页,小于时则还原。 */ + scrollThreshold: number; + /** !#en + Auto page turning velocity threshold. When users swipe the PageView quickly, + it will calculate a velocity based on the scroll distance and time, + if the calculated velocity is larger than the threshold, then it will trigger page turning. + !#zh + 快速滑动翻页临界值。 + 当用户快速滑动时,会根据滑动开始和结束的距离与时间计算出一个速度值, + 该值与此临界值相比较,如果大于临界值,则进行自动翻页。 */ + autoPageTurningThreshold: number; + /** !#en Change the PageTurning event timing of PageView. + !#zh 设置 PageView PageTurning 事件的发送时机。 */ + pageTurningEventTiming: number; + /** !#en The Page View Indicator + !#zh 页面视图指示器组件 */ + indicator: PageViewIndicator; + /** !#en The time required to turn over a page. unit: second + !#zh 每个页面翻页时所需时间。单位:秒 */ + pageTurningSpeed: number; + /** !#en PageView events callback + !#zh 滚动视图的事件回调函数 */ + pageEvents: Component.EventHandler[]; + /** + !#en Returns current page index + !#zh 返回当前页面索引 + */ + getCurrentPageIndex(): number; + /** + !#en Set current page index + !#zh 设置当前页面索引 + @param index index + */ + setCurrentPageIndex(index: number): void; + /** + !#en Returns all pages of pageview + !#zh 返回视图中的所有页面 + */ + getPages(): Node[]; + /** + !#en At the end of the current page view to insert a new view + !#zh 在当前页面视图的尾部插入一个新视图 + @param page page + */ + addPage(page: Node): void; + /** + !#en Inserts a page in the specified location + !#zh 将页面插入指定位置中 + @param page page + @param index index + */ + insertPage(page: Node, index: number): void; + /** + !#en Removes a page from PageView. + !#zh 移除指定页面 + @param page page + */ + removePage(page: Node): void; + /** + !#en Removes a page at index of PageView. + !#zh 移除指定下标的页面 + @param index index + */ + removePageAtIndex(index: number): void; + /** + !#en Removes all pages from PageView + !#zh 移除所有页面 + */ + removeAllPages(): void; + /** + !#en Scroll PageView to index. + !#zh 滚动到指定页面 + @param idx index of page. + @param timeInSecond scrolling time + */ + scrollToPage(idx: number, timeInSecond: number): void; + } + /** !#en The Page View Indicator Component + !#zh 页面视图每页标记组件 */ + export class PageViewIndicator extends Component { + /** !#en The spriteFrame for each element. + !#zh 每个页面标记显示的图片 */ + spriteFrame: SpriteFrame; + /** !#en The location direction of PageViewIndicator. + !#zh 页面标记摆放方向 */ + direction: PageViewIndicator.Direction; + /** !#en The cellSize for each element. + !#zh 每个页面标记的大小 */ + cellSize: Size; + /** !#en The distance between each element. + !#zh 每个页面标记之间的边距 */ + spacing: number; + /** + !#en Set Page View + !#zh 设置页面视图 + @param target target + */ + setPageView(target: PageView): void; + } + /** !#en + Visual indicator of progress in some operation. + Displays a bar to the user representing how far the operation has progressed. + !#zh + 进度条组件,可用于显示加载资源时的进度。 */ + export class ProgressBar extends Component { + /** !#en The targeted Sprite which will be changed progressively. + !#zh 用来显示进度条比例的 Sprite 对象。 */ + barSprite: Sprite; + /** !#en The progress mode, there are two modes supported now: horizontal and vertical. + !#zh 进度条的模式 */ + mode: ProgressBar.Mode; + /** !#en The total width or height of the bar sprite. + !#zh 进度条实际的总长度 */ + totalLength: number; + /** !#en The current progress of the bar sprite. The valid value is between 0-1. + !#zh 当前进度值,该数值的区间是 0-1 之间。 */ + progress: number; + /** !#en Whether reverse the progress direction of the bar sprite. + !#zh 进度条是否进行反方向变化。 */ + reverse: boolean; + } + /** Rendering component in scene graph. + Maintains a node which will be the scene graph of component's Node. */ + export class _RendererInSG extends _SGComponent { + } + /** The base rendering component which will attach a leaf node to the cocos2d scene graph. */ + export class _RendererUnderSG extends _SGComponent { + } + /** !#en The RichText Component. + !#zh 富文本组件 */ + export class RichText extends Component { + /** !#en Content string of RichText. + !#zh 富文本显示的文本内容。 */ + string: string; + /** !#en Horizontal Alignment of each line in RichText. + !#zh 文本内容的水平对齐方式。 */ + horizontalAlign: TextAlignment; + /** !#en Font size of RichText. + !#zh 富文本字体大小。 */ + fontSize: number; + /** !#en Custom TTF font of RichText + !#zh 富文本定制字体 */ + font: cc.TTFFont; + /** !#en The maximize width of the RichText + !#zh 富文本的最大宽度 */ + maxWidth: number; + /** !#en Line Height of RichText. + !#zh 富文本行高。 */ + lineHeight: number; + /** !#en The image atlas for the img tag. For each src value in the img tag, there should be a valid spriteFrame in the image atlas. + !#zh 对于 img 标签里面的 src 属性名称,都需要在 imageAtlas 里面找到一个有效的 spriteFrame,否则 img tag 会判定为无效。 */ + imageAtlas: SpriteAtlas; + /** !#en + Once checked, the RichText will block all input events (mouse and touch) within + the bounding box of the node, preventing the input from penetrating into the underlying node. + !#zh + 选中此选项后,RichText 将阻止节点边界框中的所有输入事件(鼠标和触摸),从而防止输入事件穿透到底层节点。 */ + handleTouchEvent: boolean; + } + /** The base class for all rendering component in scene graph. + + You should override: + - _createSgNode + - _initSgNode */ + export class _SGComponent extends Component { + } + /** !#en + The Scrollbar control allows the user to scroll an image or other view that is too large to see completely + !#zh 滚动条组件 */ + export class Scrollbar extends Component { + /** !#en The "handle" part of the scrollbar. + !#zh 作为当前滚动区域位置显示的滑块 Sprite。 */ + handle: Sprite; + /** !#en The direction of scrollbar. + !#zh ScrollBar 的滚动方向。 */ + direction: Scrollbar.Direction; + /** !#en Whether enable auto hide or not. + !#zh 是否在没有滚动动作时自动隐藏 ScrollBar。 */ + enableAutoHide: boolean; + /** !#en + The time to hide scrollbar when scroll finished. + Note: This value is only useful when enableAutoHide is true. + !#zh + 没有滚动动作后经过多久会自动隐藏。 + 注意:只要当 “enableAutoHide” 为 true 时,才有效。 */ + autoHideTime: number; + } + /** !#en + Layout container for a view hierarchy that can be scrolled by the user, + allowing it to be larger than the physical display. + + !#zh + 滚动视图组件 */ + export class ScrollView extends Component { + /** !#en This is a reference to the UI element to be scrolled. + !#zh 可滚动展示内容的节点。 */ + content: Node; + /** !#en Enable horizontal scroll. + !#zh 是否开启水平滚动。 */ + horizontal: boolean; + /** !#en Enable vertical scroll. + !#zh 是否开启垂直滚动。 */ + vertical: boolean; + /** !#en When inertia is set, the content will continue to move when touch ended. + !#zh 是否开启滚动惯性。 */ + inertia: boolean; + /** !#en + It determines how quickly the content stop moving. A value of 1 will stop the movement immediately. + A value of 0 will never stop the movement until it reaches to the boundary of scrollview. + !#zh + 开启惯性后,在用户停止触摸后滚动多快停止,0表示永不停止,1表示立刻停止。 */ + brake: number; + /** !#en When elastic is set, the content will be bounce back when move out of boundary. + !#zh 是否允许滚动内容超过边界,并在停止触摸后回弹。 */ + elastic: boolean; + /** !#en The elapse time of bouncing back. A value of 0 will bounce back immediately. + !#zh 回弹持续的时间,0 表示将立即反弹。 */ + bounceDuration: number; + /** !#en The horizontal scrollbar reference. + !#zh 水平滚动的 ScrollBar。 */ + horizontalScrollBar: Scrollbar; + /** !#en The vertical scrollbar reference. + !#zh 垂直滚动的 ScrollBar。 */ + verticalScrollBar: Scrollbar; + /** !#en Scrollview events callback + !#zh 滚动视图的事件回调函数 */ + scrollEvents: Component.EventHandler[]; + /** !#en If cancelInnerEvents is set to true, the scroll behavior will cancel touch events on inner content nodes + It's set to true by default. + !#zh 如果这个属性被设置为 true,那么滚动行为会取消子节点上注册的触摸事件,默认被设置为 true。 + 注意,子节点上的 touchstart 事件仍然会触发,触点移动距离非常短的情况下 touchmove 和 touchend 也不会受影响。 */ + cancelInnerEvents: boolean; + /** + !#en Scroll the content to the bottom boundary of ScrollView. + !#zh 视图内容将在规定时间内滚动到视图底部。 + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the bottom boundary immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to the bottom of the view. + scrollView.scrollToBottom(0.1); + ``` + */ + scrollToBottom(timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll the content to the top boundary of ScrollView. + !#zh 视图内容将在规定时间内滚动到视图顶部。 + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the top boundary immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to the top of the view. + scrollView.scrollToTop(0.1); + ``` + */ + scrollToTop(timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll the content to the left boundary of ScrollView. + !#zh 视图内容将在规定时间内滚动到视图左边。 + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the left boundary immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to the left of the view. + scrollView.scrollToLeft(0.1); + ``` + */ + scrollToLeft(timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll the content to the right boundary of ScrollView. + !#zh 视图内容将在规定时间内滚动到视图右边。 + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the right boundary immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to the right of the view. + scrollView.scrollToRight(0.1); + ``` + */ + scrollToRight(timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll the content to the top left boundary of ScrollView. + !#zh 视图内容将在规定时间内滚动到视图左上角。 + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the top left boundary immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to the upper left corner of the view. + scrollView.scrollToTopLeft(0.1); + ``` + */ + scrollToTopLeft(timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll the content to the top right boundary of ScrollView. + !#zh 视图内容将在规定时间内滚动到视图右上角。 + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the top right boundary immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to the top right corner of the view. + scrollView.scrollToTopRight(0.1); + ``` + */ + scrollToTopRight(timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll the content to the bottom left boundary of ScrollView. + !#zh 视图内容将在规定时间内滚动到视图左下角。 + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the bottom left boundary immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to the lower left corner of the view. + scrollView.scrollToBottomLeft(0.1); + ``` + */ + scrollToBottomLeft(timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll the content to the bottom right boundary of ScrollView. + !#zh 视图内容将在规定时间内滚动到视图右下角。 + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the bottom right boundary immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to the lower right corner of the view. + scrollView.scrollToBottomRight(0.1); + ``` + */ + scrollToBottomRight(timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll with an offset related to the ScrollView's top left origin, if timeInSecond is omitted, then it will jump to the + specific offset immediately. + !#zh 视图内容在规定时间内将滚动到 ScrollView 相对左上角原点的偏移位置, 如果 timeInSecond参数不传,则立即滚动到指定偏移位置。 + @param offset A Vec2, the value of which each axis between 0 and maxScrollOffset + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the specific offset of ScrollView immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to middle position in 0.1 second in x-axis + var maxScrollOffset = this.getMaxScrollOffset(); + scrollView.scrollToOffset(cc.p(maxScrollOffset.x / 2, 0), 0.1); + ``` + */ + scrollToOffset(offset: Vec2, timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Get the positive offset value corresponds to the content's top left boundary. + !#zh 获取滚动视图相对于左上角原点的当前滚动偏移 + */ + getScrollOffset(): Vec2; + /** + !#en Get the maximize available scroll offset + !#zh 获取滚动视图最大可以滚动的偏移量 + */ + getMaxScrollOffset(): Vec2; + /** + !#en Scroll the content to the horizontal percent position of ScrollView. + !#zh 视图内容在规定时间内将滚动到 ScrollView 水平方向的百分比位置上。 + @param percent A value between 0 and 1. + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the horizontal percent position of ScrollView immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Scroll to middle position. + scrollView.scrollToBottomRight(0.5, 0.1); + ``` + */ + scrollToPercentHorizontal(percent: number, timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll the content to the percent position of ScrollView in any direction. + !#zh 视图内容在规定时间内进行垂直方向和水平方向的滚动,并且滚动到指定百分比位置上。 + @param anchor A point which will be clamp between cc.p(0,0) and cc.p(1,1). + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the percent position of ScrollView immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + + @example + ```js + // Vertical scroll to the bottom of the view. + scrollView.scrollTo(cc.p(0, 1), 0.1); + + // Horizontal scroll to view right. + scrollView.scrollTo(cc.p(1, 0), 0.1); + ``` + */ + scrollTo(anchor: Vec2, timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Scroll the content to the vertical percent position of ScrollView. + !#zh 视图内容在规定时间内滚动到 ScrollView 垂直方向的百分比位置上。 + @param percent A value between 0 and 1. + @param timeInSecond Scroll time in second, if you don't pass timeInSecond, + the content will jump to the vertical percent position of ScrollView immediately. + @param attenuated Whether the scroll acceleration attenuated, default is true. + // Scroll to middle position. + scrollView.scrollToPercentVertical(0.5, 0.1); + */ + scrollToPercentVertical(percent: number, timeInSecond?: number, attenuated?: boolean): void; + /** + !#en Stop auto scroll immediately + !#zh 停止自动滚动, 调用此 API 可以让 Scrollview 立即停止滚动 + */ + stopAutoScroll(): void; + /** + !#en Modify the content position. + !#zh 设置当前视图内容的坐标点。 + @param position The position in content's parent space. + */ + setContentPosition(position: Vec2): void; + /** + !#en Query the content's position in its parent space. + !#zh 获取当前视图内容的坐标点。 + */ + getContentPosition(): Position; + /** + !#en Query whether the user is currently dragging the ScrollView to scroll it + !#zh 用户是否在拖拽当前滚动视图 + */ + isScrolling(): boolean; + /** + !#en Query whether the ScrollView is currently scrolling because of a bounceback or inertia slowdown. + !#zh 当前滚动视图是否在惯性滚动 + */ + isAutoScrolling(): boolean; + } + /** !#en The Slider Control + !#zh 滑动器组件 */ + export class Slider extends Component { + /** !#en The "handle" part of the slider + !#zh 滑动器滑块按钮部件 */ + handle: Button; + /** !#en The slider direction + !#zh 滑动器方向 */ + direction: Slider.Direction; + /** !#en The current progress of the slider. The valid value is between 0-1 + !#zh 当前进度值,该数值的区间是 0-1 之间 */ + progress: number; + /** !#en The slider events callback + !#zh 滑动器组件事件回调函数 */ + slideEvents: Component.EventHandler[]; + } + /** !#en Renders a sprite in the scene. + !#zh 该组件用于在场景中渲染精灵。 */ + export class Sprite extends _RendererUnderSG { + /** !#en The sprite frame of the sprite. + !#zh 精灵的精灵帧 */ + spriteFrame: SpriteFrame; + /** !#en The sprite render type. + !#zh 精灵渲染类型 */ + type: Sprite.SpriteType; + /** !#en + The fill type, This will only have any effect if the "type" is set to “cc.Sprite.Type.FILLED”. + !#zh + 精灵填充类型,仅渲染类型设置为 cc.Sprite.SpriteType.FILLED 时有效。 */ + fillType: Sprite.FillType; + /** !#en + The fill Center, This will only have any effect if the "type" is set to “cc.Sprite.Type.FILLED”. + !#zh + 填充中心点,仅渲染类型设置为 cc.Sprite.SpriteType.FILLED 时有效。 */ + fillCenter: Vec2; + /** !#en + The fill Start, This will only have any effect if the "type" is set to “cc.Sprite.Type.FILLED”. + !#zh + 填充起始点,仅渲染类型设置为 cc.Sprite.SpriteType.FILLED 时有效。 */ + fillStart: number; + /** !#en + The fill Range, This will only have any effect if the "type" is set to “cc.Sprite.Type.FILLED”. + !#zh + 填充范围,仅渲染类型设置为 cc.Sprite.SpriteType.FILLED 时有效。 */ + fillRange: number; + /** !#en specify the frame is trimmed or not. + !#zh 是否使用裁剪模式 */ + trim: boolean; + /** !#en specify the source Blend Factor. + !#zh 指定原图的混合模式 */ + srcBlendFactor: BlendFactor; + /** !#en specify the destination Blend Factor. + !#zh 指定目标的混合模式 */ + dstBlendFactor: BlendFactor; + /** !#en specify the size tracing mode. + !#zh 精灵尺寸调整模式 */ + sizeMode: Sprite.SizeMode; + /** + !#en Change the left sprite's cap inset. + !#zh 设置精灵左边框-用于九宫格。 + @param insetLeft The values to use for the cap inset. + + @example + ```js + sprite.setInsetLeft(5); + ``` + */ + setInsetLeft(insetLeft: number): void; + /** + !#en Query the left sprite's cap inset. + !#zh 获取精灵左边框 + + @example + ```js + var insetLeft = sprite.getInsetLeft(); + cc.log("Inset Left:" + insetLeft); + ``` + */ + getInsetLeft(): number; + /** + !#en Change the top sprite's cap inset. + !#zh 设置精灵上边框-用于九宫格。 + @param insetTop The values to use for the cap inset. + + @example + ```js + sprite.setInsetTop(5); + ``` + */ + setInsetTop(insetTop: number): void; + /** + !#en Query the top sprite's cap inset. + !#zh 获取精灵上边框。 + + @example + ```js + var insetTop = sprite.getInsetTop(); + cc.log("Inset Top:" + insetTop); + ``` + */ + getInsetTop(): number; + /** + !#en Change the right sprite's cap inset. + !#zh 设置精灵右边框-用于九宫格。 + @param insetRight The values to use for the cap inset. + + @example + ```js + sprite.setInsetRight(5); + ``` + */ + setInsetRight(insetRight: number): void; + /** + !#en Query the right sprite's cap inset. + !#zh 获取精灵右边框。 + + @example + ```js + var insetRight = sprite.getInsetRight(); + cc.log("Inset Right:" + insetRight); + ``` + */ + getInsetRight(): number; + /** + !#en Change the bottom sprite's cap inset. + !#zh 设置精灵下边框-用于九宫格。 + @param bottomInset The values to use for the cap inset. + + @example + ```js + sprite.setInsetBottom(5); + ``` + */ + setInsetBottom(bottomInset: number): void; + /** + !#en Query the bottom sprite's cap inset. + !#zh 获取精灵下边框。 + + @example + ```js + var insetBottom = sprite.getInsetBottom(); + cc.log("Inset Bottom:" + insetBottom); + ``` + */ + getInsetBottom(): number; + } + /** !#en A distortion used to change the rendering of simple sprite.If will take effect after sprite component is added. + !#zh 扭曲效果组件,用于改变SIMPLE类型sprite的渲染,只有当sprite组件已经添加后,才能起作用. */ + export class SpriteDistortion extends Component { + /** !#en Change the UV offset for distortion rendering. + !#zh 在渲染时改变UV的整体偏移. */ + offset: Vec2; + /** !#en Change the UV scale for distortion rendering. + !#zh 在渲染时改变UV的寻址系数 */ + tiling: Vec2; + } + /** !#en The toggle component is a CheckBox, when it used together with a ToggleGroup, it + could be treated as a RadioButton. + !#zh Toggle 是一个 CheckBox,当它和 ToggleGroup 一起使用的时候,可以变成 RadioButton。 */ + export class Toggle extends Button { + /** !#en When this value is true, the check mark component will be enabled, otherwise + the check mark component will be disabled. + !#zh 如果这个设置为 true,则 check mark 组件会处于 enabled 状态,否则处于 disabled 状态。 */ + isChecked: boolean; + /** !#en The toggle group which the toggle belongs to, when it is null, the toggle is a CheckBox. + Otherwise, the toggle is a RadioButton. + !#zh Toggle 所属的 ToggleGroup,这个属性是可选的。如果这个属性为 null,则 Toggle 是一个 CheckBox, + 否则,Toggle 是一个 RadioButton。 */ + toggleGroup: ToggleGroup; + /** !#en The image used for the checkmark. + !#zh Toggle 处于选中状态时显示的图片 */ + checkMark: Sprite; + /** !#en If Toggle is clicked, it will trigger event's handler + !#zh Toggle 按钮的点击事件列表。 */ + checkEvents: Component.EventHandler[]; + /** + !#en Make the toggle button checked. + !#zh 使 toggle 按钮处于选中状态 + */ + check(): void; + /** + !#en Make the toggle button unchecked. + !#zh 使 toggle 按钮处于未选中状态 + */ + uncheck(): void; + } + /** !#en ToggleGroup is not a visiable UI component but a way to modify the behavior of a set of Toggles. + Toggles that belong to the same group could only have one of them to be switched on at a time. + !#zh ToggleGroup 不是一个可见的 UI 组件,它可以用来修改一组 Toggle 组件的行为。当一组 Toggle 属于同一个 ToggleGroup 的时候, + 任何时候只能有一个 Toggle 处于选中状态。 */ + export class ToggleGroup extends Component { + /** !#en If this setting is true, a toggle could be switched off and on when pressed. + If it is false, it will make sure there is always only one toggle could be switched on + and the already switched on toggle can't be switched off. + !#zh 如果这个设置为 true, 那么 toggle 按钮在被点击的时候可以反复地被选中和未选中。 */ + allowSwitchOff: boolean; + /** !#en Read only property, return the toggle items array reference managed by toggleGroup. + !#zh 只读属性,返回 toggleGroup 管理的 toggle 数组引用 */ + toggleItems: any[]; + } + /** !#en cc.VideoPlayer is a component for playing videos, you can use it for showing videos in your game. + !#zh Video 组件,用于在游戏中播放视频 */ + export class VideoPlayer extends _RendererUnderSG { + /** !#en The resource type of videoplayer, REMOTE for remote url and LOCAL for local file path. + !#zh 视频来源:REMOTE 表示远程视频 URL,LOCAL 表示本地视频地址。 */ + resourceType: VideoPlayer.ResourceType; + /** !#en The remote URL of video. + !#zh 远程视频的 URL */ + remoteURL: string; + /** !#en The local video full path. + !#zh 本地视频的 URL */ + clip: string; + /** !#en The current playback time of the now playing item in seconds, you could also change the start playback time. + !#zh 指定视频从什么时间点开始播放,单位是秒,也可以用来获取当前视频播放的时间进度。 */ + currentTime: number; + /** !#en Whether keep the aspect ration of the original video. + !#zh 是否保持视频原来的宽高比 */ + keepAspectRatio: boolean; + /** !#en Whether play video in fullscreen mode. + !#zh 是否全屏播放视频 */ + isFullscreen: boolean; + /** !#en the video player's callback, it will be triggered when certain event occurs, like: playing, paused, stopped and completed. + !#zh 视频播放回调函数,该回调函数会在特定情况被触发,比如播放中,暂时,停止和完成播放。 */ + videoPlayerEvent: Component.EventHandler[]; + /** + !#en If a video is paused, call this method could resume playing. If a video is stopped, call this method to play from scratch. + !#zh 如果视频被暂停播放了,调用这个接口可以继续播放。如果视频被停止播放了,调用这个接口可以从头开始播放。 + */ + play(): void; + /** + !#en If a video is paused, call this method to resume playing. + !#zh 如果一个视频播放被暂停播放了,调用这个接口可以继续播放。 + */ + resume(): void; + /** + !#en If a video is playing, call this method to pause playing. + !#zh 如果一个视频正在播放,调用这个接口可以暂停播放。 + */ + pause(): void; + /** + !#en If a video is playing, call this method to stop playing immediately. + !#zh 如果一个视频正在播放,调用这个接口可以立马停止播放。 + */ + stop(): void; + /** + !#en Gets the duration of the video + !#zh 获取视频文件的播放总时长 + */ + getDuration(): number; + /** + !#en Determine whether video is playing or not. + !#zh 判断当前视频是否处于播放状态 + */ + isPlaying(): boolean; + /** + !#en if you don't need the VideoPlayer and it isn't in any running Scene, you should + call the destroy method on this component or the associated node explicitly. + Otherwise, the created DOM element won't be removed from web page. + !#zh + 如果你不再使用 VideoPlayer,并且组件未添加到场景中,那么你必须手动对组件或所在节点调用 destroy。 + 这样才能移除网页上的 DOM 节点,避免 Web 平台内存泄露。 + + @example + ```js + videoplayer.node.parent = null; // or videoplayer.node.removeFromParent(false); + // when you don't need videoplayer anymore + videoplayer.node.destroy(); + ``` + */ + destroy(): boolean; + } + /** !#en + Handling touch events in a ViewGroup takes special care, + because it's common for a ViewGroup to have children that are targets for different touch events than the ViewGroup itself. + To make sure that each view correctly receives the touch events intended for it, + ViewGroup should register capture phase event and handle the event propagation properly. + Please refer to Scrollview for more information. + + !#zh + ViewGroup的事件处理比较特殊,因为 ViewGroup 里面的子节点关心的事件跟 ViewGroup 本身可能不一样。 + 为了让子节点能够正确地处理事件,ViewGroup 需要注册 capture 阶段的事件,并且合理地处理 ViewGroup 之间的事件传递。 + 请参考 ScrollView 的实现来获取更多信息。 */ + export class ViewGroup extends Component { + } + /** !#en cc.WebView is a component for display web pages in the game + !#zh WebView 组件,用于在游戏中显示网页 */ + export class WebView extends _RendererUnderSG { + /** !#en A given URL to be loaded by the WebView, it should have a http or https prefix. + !#zh 指定 WebView 加载的网址,它应该是一个 http 或者 https 开头的字符串 */ + url: string; + /** !#en The webview's event callback , it will be triggered when certain webview event occurs. + !#zh WebView 的回调事件,当网页加载过程中,加载完成后或者加载出错时都会回调此函数 */ + webviewLoadedEvents: Component.EventHandler[]; + /** + !#en + Set javascript interface scheme (see also setOnJSCallback).
+ Note: Supports only on the Android and iOS. For HTML5, please refer to the official documentation.
+ Please refer to the official documentation for more details. + !#zh + 设置 JavaScript 接口方案(与 'setOnJSCallback' 配套使用)。
+ 注意:只支持 Android 和 iOS ,Web 端用法请前往官方文档查看。
+ 详情请参阅官方文档 + @param scheme scheme + */ + setJavascriptInterfaceScheme(scheme: string): void; + /** + !#en + This callback called when load URL that start with javascript + interface scheme (see also setJavascriptInterfaceScheme).
+ Note: Supports only on the Android and iOS. For HTML5, please refer to the official documentation.
+ Please refer to the official documentation for more details. + !#zh + 当加载 URL 以 JavaScript 接口方案开始时调用这个回调函数。
+ 注意:只支持 Android 和 iOS,Web 端用法请前往官方文档查看。 + 详情请参阅官方文档 + @param callback callback + */ + setOnJSCallback(callback: Function): void; + /** + !#en + Evaluates JavaScript in the context of the currently displayed page.
+ Please refer to the official document for more details
+ Note: Cross domain issues need to be resolved by yourself
+ !#zh + 执行 WebView 内部页面脚本(详情请参阅官方文档)
+ 注意:需要自行解决跨域问题 + @param str str + */ + evaluateJS(str: string): void; + /** + !#en if you don't need the WebView and it isn't in any running Scene, you should + call the destroy method on this component or the associated node explicitly. + Otherwise, the created DOM element won't be removed from web page. + !#zh + 如果你不再使用 WebView,并且组件未添加到场景中,那么你必须手动对组件或所在节点调用 destroy。 + 这样才能移除网页上的 DOM 节点,避免 Web 平台内存泄露。 + + @example + ```js + webview.node.parent = null; // or webview.node.removeFromParent(false); + // when you don't need webview anymore + webview.node.destroy(); + ``` + */ + destroy(): void; + } + /** !#en + Stores and manipulate the anchoring based on its parent. + Widget are used for GUI but can also be used for other things. + Widget will adjust current node's position and size automatically, but the results after adjustment can not be obtained until the next frame unless you call {{#crossLink "Widget/updateAlignment:method"}}{{/crossLink}} manually. + !#zh + Widget 组件,用于设置和适配其相对于父节点的边距,Widget 通常被用于 UI 界面,也可以用于其他地方。 + Widget 会自动调整当前节点的坐标和宽高,不过目前调整后的结果要到下一帧才能在脚本里获取到,除非你先手动调用 {{#crossLink "Widget/updateAlignment:method"}}{{/crossLink}}。 */ + export class Widget extends Component { + /** !#en Specifies an alignment target that can only be one of the parent nodes of the current node. + The default value is null, and when null, indicates the current parent. + !#zh 指定一个对齐目标,只能是当前节点的其中一个父节点,默认为空,为空时表示当前父节点。 */ + target: Node; + /** !#en Whether to align the top. + !#zh 是否对齐上边。 */ + isAlignTop: boolean; + /** !#en + Vertically aligns the midpoint, This will open the other vertical alignment options cancel. + !#zh + 是否垂直方向对齐中点,开启此项会将垂直方向其他对齐选项取消。 */ + isAlignVerticalCenter: boolean; + /** !#en Whether to align the bottom. + !#zh 是否对齐下边。 */ + isAlignBottom: boolean; + /** !#en Whether to align the left. + !#zh 是否对齐左边 */ + isAlignLeft: boolean; + /** !#en + Horizontal aligns the midpoint. This will open the other horizontal alignment options canceled. + !#zh + 是否水平方向对齐中点,开启此选项会将水平方向其他对齐选项取消。 */ + isAlignHorizontalCenter: boolean; + /** !#en Whether to align the right. + !#zh 是否对齐右边。 */ + isAlignRight: boolean; + /** !#en + Whether the stretched horizontally, when enable the left and right alignment will be stretched horizontally, + the width setting is invalid (read only). + !#zh + 当前是否水平拉伸。当同时启用左右对齐时,节点将会被水平拉伸,此时节点的宽度只读。 */ + isStretchWidth: boolean; + /** !#en + Whether the stretched vertically, when enable the left and right alignment will be stretched vertically, + then height setting is invalid (read only) + !#zh + 当前是否垂直拉伸。当同时启用上下对齐时,节点将会被垂直拉伸,此时节点的高度只读。 */ + isStretchHeight: boolean; + /** !#en + The margins between the top of this node and the top of parent node, + the value can be negative, Only available in 'isAlignTop' open. + !#zh + 本节点顶边和父节点顶边的距离,可填写负值,只有在 isAlignTop 开启时才有作用。 */ + top: number; + /** !#en + The margins between the bottom of this node and the bottom of parent node, + the value can be negative, Only available in 'isAlignBottom' open. + !#zh + 本节点底边和父节点底边的距离,可填写负值,只有在 isAlignBottom 开启时才有作用。 */ + bottom: number; + /** !#en + The margins between the left of this node and the left of parent node, + the value can be negative, Only available in 'isAlignLeft' open. + !#zh + 本节点左边和父节点左边的距离,可填写负值,只有在 isAlignLeft 开启时才有作用。 */ + left: number; + /** !#en + The margins between the right of this node and the right of parent node, + the value can be negative, Only available in 'isAlignRight' open. + !#zh + 本节点右边和父节点右边的距离,可填写负值,只有在 isAlignRight 开启时才有作用。 */ + right: number; + /** !#en + Horizontal aligns the midpoint offset value, + the value can be negative, Only available in 'isAlignHorizontalCenter' open. + !#zh 水平居中的偏移值,可填写负值,只有在 isAlignHorizontalCenter 开启时才有作用。 */ + horizontalCenter: number; + /** !#en + Vertical aligns the midpoint offset value, + the value can be negative, Only available in 'isAlignVerticalCenter' open. + !#zh 垂直居中的偏移值,可填写负值,只有在 isAlignVerticalCenter 开启时才有作用。 */ + verticalCenter: number; + /** !#en If true, horizontalCenter is pixel margin, otherwise is percentage (0 - 1) margin. + !#zh 如果为 true,"horizontalCenter" 将会以像素作为偏移值,反之为百分比(0 到 1)。 */ + isAbsoluteHorizontalCenter: boolean; + /** !#en If true, verticalCenter is pixel margin, otherwise is percentage (0 - 1) margin. + !#zh 如果为 true,"verticalCenter" 将会以像素作为偏移值,反之为百分比(0 到 1)。 */ + isAbsoluteVerticalCenter: boolean; + /** !#en + If true, top is pixel margin, otherwise is percentage (0 - 1) margin relative to the parent's height. + !#zh + 如果为 true,"top" 将会以像素作为边距,否则将会以相对父物体高度的百分比(0 到 1)作为边距。 */ + isAbsoluteTop: boolean; + /** !#en + If true, bottom is pixel margin, otherwise is percentage (0 - 1) margin relative to the parent's height. + !#zh + 如果为 true,"bottom" 将会以像素作为边距,否则将会以相对父物体高度的百分比(0 到 1)作为边距。 */ + isAbsoluteBottom: boolean; + /** !#en + If true, left is pixel margin, otherwise is percentage (0 - 1) margin relative to the parent's width. + !#zh + 如果为 true,"left" 将会以像素作为边距,否则将会以相对父物体宽度的百分比(0 到 1)作为边距。 */ + isAbsoluteLeft: boolean; + /** !#en + If true, right is pixel margin, otherwise is percentage (0 - 1) margin relative to the parent's width. + !#zh + 如果为 true,"right" 将会以像素作为边距,否则将会以相对父物体宽度的百分比(0 到 1)作为边距。 */ + isAbsoluteRight: boolean; + /** !#en TODO + !#zh + 开启后仅会在 onEnable 的当帧结束时对齐一次,然后立刻禁用当前组件。 + 这样便于脚本或动画继续控制当前节点。 + 注意:onEnable 时所在的那一帧仍然会进行对齐。 */ + isAlignOnce: boolean; + /** + !#en + Immediately perform the widget alignment. You need to manually call this method only if + you need to get the latest results after the alignment before the end of current frame. + !#zh + 立刻执行 widget 对齐操作。这个接口一般不需要手工调用。 + 只有当你需要在当前帧结束前获得 widget 对齐后的最新结果时才需要手动调用这个方法。 + + @example + ```js + widget.top = 10; // change top margin + cc.log(widget.node.y); // not yet changed + widget.updateAlignment(); + cc.log(widget.node.y); // changed + ``` + */ + updateAlignment(): void; + } + /** !#en + EventTarget is an object to which an event is dispatched when something has occurred. + Entity are the most common event targets, but other objects can be event targets too. + + Event targets are an important part of the Fireball event model. + The event target serves as the focal point for how events flow through the scene graph. + When an event such as a mouse click or a keypress occurs, Fireball dispatches an event object + into the event flow from the root of the hierarchy. The event object then makes its way through + the scene graph until it reaches the event target, at which point it begins its return trip through + the scene graph. This round-trip journey to the event target is conceptually divided into three phases: + - The capture phase comprises the journey from the root to the last node before the event target's node + - The target phase comprises only the event target node + - The bubbling phase comprises any subsequent nodes encountered on the return trip to the root of the tree + See also: http://www.w3.org/TR/DOM-Level-3-Events/#event-flow + + Event targets can implement the following methods: + - _getCapturingTargets + - _getBubblingTargets + + !#zh + 事件目标是事件触发时,分派的事件对象,Node 是最常见的事件目标, + 但是其他对象也可以是事件目标。
*/ + export class EventTarget { + /** + !#en + Register an callback of a specific event type on the EventTarget. + !#zh + 注册事件目标的特定事件类型回调。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + on(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + on(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Removes the listeners previously registered with the same type, callback, target and or useCapture, + if only type is passed as parameter, all listeners registered with that type will be removed. + !#zh + 删除之前用同类型,回调,目标或 useCapture 注册的事件监听器,如果只传递 type,将会删除 type 类型的所有事件监听器。 + @param type A string representing the event type being removed. + @param callback The callback to remove. + @param target The target (this object) to invoke the callback, if it's not given, only callback without target will be removed + @param useCapture Specifies whether the callback being removed was registered as a capturing callback or not. + If not specified, useCapture defaults to false. If a callback was registered twice, + one with capture and one without, each must be removed separately. Removal of a capturing callback + does not affect a non-capturing version of the same listener, and vice versa. + + @example + ```js + // register touchEnd eventListener + var touchEnd = node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + // remove touch end event listener + node.off(cc.Node.EventType.TOUCH_END, touchEnd, node); + // remove all touch end event listeners + node.off(cc.Node.EventType.TOUCH_END); + ``` + */ + off(type: string, callback?: Function, target?: any, useCapture?: boolean): void; + /** + !#en Removes all callbacks previously registered with the same target (passed as parameter). + This is not for removing all listeners in the current event target, + and this is not for removing all listeners the target parameter have registered. + It's only for removing all listeners (callback and target couple) registered on the current event target by the target parameter. + !#zh 在当前 EventTarget 上删除指定目标(target 参数)注册的所有事件监听器。 + 这个函数无法删除当前 EventTarget 的所有事件监听器,也无法删除 target 参数所注册的所有事件监听器。 + 这个函数只能删除 target 参数在当前 EventTarget 上注册的所有事件监听器。 + @param target The target to be searched for all related listeners + */ + targetOff(target: any): void; + /** + !#en + Register an callback of a specific event type on the EventTarget, + the callback will remove itself after the first time it is triggered. + !#zh + 注册事件目标的特定事件类型回调,回调会在第一时间被触发后删除自身。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.once(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + once(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + once(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Dispatches an event into the event flow. + The event target is the EventTarget object upon which the dispatchEvent() method is called. + !#zh 分发事件到事件流中。 + @param event The Event object that is dispatched into the event flow + */ + dispatchEvent(event: Event): void; + /** + !#en + Send an event to this object directly, this method will not propagate the event to any other objects. + The event will be created from the supplied message, you can get the "detail" argument from event.detail. + !#zh + 该对象直接发送事件, 这种方法不会对事件传播到任何其他对象。 + @param message the message to send + @param detail whatever argument the message needs + */ + emit(message: string, detail?: any): void; + } + /** !#en Base class of all kinds of events. + !#zh 包含事件相关信息的对象。 */ + export class Event { + /** + + @param type The name of the event (case-sensitive), e.g. "click", "fire", or "submit" + @param bubbles A boolean indicating whether the event bubbles up through the tree or not + */ + constructor(type: string, bubbles: boolean); + /** !#en The name of the event (case-sensitive), e.g. "click", "fire", or "submit". + !#zh 事件类型。 */ + type: string; + /** !#en Indicate whether the event bubbles up through the tree or not. + !#zh 表示该事件是否进行冒泡。 */ + bubbles: boolean; + /** !#en A reference to the target to which the event was originally dispatched. + !#zh 最初事件触发的目标 */ + target: any; + /** !#en A reference to the currently registered target for the event. + !#zh 当前目标 */ + currentTarget: any; + /** !#en + Indicates which phase of the event flow is currently being evaluated. + Returns an integer value represented by 4 constants: + - Event.NONE = 0 + - Event.CAPTURING_PHASE = 1 + - Event.AT_TARGET = 2 + - Event.BUBBLING_PHASE = 3 + The phases are explained in the [section 3.1, Event dispatch and DOM event flow] + (http://www.w3.org/TR/DOM-Level-3-Events/#event-flow), of the DOM Level 3 Events specification. + !#zh 事件阶段 */ + eventPhase: number; + /** + !#en Reset the event for being stored in the object pool. + !#zh 重置对象池中存储的事件。 + */ + unuse(): string; + /** + !#en Reuse the event for being used again by the object pool. + !#zh 用于对象池再次使用的事件。 + */ + reuse(): string; + /** + !#en Stops propagation for current event. + !#zh 停止传递当前事件。 + */ + stopPropagation(): void; + /** + !#en Stops propagation for current event immediately, + the event won't even be dispatched to the listeners attached in the current target. + !#zh 立即停止当前事件的传递,事件甚至不会被分派到所连接的当前目标。 + */ + stopPropagationImmediate(): void; + /** + !#en Checks whether the event has been stopped. + !#zh 检查该事件是否已经停止传递. + */ + isStopped(): boolean; + /** + !#en +

+ Gets current target of the event
+ note: It only be available when the event listener is associated with node.
+ It returns 0 when the listener is associated with fixed priority. +

+ !#zh 获取当前目标节点 + */ + getCurrentTarget(): Node; + /** + !#en Gets the event type. + !#zh 获取事件类型 + */ + getType(): string; + /** !#en Code for event without type. + !#zh 没有类型的事件 */ + static NO_TYPE: string; + /** !#en The type code of Touch event. + !#zh 触摸事件类型 */ + static TOUCH: string; + /** !#en The type code of Mouse event. + !#zh 鼠标事件类型 */ + static MOUSE: string; + /** !#en The type code of Keyboard event. + !#zh 键盘事件类型 */ + static KEYBOARD: string; + /** !#en The type code of Acceleration event. + !#zh 加速器事件类型 */ + static ACCELERATION: string; + /** !#en Events not currently dispatched are in this phase + !#zh 尚未派发事件阶段 */ + static NONE: number; + /** !#en + The capturing phase comprises the journey from the root to the last node before the event target's node + see http://www.w3.org/TR/DOM-Level-3-Events/#event-flow + !#zh 捕获阶段,包括事件目标节点之前从根节点到最后一个节点的过程。 */ + static CAPTURING_PHASE: number; + /** !#en + The target phase comprises only the event target node + see http://www.w3.org/TR/DOM-Level-3-Events/#event-flow + !#zh 目标阶段仅包括事件目标节点。 */ + static AT_TARGET: number; + /** !#en + The bubbling phase comprises any subsequent nodes encountered on the return trip to the root of the hierarchy + see http://www.w3.org/TR/DOM-Level-3-Events/#event-flow + !#zh 冒泡阶段, 包括回程遇到到层次根节点的任何后续节点。 */ + static BUBBLING_PHASE: number; + } + /** !#en +

+ The base class of event listener.
+ If you need custom listener which with different callback, you need to inherit this class.
+ For instance, you could refer to EventListenerAcceleration, EventListenerKeyboard,
+ EventListenerTouchOneByOne, EventListenerCustom. +

+ + !#zh + 封装用户的事件处理逻辑。 + 注意:这是一个抽象类,开发者不应该直接实例化这个类,请参考 {{#crossLink "EventListener/create:method"}}cc.EventListener.create{{/crossLink}}。 */ + export class EventListener { + /** + Constructor + @param type type + @param listenerID listenerID + @param callback callback + */ + constructor(type: number, listenerID: number, callback: number); + /** + !#en Checks whether the listener is available. + !#zh 检测监听器是否有效 + */ + checkAvailable(): boolean; + /** + !#en Clones the listener, its subclasses have to override this method. + !#zh 克隆监听器,它的子类必须重写此方法。 + */ + clone(): EventListener; + /** + !#en Enables or disables the listener + !#zh 启用或禁用监听器。 + @param enabled enabled + */ + setEnabled(enabled: boolean): void; + /** + !#en Checks whether the listener is enabled + !#zh 检查监听器是否可用。 + */ + isEnabled(): boolean; + /** !#en The type code of unknown event listener. + !#zh 未知的事件监听器类型 */ + static UNKNOWN: number; + /** !#en The type code of keyboard event listener. + !#zh 键盘事件监听器类型 */ + static KEYBOARD: number; + /** !#en The type code of acceleration event listener. + !#zh 加速器事件监听器类型 */ + static ACCELERATION: number; + /** + !#en + Create a EventListener object with configuration including the event type, handlers and other parameters. + In handlers, this refer to the event listener object itself. + You can also pass custom parameters in the configuration object, + all custom parameters will be polyfilled into the event listener object and can be accessed in handlers. + !#zh 通过指定不同的 Event 对象来设置想要创建的事件监听器。 + @param argObj a json object + + @example + ```js + // Create KEYBOARD EventListener. + cc.EventListener.create({ + event: cc.EventListener.KEYBOARD, + onKeyPressed: function (keyCode, event) { + cc.log('pressed key: ' + keyCode); + }, + onKeyReleased: function (keyCode, event) { + cc.log('released key: ' + keyCode); + } + }); + + // Create ACCELERATION EventListener. + cc.EventListener.create({ + event: cc.EventListener.ACCELERATION, + callback: function (acc, event) { + cc.log('acc: ' + keyCode); + } + }); + ``` + */ + static create(argObj: any): EventListener; + } + /** !#en +

+ cc.eventManager is a singleton object which manages event listener subscriptions and event dispatching.
+
+ The EventListener list is managed in such way so that event listeners can be added and removed
+ while events are being dispatched. +

+ !#zh + 事件管理器,它主要管理事件监听器注册和派发系统事件。 + 原始设计中,它支持鼠标,触摸,键盘,陀螺仪和自定义事件。 + 在 Creator 的设计中,鼠标,触摸和自定义事件的监听和派发请参考 http://cocos.com/docs/creator/scripting/events.html。 */ + export class eventManager { + /** + !#en Pauses all listeners which are associated the specified target. + !#zh 暂停传入的 node 相关的所有监听器的事件响应。 + @param node node + @param recursive recursive + */ + static pauseTarget(node: Node, recursive?: boolean): void; + /** + !#en Resumes all listeners which are associated the specified target. + !#zh 恢复传入的 node 相关的所有监听器的事件响应。 + @param node node + @param recursive recursive + */ + static resumeTarget(node: Node, recursive?: boolean): void; + /** + !#en Query whether the specified event listener id has been added. + !#zh 查询指定的事件 ID 是否存在 + @param listenerID The listener id. + */ + static hasEventListener(listenerID: string|number): boolean; + /** + !#en +

+ Adds a event listener for a specified event.
+ if the parameter "nodeOrPriority" is a node, + it means to add a event listener for a specified event with the priority of scene graph.
+ if the parameter "nodeOrPriority" is a Number, + it means to add a event listener for a specified event with the fixed priority.
+

+ !#zh + 将事件监听器添加到事件管理器中。
+ 如果参数 “nodeOrPriority” 是节点,优先级由 node 的渲染顺序决定,显示在上层的节点将优先收到事件。
+ 如果参数 “nodeOrPriority” 是数字,优先级则固定为该参数的数值,数字越小,优先级越高。
+ @param listener The listener of a specified event or a object of some event parameters. + @param nodeOrPriority The priority of the listener is based on the draw order of this node or fixedPriority The fixed priority of the listener. + */ + static addListener(listener: EventListener|any, nodeOrPriority: Node|number): EventListener; + /** + !#en Remove a listener. + !#zh 移除一个已添加的监听器。 + @param listener an event listener or a registered node target + + @example + ```js + + // 1. remove eventManager add Listener; + var mouseListener1 = cc.eventManager.addListener({ + event: cc.EventListener.MOUSE, + onMouseDown: function(keyCode, event){ }, + onMouseUp: function(keyCode, event){ }, + onMouseMove: function () { }, + onMouseScroll: function () { } + }, node); + + cc.eventManager.removeListener(mouseListener1); + + // 2. remove eventListener create Listener; + var mouseListener2 = cc.EventListener.create({ + event: cc.EventListener.MOUSE, + onMouseDown: function(keyCode, event){ }, + onMouseUp: function(keyCode, event){ }, + onMouseMove: function () { }, + onMouseScroll: function () { } + }); + + cc.eventManager.removeListener(mouseListener2); + + ``` + */ + static removeListener(listener: EventListener): void; + /** + !#en Removes all listeners with the same event listener type or removes all listeners of a node. + !#zh + 移除注册到 eventManager 中指定类型的所有事件监听器。
+ 1. 如果传入的第一个参数类型是 Node,那么事件管理器将移除与该对象相关的所有事件监听器。 + (如果第二参数 recursive 是 true 的话,就会连同该对象的子控件上所有的事件监听器也一并移除)
+ 2. 如果传入的第一个参数类型是 Number(该类型 EventListener 中定义的事件类型), + 那么事件管理器将移除该类型的所有事件监听器。
+ + 下列是目前存在监听器类型:
+ cc.EventListener.UNKNOWN
+ cc.EventListener.KEYBOARD
+ cc.EventListener.ACCELERATION,
+ @param listenerType listenerType or a node + @param recursive recursive + */ + static removeListeners(listenerType: number|Node, recursive?: boolean): void; + /** + !#en Removes all listeners + !#zh 移除所有事件监听器。 + */ + static removeAllListeners(): void; + /** + !#en Sets listener's priority with fixed value. + !#zh 设置 FixedPriority 类型监听器的优先级。 + @param listener listener + @param fixedPriority fixedPriority + */ + static setPriority(listener: EventListener, fixedPriority: number): void; + /** + !#en Whether to enable dispatching events + !#zh 启用或禁用事件管理器,禁用后不会分发任何事件。 + @param enabled enabled + */ + static setEnabled(enabled: boolean): void; + /** + !#en Checks whether dispatching events is enabled + !#zh 检测事件管理器是否启用。 + */ + static isEnabled(): boolean; + } + /** !#en The touch event class + !#zh 封装了触摸相关的信息。 */ + export class Touch { + /** + !#en Returns the current touch location in OpenGL coordinates.、 + !#zh 获取当前触点位置。 + */ + getLocation(): Vec2; + /** + !#en Returns X axis location value. + !#zh 获取当前触点 X 轴位置。 + */ + getLocationX(): number; + /** + !#en Returns Y axis location value. + !#zh 获取当前触点 Y 轴位置。 + */ + getLocationY(): number; + /** + !#en Returns the previous touch location in OpenGL coordinates. + !#zh 获取触点在上一次事件时的位置对象,对象包含 x 和 y 属性。 + */ + getPreviousLocation(): Vec2; + /** + !#en Returns the start touch location in OpenGL coordinates. + !#zh 获获取触点落下时的位置对象,对象包含 x 和 y 属性。 + */ + getStartLocation(): Vec2; + /** + !#en Returns the delta distance from the previous touche to the current one in screen coordinates. + !#zh 获取触点距离上一次事件移动的距离对象,对象包含 x 和 y 属性。 + */ + getDelta(): Vec2; + /** + !#en Returns the current touch location in screen coordinates. + !#zh 获取当前事件在游戏窗口内的坐标位置对象,对象包含 x 和 y 属性。 + */ + getLocationInView(): Vec2; + /** + !#en Returns the previous touch location in screen coordinates. + !#zh 获取触点在上一次事件时在游戏窗口中的位置对象,对象包含 x 和 y 属性。 + */ + getPreviousLocationInView(): Vec2; + /** + !#en Returns the start touch location in screen coordinates. + !#zh 获取触点落下时在游戏窗口中的位置对象,对象包含 x 和 y 属性。 + */ + getStartLocationInView(): Vec2; + /** + !#en Returns the id of cc.Touch. + !#zh 触点的标识 ID,可以用来在多点触摸中跟踪触点。 + */ + getID(): number; + /** + !#en Sets information to touch. + !#zh 设置触摸相关的信息。用于监控触摸事件。 + @param id id + @param x x + @param y y + */ + setTouchInfo(id: number, x: number, y: number): void; + } + /** !#en The System event, it currently supports the key events and accelerometer events + !#zh 系统事件,它目前支持按键事件和重力感应事件 */ + export class SystemEvent extends EventTarget { + } + /** undefined */ + export class Graphics extends _RendererUnderSG { + /** !#en + Current line width. + !#zh + 当前线条宽度 */ + lineWidth: number; + /** !#en + lineJoin determines how two connecting segments (of lines, arcs or curves) with non-zero lengths in a shape are joined together. + !#zh + lineJoin 用来设置2个长度不为0的相连部分(线段,圆弧,曲线)如何连接在一起的属性。 */ + lineJoin: Graphics.LineJoin; + /** !#en + lineCap determines how the end points of every line are drawn. + !#zh + lineCap 指定如何绘制每一条线段末端。 */ + lineCap: Graphics.LineCap; + /** !#en + stroke color + !#zh + 线段颜色 */ + strokeColor: Color; + /** !#en + fill color + !#zh + 填充颜色 */ + fillColor: Color; + /** !#en + Sets the miter limit ratio + !#zh + 设置斜接面限制比例 */ + miterLimit: number; + /** + !#en Move path start point to (x,y). + !#zh 移动路径起点到坐标(x, y) + @param x The x axis of the coordinate for the end point. + @param y The y axis of the coordinate for the end point. + */ + moveTo(x?: number, y?: number): void; + /** + !#en Adds a straight line to the path + !#zh 绘制直线路径 + @param x The x axis of the coordinate for the end point. + @param y The y axis of the coordinate for the end point. + */ + lineTo(x?: number, y?: number): void; + /** + !#en Adds a cubic Bézier curve to the path + !#zh 绘制三次贝赛尔曲线路径 + @param c1x The x axis of the coordinate for the first control point. + @param c1y The y axis of the coordinate for first control point. + @param c2x The x axis of the coordinate for the second control point. + @param c2y The y axis of the coordinate for the second control point. + @param x The x axis of the coordinate for the end point. + @param y The y axis of the coordinate for the end point. + */ + bezierCurveTo(c1x?: number, c1y?: number, c2x?: number, c2y?: number, x?: number, y?: number): void; + /** + !#en Adds a quadratic Bézier curve to the path + !#zh 绘制二次贝赛尔曲线路径 + @param cx The x axis of the coordinate for the control point. + @param cy The y axis of the coordinate for the control point. + @param x The x axis of the coordinate for the end point. + @param y The y axis of the coordinate for the end point. + */ + quadraticCurveTo(cx?: number, cy?: number, x?: number, y?: number): void; + /** + !#en Adds an arc to the path which is centered at (cx, cy) position with radius r starting at startAngle and ending at endAngle going in the given direction by counterclockwise (defaulting to false). + !#zh 绘制圆弧路径。圆弧路径的圆心在 (cx, cy) 位置,半径为 r ,根据 counterclockwise (默认为false)指定的方向从 startAngle 开始绘制,到 endAngle 结束。 + @param cx The x axis of the coordinate for the center point. + @param cy The y axis of the coordinate for the center point. + @param r The arc's radius. + @param startAngle The angle at which the arc starts, measured clockwise from the positive x axis and expressed in radians. + @param endAngle The angle at which the arc ends, measured clockwise from the positive x axis and expressed in radians. + @param counterclockwise An optional Boolean which, if true, causes the arc to be drawn counter-clockwise between the two angles. By default it is drawn clockwise. + */ + arc(cx?: number, cy?: number, r?: number, startAngle?: number, endAngle?: number, counterclockwise?: number): void; + /** + !#en Adds an ellipse to the path. + !#zh 绘制椭圆路径。 + @param cx The x axis of the coordinate for the center point. + @param cy The y axis of the coordinate for the center point. + @param rx The ellipse's x-axis radius. + @param ry The ellipse's y-axis radius. + */ + ellipse(cx?: number, cy?: number, rx?: number, ry?: number): void; + /** + !#en Adds an circle to the path. + !#zh 绘制圆形路径。 + @param cx The x axis of the coordinate for the center point. + @param cy The y axis of the coordinate for the center point. + @param r The circle's radius. + */ + circle(cx?: number, cy?: number, r?: number): void; + /** + !#en Adds an rectangle to the path. + !#zh 绘制矩形路径。 + @param x The x axis of the coordinate for the rectangle starting point. + @param y The y axis of the coordinate for the rectangle starting point. + @param w The rectangle's width. + @param h The rectangle's height. + */ + rect(x?: number, y?: number, w?: number, h?: number): void; + /** + !#en Adds an round corner rectangle to the path. + !#zh 绘制圆角矩形路径。 + @param x The x axis of the coordinate for the rectangle starting point. + @param y The y axis of the coordinate for the rectangle starting point. + @param w The rectangles width. + @param h The rectangle's height. + @param r The radius of the rectangle. + */ + roundRect(x?: number, y?: number, w?: number, h?: number, r?: number): void; + /** + !#en Draws a filled rectangle. + !#zh 绘制填充矩形。 + @param x The x axis of the coordinate for the rectangle starting point. + @param y The y axis of the coordinate for the rectangle starting point. + @param w The rectangle's width. + @param h The rectangle's height. + */ + fillRect(x?: number, y?: number, w?: number, h?: number): void; + /** + !#en Erasing any previously drawn content. + !#zh 擦除之前绘制的所有内容的方法。 + @param clean Whether to clean the graphics inner cache. + */ + clear(clean?: boolean): void; + /** + !#en Causes the point of the pen to move back to the start of the current path. It tries to add a straight line from the current point to the start. + !#zh 将笔点返回到当前路径起始点的。它尝试从当前点到起始点绘制一条直线。 + */ + close(): void; + /** + !#en Strokes the current or given path with the current stroke style. + !#zh 根据当前的画线样式,绘制当前或已经存在的路径。 + */ + stroke(): void; + /** + !#en Fills the current or given path with the current fill style. + !#zh 根据当前的画线样式,填充当前或已经存在的路径。 + */ + fill(): void; + } + /** Loader for resource loading process. It's a singleton object. */ + export class loader extends Pipeline { + /** The asset loader in cc.loader's pipeline, it's by default the first pipe. + It's used to identify an asset's type, and determine how to download it. */ + static assetLoader: any; + /** The downloader in cc.loader's pipeline, it's by default the second pipe. + It's used to download files with several handlers: pure text, image, script, audio, font, uuid. + You can add your own download function with addDownloadHandlers */ + static downloader: any; + /** The downloader in cc.loader's pipeline, it's by default the third pipe. + It's used to parse downloaded content with several handlers: JSON, image, plist, fnt, uuid. + You can add your own download function with addLoadHandlers */ + static loader: any; + /** + Gets a new XMLHttpRequest instance. + */ + static getXMLHttpRequest(): XMLHttpRequest; + /** + Add custom supported types handler or modify existing type handler for download process. + @param extMap Custom supported types with corresponded handler + + @example + ```js + cc.loader.addDownloadHandlers({ + // This will match all url with `.scene` extension or all url with `scene` type + 'scene' : function (url, callback) {} + }); + ``` + */ + static addDownloadHandlers(extMap: any): void; + /** + Add custom supported types handler or modify existing type handler for load process. + @param extMap Custom supported types with corresponded handler + + @example + ```js + cc.loader.addLoadHandlers({ + // This will match all url with `.scene` extension or all url with `scene` type + 'scene' : function (url, callback) {} + }); + ``` + */ + static addLoadHandlers(extMap: any): void; + /** + Load resources with a progression callback and a complete callback. + The progression callback is the same as Pipeline's {{#crossLink "LoadingItems/onProgress:method"}}onProgress{{/crossLink}} + The complete callback is almost the same as Pipeline's {{#crossLink "LoadingItems/onComplete:method"}}onComplete{{/crossLink}} + The only difference is when user pass a single url as resources, the complete callback will set its result directly as the second parameter. + @param resources Url list in an array + @param progressCallback Callback invoked when progression change + @param completeCallback Callback invoked when all resources loaded + + @example + ```js + cc.loader.load('a.png', function (err, tex) { + cc.log('Result should be a texture: ' + (tex instanceof cc.Texture2D)); + }); + + cc.loader.load('http://example.com/a.png', function (err, tex) { + cc.log('Should load a texture from external url: ' + (tex instanceof cc.Texture2D)); + }); + + cc.loader.load({url: 'http://example.com/getImageREST?file=a.png', type: 'png'}, function (err, tex) { + cc.log('Should load a texture from RESTful API by specify the type: ' + (tex instanceof cc.Texture2D)); + }); + + cc.loader.load(['a.png', 'b.json'], function (errors, results) { + if (errors) { + for (var i = 0; i < errors.length; i++) { + cc.log('Error url [' + errors[i] + ']: ' + results.getError(errors[i])); + } + } + var aTex = results.getContent('a.png'); + var bJsonObj = results.getContent('b.json'); + }); + ``` + */ + static load(resources: string|string[]|{uuid?: string, url?: string, type?: string}, completeCallback?: Function): void; + static load(resources: string|string[]|{uuid?: string, url?: string, type?: string}, progressCallback: (completedCount: number, totalCount: number, item: any) => void, completeCallback: Function|null): void; + /** + Load resources from the "resources" folder inside the "assets" folder of your project.
+
+ Note: All asset URLs in Creator use forward slashes, URLs using backslashes will not work. + @param url Url of the target resource. + The url is relative to the "resources" folder, extensions must be omitted. + @param type Only asset of type will be loaded if this argument is supplied. + @param progressCallback Callback invoked when progression change. + @param completeCallback Callback invoked when the resource loaded. + + @example + ```js + // load the prefab (project/assets/resources/misc/character/cocos) from resources folder + cc.loader.loadRes('misc/character/cocos', function (err, prefab) { + if (err) { + cc.error(err.message || err); + return; + } + cc.log('Result should be a prefab: ' + (prefab instanceof cc.Prefab)); + }); + + // load the sprite frame of (project/assets/resources/imgs/cocos.png) from resources folder + cc.loader.loadRes('imgs/cocos', cc.SpriteFrame, function (err, spriteFrame) { + if (err) { + cc.error(err.message || err); + return; + } + cc.log('Result should be a sprite frame: ' + (spriteFrame instanceof cc.SpriteFrame)); + }); + ``` + */ + static loadRes(url: string, type: typeof cc.Asset, progressCallback: (completedCount: number, totalCount: number, item: any) => void, completeCallback: ((error: Error, resource: any) => void)|null): void; + static loadRes(url: string, type: typeof cc.Asset, completeCallback: (error: Error, resource: any) => void): void; + static loadRes(url: string, type: typeof cc.Asset): void; + static loadRes(url: string, progressCallback: (completedCount: number, totalCount: number, item: any) => void, completeCallback: ((error: Error, resource: any) => void)|null): void; + static loadRes(url: string, completeCallback: (error: Error, resource: any) => void): void; + static loadRes(url: string): void; + /** + This method is like {{#crossLink "loader/loadRes:method"}}{{/crossLink}} except that it accepts array of url. + @param urls Array of URLs of the target resource. + The url is relative to the "resources" folder, extensions must be omitted. + @param type Only asset of type will be loaded if this argument is supplied. + @param progressCallback Callback invoked when progression change. + @param completeCallback A callback which is called when all assets have been loaded, or an error occurs. + + @example + ```js + // load the SpriteFrames from resources folder + var spriteFrames; + var urls = ['misc/characters/character_01', 'misc/weapons/weapons_01']; + cc.loader.loadResArray(urls, cc.SpriteFrame, function (err, assets) { + if (err) { + cc.error(err); + return; + } + spriteFrames = assets; + // ... + }); + ``` + */ + static loadResArray(url: string[], type: typeof cc.Asset, progressCallback: (completedCount: number, totalCount: number, item: any) => void, completeCallback: ((error: Error, resource: any[]) => void)|null): void; + static loadResArray(url: string[], type: typeof cc.Asset, completeCallback: (error: Error, resource: any[]) => void): void; + static loadResArray(url: string[], type: typeof cc.Asset): void; + static loadResArray(url: string[], progressCallback: (completedCount: number, totalCount: number, item: any) => void, completeCallback: ((error: Error, resource: any[]) => void)|null): void; + static loadResArray(url: string[], completeCallback: (error: Error, resource: any[]) => void): void; + static loadResArray(url: string[]): void; + /** + Load all assets in a folder inside the "assets/resources" folder of your project.
+
+ Note: All asset URLs in Creator use forward slashes, URLs using backslashes will not work. + @param url Url of the target folder. + The url is relative to the "resources" folder, extensions must be omitted. + @param type Only asset of type will be loaded if this argument is supplied. + @param progressCallback Callback invoked when progression change. + @param completeCallback A callback which is called when all assets have been loaded, or an error occurs. + + @example + ```js + // load the texture (resources/imgs/cocos.png) and the corresponding sprite frame + cc.loader.loadResDir('imgs/cocos', function (err, assets) { + if (err) { + cc.error(err); + return; + } + var texture = assets[0]; + var spriteFrame = assets[1]; + }); + + // load all textures in "resources/imgs/" + cc.loader.loadResDir('imgs', cc.Texture2D, function (err, textures) { + var texture1 = textures[0]; + var texture2 = textures[1]; + }); + + // load all JSONs in "resources/data/" + cc.loader.loadResDir('data', function (err, objects, urls) { + var data = objects[0]; + var url = urls[0]; + }); + ``` + */ + static loadResDir(url: string, type: typeof cc.Asset, progressCallback: (completedCount: number, totalCount: number, item: any) => void, completeCallback: ((error: Error, resource: any[], urls: string[]) => void)|null): void; + static loadResDir(url: string, type: typeof cc.Asset, completeCallback: (error: Error, resource: any[], urls: string[]) => void): void; + static loadResDir(url: string, type: typeof cc.Asset): void; + static loadResDir(url: string, progressCallback: (completedCount: number, totalCount: number, item: any) => void, completeCallback: ((error: Error, resource: any[], urls: string[]) => void)|null): void; + static loadResDir(url: string, completeCallback: (error: Error, resource: any[], urls: string[]) => void): void; + static loadResDir(url: string): void; + /** + Get resource data by id.
+ When you load resources with {{#crossLink "loader/load:method"}}{{/crossLink}} or {{#crossLink "loader/loadRes:method"}}{{/crossLink}}, + the url will be the unique identity of the resource. + After loaded, you can acquire them by passing the url to this API. + @param url url + @param type Only asset of type will be returned if this argument is supplied. + */ + static getRes(url: string, type?: Function): any; + /** + !#en Get all resource dependencies of the requested asset in an array, including itself. + The owner parameter accept the following types: 1. The asset itself; 2. The resource url; 3. The asset's uuid.
+ The returned array stores the dependencies with their uuids, after retrieve dependencies, + you can release them, access dependent assets by passing the uuid to {{#crossLink "loader/getRes:method"}}{{/crossLink}}, or other stuffs you want.
+ For release all dependencies of an asset, please refer to {{#crossLink "loader/release:method"}}{{/crossLink}} + Here is some examples: + !#zh 获取一个指定资源的所有依赖资源,包含它自身,并保存在数组中返回。owner 参数接收以下几种类型:1. 资源 asset 对象;2. 资源目录下的 url;3. 资源的 uuid。
+ 返回的数组将仅保存依赖资源的 uuid,获取这些 uuid 后,你可以从 loader 释放这些资源;通过 {{#crossLink "loader/getRes:method"}}{{/crossLink}} 获取某个资源或者进行其他你需要的操作。
+ 想要释放一个资源及其依赖资源,可以参考 {{#crossLink "loader/release:method"}}{{/crossLink}}。下面是一些示例代码: + @param owner The owner asset or the resource url or the asset's uuid + + @example + ```js + // Release all dependencies of a loaded prefab + var deps = cc.loader.getDependsRecursively(prefab); + cc.loader.release(deps); + // Retrieve all dependent textures + var deps = cc.loader.getDependsRecursively('prefabs/sample'); + var textures = []; + for (var i = 0; i < deps.length; ++i) { + var item = cc.loader.getRes(deps[i]); + if (item instanceof cc.Texture2D) { + textures.push(item); + } + } + ``` + */ + static getDependsRecursively(owner: Asset|RawAsset|string): any[]; + /** + !#en + Release the content of an asset or an array of assets by uuid. + Start from v1.3, this method will not only remove the cache of the asset in loader, but also clean up its content. + For example, if you release a texture, the texture asset and its gl texture data will be freed up. + In complexe project, you can use this function with {{#crossLink "loader/getDependsRecursively:method"}}{{/crossLink}} to free up memory in critical circumstances. + Notice, this method may cause the texture to be unusable, if there are still other nodes use the same texture, they may turn to black and report gl errors. + If you only want to remove the cache of an asset, please use {{#crossLink "pipeline/removeItem:method"}}{{/crossLink}} + !#zh + 通过 id(通常是资源 url)来释放一个资源或者一个资源数组。 + 从 v1.3 开始,这个方法不仅会从 loader 中删除资源的缓存引用,还会清理它的资源内容。 + 比如说,当你释放一个 texture 资源,这个 texture 和它的 gl 贴图数据都会被释放。 + 在复杂项目中,我们建议你结合 {{#crossLink "loader/getDependsRecursively:method"}}{{/crossLink}} 来使用,便于在设备内存告急的情况下更快地释放不再需要的资源的内存。 + 注意,这个函数可能会导致资源贴图或资源所依赖的贴图不可用,如果场景中存在节点仍然依赖同样的贴图,它们可能会变黑并报 GL 错误。 + 如果你只想删除一个资源的缓存引用,请使用 {{#crossLink "pipeline/removeItem:method"}}{{/crossLink}} + @param asset asset + + @example + ```js + // Release a texture which is no longer need + cc.loader.release(texture); + // Release all dependencies of a loaded prefab + var deps = cc.loader.getDependsRecursively('prefabs/sample'); + cc.loader.release(deps); + // If there is no instance of this prefab in the scene, the prefab and its dependencies like textures, sprite frames, etc, will be freed up. + // If you have some other nodes share a texture in this prefab, you can skip it in two ways: + // 1. Forbid auto release a texture before release + cc.loader.setAutoRelease(texture2d, false); + // 2. Remove it from the dependencies array + var deps = cc.loader.getDependsRecursively('prefabs/sample'); + var index = deps.indexOf(texture2d._uuid); + if (index !== -1) + deps.splice(index, 1); + cc.loader.release(deps); + ``` + */ + static release(asset: Asset|RawAsset|string|any[]): void; + /** + !#en Release the asset by its object. Refer to {{#crossLink "loader/release:method"}}{{/crossLink}} for detailed informations. + !#zh 通过资源对象自身来释放资源。详细信息请参考 {{#crossLink "loader/release:method"}}{{/crossLink}} + @param asset asset + */ + static releaseAsset(asset: Asset): void; + /** + !#en Release the asset loaded by {{#crossLink "loader/loadRes:method"}}{{/crossLink}}. Refer to {{#crossLink "loader/release:method"}}{{/crossLink}} for detailed informations. + !#zh 释放通过 {{#crossLink "loader/loadRes:method"}}{{/crossLink}} 加载的资源。详细信息请参考 {{#crossLink "loader/release:method"}}{{/crossLink}} + @param url url + @param type Only asset of type will be released if this argument is supplied. + */ + static releaseRes(url: string, type?: Function): void; + /** + !#en Release the all assets loaded by {{#crossLink "loader/loadResDir:method"}}{{/crossLink}}. Refer to {{#crossLink "loader/release:method"}}{{/crossLink}} for detailed informations. + !#zh 释放通过 {{#crossLink "loader/loadResDir:method"}}{{/crossLink}} 加载的资源。详细信息请参考 {{#crossLink "loader/release:method"}}{{/crossLink}} + @param url url + @param type Only asset of type will be released if this argument is supplied. + */ + static releaseResDir(url: string, type?: Function): void; + /** + !#en Resource all assets. Refer to {{#crossLink "loader/release:method"}}{{/crossLink}} for detailed informations. + !#zh 释放所有资源。详细信息请参考 {{#crossLink "loader/release:method"}}{{/crossLink}} + */ + static releaseAll(): void; + /** + !#en + Indicates whether to release the asset when loading a new scene.
+ By default, when loading a new scene, all assets in the previous scene will be released or preserved + according to whether the previous scene checked the "Auto Release Assets" option. + On the other hand, assets dynamically loaded by using `cc.loader.loadRes` or `cc.loader.loadResDir` + will not be affected by that option, remain not released by default.
+ Use this API to change the default behavior on a single asset, to force preserve or release specified asset when scene switching.
+
+ See: {{#crossLink "loader/setAutoReleaseRecursively:method"}}cc.loader.setAutoReleaseRecursively{{/crossLink}}, {{#crossLink "loader/isAutoRelease:method"}}cc.loader.isAutoRelease{{/crossLink}} + !#zh + 设置当场景切换时是否自动释放资源。
+ 默认情况下,当加载新场景时,旧场景的资源根据旧场景是否勾选“Auto Release Assets”,将会被释放或者保留。 + 而使用 `cc.loader.loadRes` 或 `cc.loader.loadResDir` 动态加载的资源,则不受场景设置的影响,默认不自动释放。
+ 使用这个 API 可以在单个资源上改变这个默认行为,强制在切换场景时保留或者释放指定资源。
+
+ 参考:{{#crossLink "loader/setAutoReleaseRecursively:method"}}cc.loader.setAutoReleaseRecursively{{/crossLink}},{{#crossLink "loader/isAutoRelease:method"}}cc.loader.isAutoRelease{{/crossLink}} + @param assetOrUrlOrUuid asset object or the raw asset's url or uuid + @param autoRelease indicates whether should release automatically + + @example + ```js + // auto release the texture event if "Auto Release Assets" disabled in current scene + cc.loader.setAutoRelease(texture2d, true); + // don't release the texture even if "Auto Release Assets" enabled in current scene + cc.loader.setAutoRelease(texture2d, false); + // first parameter can be url + cc.loader.setAutoRelease(audioUrl, false); + ``` + */ + static setAutoRelease(assetOrUrlOrUuid: Asset|string, autoRelease: boolean): void; + /** + !#en + Indicates whether to release the asset and its referenced other assets when loading a new scene.
+ By default, when loading a new scene, all assets in the previous scene will be released or preserved + according to whether the previous scene checked the "Auto Release Assets" option. + On the other hand, assets dynamically loaded by using `cc.loader.loadRes` or `cc.loader.loadResDir` + will not be affected by that option, remain not released by default.
+ Use this API to change the default behavior on the specified asset and its recursively referenced assets, to force preserve or release specified asset when scene switching.
+
+ See: {{#crossLink "loader/setAutoRelease:method"}}cc.loader.setAutoRelease{{/crossLink}}, {{#crossLink "loader/isAutoRelease:method"}}cc.loader.isAutoRelease{{/crossLink}} + !#zh + 设置当场景切换时是否自动释放资源及资源引用的其它资源。
+ 默认情况下,当加载新场景时,旧场景的资源根据旧场景是否勾选“Auto Release Assets”,将会被释放或者保留。 + 而使用 `cc.loader.loadRes` 或 `cc.loader.loadResDir` 动态加载的资源,则不受场景设置的影响,默认不自动释放。
+ 使用这个 API 可以在指定资源及资源递归引用到的所有资源上改变这个默认行为,强制在切换场景时保留或者释放指定资源。
+
+ 参考:{{#crossLink "loader/setAutoRelease:method"}}cc.loader.setAutoRelease{{/crossLink}},{{#crossLink "loader/isAutoRelease:method"}}cc.loader.isAutoRelease{{/crossLink}} + @param assetOrUrlOrUuid asset object or the raw asset's url or uuid + @param autoRelease indicates whether should release automatically + + @example + ```js + // auto release the SpriteFrame and its Texture event if "Auto Release Assets" disabled in current scene + cc.loader.setAutoReleaseRecursively(spriteFrame, true); + // don't release the SpriteFrame and its Texture even if "Auto Release Assets" enabled in current scene + cc.loader.setAutoReleaseRecursively(spriteFrame, false); + // don't release the Prefab and all the referenced assets + cc.loader.setAutoReleaseRecursively(prefab, false); + ``` + */ + static setAutoReleaseRecursively(assetOrUrlOrUuid: Asset|string, autoRelease: boolean): void; + /** + !#en + Returns whether the asset is configured as auto released, despite how "Auto Release Assets" property is set on scene asset.
+
+ See: {{#crossLink "loader/setAutoRelease:method"}}cc.loader.setAutoRelease{{/crossLink}}, {{#crossLink "loader/setAutoReleaseRecursively:method"}}cc.loader.setAutoReleaseRecursively{{/crossLink}} + + !#zh + 返回指定的资源是否有被设置为自动释放,不论场景的“Auto Release Assets”如何设置。
+
+ 参考:{{#crossLink "loader/setAutoRelease:method"}}cc.loader.setAutoRelease{{/crossLink}},{{#crossLink "loader/setAutoReleaseRecursively:method"}}cc.loader.setAutoReleaseRecursively{{/crossLink}} + @param assetOrUrl asset object or the raw asset's url + */ + static isAutoRelease(assetOrUrl: Asset|string): boolean; + } + /** !#en + LoadingItems is the queue of items which can flow them into the loading pipeline.
+ Please don't construct it directly, use {{#crossLink "LoadingItems.create"}}LoadingItems.create{{/crossLink}} instead, because we use an internal pool to recycle the queues.
+ It hold a map of items, each entry in the map is a url to object key value pair.
+ Each item always contains the following property:
+ - id: The identification of the item, usually it's identical to url
+ - url: The url
+ - type: The type, it's the extension name of the url by default, could be specified manually too.
+ - error: The error happened in pipeline will be stored in this property.
+ - content: The content processed by the pipeline, the final result will also be stored in this property.
+ - complete: The flag indicate whether the item is completed by the pipeline.
+ - states: An object stores the states of each pipe the item go through, the state can be: Pipeline.ItemState.WORKING | Pipeline.ItemState.ERROR | Pipeline.ItemState.COMPLETE
+
+ Item can hold other custom properties.
+ Each LoadingItems object will be destroyed for recycle after onComplete callback
+ So please don't hold its reference for later usage, you can copy properties in it though. + !#zh + LoadingItems 是一个加载对象队列,可以用来输送加载对象到加载管线中。
+ 请不要直接使用 new 构造这个类的对象,你可以使用 {{#crossLink "LoadingItems.create"}}LoadingItems.create{{/crossLink}} 来创建一个新的加载队列,这样可以允许我们的内部对象池回收并重利用加载队列。 + 它有一个 map 属性用来存放加载项,在 map 对象中已 url 为 key 值。
+ 每个对象都会包含下列属性:
+ - id:该对象的标识,通常与 url 相同。
+ - url:路径
+ - type: 类型,它这是默认的 URL 的扩展名,可以手动指定赋值。
+ - error:pipeline 中发生的错误将被保存在这个属性中。
+ - content: pipeline 中处理的临时结果,最终的结果也将被存储在这个属性中。
+ - complete:该标志表明该对象是否通过 pipeline 完成。
+ - states:该对象存储每个管道中对象经历的状态,状态可以是 Pipeline.ItemState.WORKING | Pipeline.ItemState.ERROR | Pipeline.ItemState.COMPLETE
+
+ 对象可容纳其他自定义属性。
+ 每个 LoadingItems 对象都会在 onComplete 回调之后被销毁,所以请不要持有它的引用并在结束回调之后依赖它的内容执行任何逻辑,有这种需求的话你可以提前复制它的内容。 */ + export class LoadingItems extends CallbacksInvoker { + /** + !#en This is a callback which will be invoked while an item flow out the pipeline. + You can pass the callback function in LoadingItems.create or set it later. + !#zh 这个回调函数将在 item 加载结束后被调用。你可以在构造时传递这个回调函数或者是在构造之后直接设置。 + @param completedCount The number of the items that are already completed. + @param totalCount The total number of the items. + @param item The latest item which flow out the pipeline. + + @example + ```js + loadingItems.onProgress = function (completedCount, totalCount, item) { + var progress = (100 * completedCount / totalCount).toFixed(2); + cc.log(progress + '%'); + } + ``` + */ + onProgress(completedCount: number, totalCount: number, item: any): void; + /** + !#en This is a callback which will be invoked while all items is completed, + You can pass the callback function in LoadingItems.create or set it later. + !#zh 该函数将在加载队列全部完成时被调用。你可以在构造时传递这个回调函数或者是在构造之后直接设置。 + @param errors All errored urls will be stored in this array, if no error happened, then it will be null + @param items All items. + + @example + ```js + loadingItems.onComplete = function (errors, items) { + if (error) + cc.log('Completed with ' + errors.length + ' errors'); + else + cc.log('Completed ' + items.totalCount + ' items'); + } + ``` + */ + onComplete(errors: any[], items: LoadingItems): void; + /** !#en The map of all items. + !#zh 存储所有加载项的对象。 */ + map: any; + /** !#en The map of completed items. + !#zh 存储已经完成的加载项。 */ + completed: any; + /** !#en Total count of all items. + !#zh 所有加载项的总数。 */ + totalCount: number; + /** !#en Total count of completed items. + !#zh 所有完成加载项的总数。 */ + completedCount: number; + /** !#en Activated or not. + !#zh 是否启用。 */ + active: boolean; + /** + !#en The constructor function of LoadingItems, this will use recycled LoadingItems in the internal pool if possible. + You can pass onProgress and onComplete callbacks to visualize the loading process. + !#zh LoadingItems 的构造函数,这种构造方式会重用内部对象缓冲池中的 LoadingItems 队列,以尽量避免对象创建。 + 你可以传递 onProgress 和 onComplete 回调函数来获知加载进度信息。 + @param pipeline The pipeline to process the queue. + @param urlList The items array. + @param onProgress The progression callback, refer to {{#crossLink "LoadingItems.onProgress"}}{{/crossLink}} + @param onComplete The completion callback, refer to {{#crossLink "LoadingItems.onComplete"}}{{/crossLink}} + + @example + ```js + LoadingItems.create(cc.loader, ['a.png', 'b.plist'], function (completedCount, totalCount, item) { + var progress = (100 * completedCount / totalCount).toFixed(2); + cc.log(progress + '%'); + }, function (errors, items) { + if (errors) { + for (var i = 0; i < errors.length; ++i) { + cc.log('Error url: ' + errors[i] + ', error: ' + items.getError(errors[i])); + } + } + else { + var result_a = items.getContent('a.png'); + // ... + } + }) + ``` + */ + static create(pipeline: Pipeline, urlList: any[], onProgress: Function, onComplete: Function): LoadingItems; + /** + !#en Retrieve the LoadingItems queue object for an item. + !#zh 通过 item 对象获取它的 LoadingItems 队列。 + @param item The item to query + */ + static getQueue(item: any): LoadingItems; + /** + !#en Complete an item in the LoadingItems queue, please do not call this method unless you know what's happening. + !#zh 通知 LoadingItems 队列一个 item 对象已完成,请不要调用这个函数,除非你知道自己在做什么。 + @param item The item which has completed + */ + static itemComplete(item: any): void; + /** + !#en Add urls to the LoadingItems queue. + !#zh 向一个 LoadingItems 队列添加加载项。 + @param urlList The url list to be appended, the url can be object or string + */ + append(urlList: any[]): any[]; + /** + !#en Complete a LoadingItems queue, please do not call this method unless you know what's happening. + !#zh 完成一个 LoadingItems 队列,请不要调用这个函数,除非你知道自己在做什么。 + */ + allComplete(): void; + /** + !#en Check whether all items are completed. + !#zh 检查是否所有加载项都已经完成。 + */ + isCompleted(): boolean; + /** + !#en Check whether an item is completed. + !#zh 通过 id 检查指定加载项是否已经加载完成。 + @param id The item's id. + */ + isItemCompleted(id: string): boolean; + /** + !#en Check whether an item exists. + !#zh 通过 id 检查加载项是否存在。 + @param id The item's id. + */ + exists(id: string): boolean; + /** + !#en Returns the content of an internal item. + !#zh 通过 id 获取指定对象的内容。 + @param id The item's id. + */ + getContent(id: string): any; + /** + !#en Returns the error of an internal item. + !#zh 通过 id 获取指定对象的错误信息。 + @param id The item's id. + */ + getError(id: string): any; + /** + !#en Add a listener for an item, the callback will be invoked when the item is completed. + !#zh 监听加载项(通过 key 指定)的完成事件。 + @param key key + @param callback can be null + @param target can be null + */ + addListener(key: string, callback: Function, target: any): boolean; + /** + !#en + Check if the specified key has any registered callback.
+ If a callback is also specified, it will only return true if the callback is registered. + !#zh + 检查指定的加载项是否有完成事件监听器。
+ 如果同时还指定了一个回调方法,并且回调有注册,它只会返回 true。 + @param key key + @param callback callback + @param target target + */ + hasListener(key: string, callback?: Function, target?: any): boolean; + /** + !#en + Removes a listener.
+ It will only remove when key, callback, target all match correctly. + !#zh + 移除指定加载项已经注册的完成事件监听器。
+ 只会删除 key, callback, target 均匹配的监听器。 + @param key key + @param callback callback + @param target target + */ + remove(key: string, callback: Function, target: any): boolean; + /** + !#en + Removes all callbacks registered in a certain event + type or all callbacks registered with a certain target. + !#zh 删除指定目标的所有完成事件监听器。 + @param key The event key to be removed or the target to be removed + */ + removeAllListeners(key: string|any): void; + /** + !#en Complete an item in the LoadingItems queue, please do not call this method unless you know what's happening. + !#zh 通知 LoadingItems 队列一个 item 对象已完成,请不要调用这个函数,除非你知道自己在做什么。 + @param id The item url + */ + itemComplete(id: string): void; + /** + !#en Destroy the LoadingItems queue, the queue object won't be garbage collected, it will be recycled, so every after destroy is not reliable. + !#zh 销毁一个 LoadingItems 队列,这个队列对象会被内部缓冲池回收,所以销毁后的所有内部信息都是不可依赖的。 + */ + destroy(): void; + } + /** !#en + A pipeline describes a sequence of manipulations, each manipulation is called a pipe.
+ It's designed for loading process. so items should be urls, and the url will be the identity of each item during the process.
+ A list of items can flow in the pipeline and it will output the results of all pipes.
+ They flow in the pipeline like water in tubes, they go through pipe by pipe separately.
+ Finally all items will flow out the pipeline and the process is finished. + + !#zh + pipeline 描述了一系列的操作,每个操作都被称为 pipe。
+ 它被设计来做加载过程的流程管理。所以 item 应该是 url,并且该 url 将是在处理中的每个 item 的身份标识。
+ 一个 item 列表可以在 pipeline 中流动,它将输出加载项经过所有 pipe 之后的结果。
+ 它们穿过 pipeline 就像水在管子里流动,将会按顺序流过每个 pipe。
+ 最后当所有加载项都流出 pipeline 时,整个加载流程就结束了。 */ + export class Pipeline { + /** + !#en + Constructor, pass an array of pipes to construct a new Pipeline, + the pipes will be chained in the given order.
+ A pipe is an object which must contain an `id` in string and a `handle` function, + the id must be unique in the pipeline.
+ It can also include `async` property to identify whether it's an asynchronous process. + !#zh + 构造函数,通过一系列的 pipe 来构造一个新的 pipeline,pipes 将会在给定的顺序中被锁定。
+ 一个 pipe 就是一个对象,它包含了字符串类型的 ‘id’ 和 ‘handle’ 函数,在 pipeline 中 id 必须是唯一的。
+ 它还可以包括 ‘async’ 属性以确定它是否是一个异步过程。 + @param pipes pipes + + @example + ```js + var pipeline = new Pipeline([ + { + id: 'Downloader', + handle: function (item, callback) {}, + async: true + }, + {id: 'Parser', handle: function (item) {}, async: false} + ]); + ``` + */ + constructor(pipes: any[]); + /** + !#en + Insert a new pipe at the given index of the pipeline.
+ A pipe must contain an `id` in string and a `handle` function, the id must be unique in the pipeline. + !#zh + 在给定的索引位置插入一个新的 pipe。
+ 一个 pipe 必须包含一个字符串类型的 ‘id’ 和 ‘handle’ 函数,该 id 在 pipeline 必须是唯一标识。 + @param pipe The pipe to be inserted + @param index The index to insert + */ + insertPipe(pipe: any, index: number): void; + /** + !en + Insert a pipe to the end of an existing pipe. The existing pipe must be a valid pipe in the pipeline. + !zh + 在当前 pipeline 的一个已知 pipe 后面插入一个新的 pipe。 + @param refPipe An existing pipe in the pipeline. + @param newPipe The pipe to be inserted. + */ + insertPipeAfter(refPipe: any, newPipe: any): void; + /** + !#en + Add a new pipe at the end of the pipeline.
+ A pipe must contain an `id` in string and a `handle` function, the id must be unique in the pipeline. + !#zh + 添加一个新的 pipe 到 pipeline 尾部。
+ 该 pipe 必须包含一个字符串类型 ‘id’ 和 ‘handle’ 函数,该 id 在 pipeline 必须是唯一标识。 + @param pipe The pipe to be appended + */ + appendPipe(pipe: any): void; + /** + !#en + Let new items flow into the pipeline.
+ Each item can be a simple url string or an object, + if it's an object, it must contain `id` property.
+ You can specify its type by `type` property, by default, the type is the extension name in url.
+ By adding a `skips` property including pipe ids, you can skip these pipe.
+ The object can contain any supplementary property as you want.
+ !#zh + 让新的 item 流入 pipeline 中。
+ 这里的每个 item 可以是一个简单字符串类型的 url 或者是一个对象, + 如果它是一个对象的话,他必须要包含 ‘id’ 属性。
+ 你也可以指定它的 ‘type’ 属性类型,默认情况下,该类型是 ‘url’ 的后缀名。
+ 也通过添加一个 包含 ‘skips’ 属性的 item 对象,你就可以跳过 skips 中包含的 pipe。
+ 该对象可以包含任何附加属性。 + @param items items + + @example + ```js + pipeline.flowIn([ + 'res/Background.png', + { + id: 'res/scene.json', + type: 'scene', + name: 'scene', + skips: ['Downloader'] + } + ]); + ``` + */ + flowIn(items: any[]): void; + /** + !#en + Let new items flow into the pipeline and give a callback when the list of items are all completed.
+ This is for loading dependencies for an existing item in flow, usually used in a pipe logic.
+ For example, we have a loader for scene configuration file in JSON, the scene will only be fully loaded
+ after all its dependencies are loaded, then you will need to use function to flow in all dependencies
+ found in the configuration file, and finish the loader pipe only after all dependencies are loaded (in the callback). + !#zh + 让新 items 流入 pipeline 并且当 item 列表完成时进行回调函数。
+ 这个 API 的使用通常是为了加载依赖项。
+ 例如:
+ 我们需要加载一个场景配置的 JSON 文件,该场景会将所有的依赖项全部都加载完毕以后,进行回调表示加载完毕。 + @param urlList urlList + @param callback callback + */ + flowInDeps(urlList: any[], callback: Function): any[]; + /** + !#en + Copy the item states from one source item to all destination items.
+ It's quite useful when a pipe generate new items from one source item,
+ then you should flowIn these generated items into pipeline,
+ but you probably want them to skip all pipes the source item already go through,
+ you can achieve it with this API.
+
+ For example, an unzip pipe will generate more items, but you won't want them to pass unzip or download pipe again. + !#zh + 从一个源 item 向所有目标 item 复制它的 pipe 状态,用于避免重复通过部分 pipe。
+ 当一个源 item 生成了一系列新的 items 时很有用,
+ 你希望让这些新的依赖项进入 pipeline,但是又不希望它们通过源 item 已经经过的 pipe,
+ 但是你可能希望他们源 item 已经通过并跳过所有 pipes,
+ 这个时候就可以使用这个 API。 + @param srcItem The source item + @param dstItems A single destination item or an array of destination items + */ + copyItemStates(srcItem: any, dstItems: any[]|any): void; + /** + !#en Returns whether the pipeline is flowing (contains item) currently. + !#zh 获取 pipeline 当前是否正在处理中。 + */ + isFlowing(): boolean; + /** + !#en Returns all items in pipeline. Returns null, please use API of Loader or LoadingItems. + !#zh 获取 pipeline 中的所有 items。返回 null,请使用 Loader / LoadingItems API。 + */ + getItems(): LoadingItems; + /** + !#en Returns an item in pipeline. + !#zh 根据 id 获取一个 item + @param id The id of the item + */ + getItem(id: any): any; + /** + !#en Removes an completed item in pipeline. + It will only remove the cache in the pipeline or loader, its dependencies won't be released. + cc.loader provided another method to completely cleanup the resource and its dependencies, + please refer to {{#crossLink "loader/release:method"}}cc.loader.release{{/crossLink}} + !#zh 移除指定的已完成 item。 + 这将仅仅从 pipeline 或者 loader 中删除其缓存,并不会释放它所依赖的资源。 + cc.loader 中提供了另一种删除资源及其依赖的清理方法,请参考 {{#crossLink "loader/release:method"}}cc.loader.release{{/crossLink}} + @param id The id of the item + */ + removeItem(id: any): boolean; + /** + !#en Clear the current pipeline, this function will clean up the items. + !#zh 清空当前 pipeline,该函数将清理 items。 + */ + clear(): void; + } + /** undefined */ + export class WorldManifold { + /** !#en + world contact point (point of intersection) + !#zh + 碰撞点集合 */ + points: [Vec2]; + /** !#en + world vector pointing from A to B + !#zh + 世界坐标系下由 A 指向 B 的向量 */ + normal: Vec2; + } + /** !#en + A manifold point is a contact point belonging to a contact manifold. + It holds details related to the geometry and dynamics of the contact points. + Note: the impulses are used for internal caching and may not + provide reliable contact forces, especially for high speed collisions. + !#zh + ManifoldPoint 是接触信息中的接触点信息。它拥有关于几何和接触点的详细信息。 + 注意:信息中的冲量用于系统内部缓存,提供的接触力可能不是很准确,特别是高速移动中的碰撞信息。 */ + export class ManifoldPoint { + /** !#en + The local point usage depends on the manifold type: + -e_circles: the local center of circleB + -e_faceA: the local center of circleB or the clip point of polygonB + -e_faceB: the clip point of polygonA + !#zh + 本地坐标点的用途取决于 manifold 的类型 + - e_circles: circleB 的本地中心点 + - e_faceA: circleB 的本地中心点 或者是 polygonB 的截取点 + - e_faceB: polygonB 的截取点 */ + localPoint: Vec2; + /** !#en + Normal impulse. + !#zh + 法线冲量。 */ + normalImpulse: number; + /** !#en + Tangent impulse. + !#zh + 切线冲量。 */ + tangentImpulse: number; + } + /** undefined */ + export class Manifold { + /** !#en + Manifold type : 0: e_circles, 1: e_faceA, 2: e_faceB + !#zh + Manifold 类型 : 0: e_circles, 1: e_faceA, 2: e_faceB */ + type: number; + /** !#en + The local point usage depends on the manifold type: + -e_circles: the local center of circleA + -e_faceA: the center of faceA + -e_faceB: the center of faceB + !#zh + 用途取决于 manifold 类型 + -e_circles: circleA 的本地中心点 + -e_faceA: faceA 的本地中心点 + -e_faceB: faceB 的本地中心点 */ + localPoint: Vec2; + /** !#en + -e_circles: not used + -e_faceA: the normal on polygonA + -e_faceB: the normal on polygonB + !#zh + -e_circles: 没被使用到 + -e_faceA: polygonA 的法向量 + -e_faceB: polygonB 的法向量 */ + localNormal: Vec2; + /** !#en + the points of contact. + !#zh + 接触点信息。 */ + points: [ManifoldPoint]; + } + /** !#en + Contact impulses for reporting. + !#zh + 用于返回给回调的接触冲量。 */ + export class PhysicsImpulse { + /** !#en + Normal impulses. + !#zh + 法线方向的冲量 */ + normalImpulses: void; + /** !#en + Tangent impulses + !#zh + 切线方向的冲量 */ + tangentImpulses: void; + } + /** !#en + PhysicsContact will be generated during begin and end collision as a parameter of the collision callback. + Note that contacts will be reused for speed up cpu time, so do not cache anything in the contact. + !#zh + 物理接触会在开始和结束碰撞之间生成,并作为参数传入到碰撞回调函数中。 + 注意:传入的物理接触会被系统进行重用,所以不要在使用中缓存里面的任何信息。 */ + export class PhysicsContact { + /** + !#en + Get the world manifold. + !#zh + 获取世界坐标系下的碰撞信息。 + */ + getWorldManifold(): WorldManifold; + /** + !#en + Get the manifold. + !#zh + 获取世界坐标系下的碰撞信息。 + */ + getManifold(): Manifold; + /** + !#en + Get the impulses. + Note: PhysicsImpulse can only used in onPostSolve callback. + !#zh + 获取冲量信息 + 注意:这个信息只有在 onPostSolve 回调中才能获取到 + */ + getImpulse(): PhysicsImpulse; + colliderA: Collider; + colliderB: Collider; + /** !#en + If set disabled to true, the contact will be ignored until contact end. + If you just want to disabled contact for current time step or sub-step, please use disabledOnce. + !#zh + 如果 disabled 被设置为 true,那么直到接触结束此接触都将被忽略。 + 如果只是希望在当前时间步或子步中忽略此接触,请使用 disabledOnce 。 */ + disabled: boolean; + /** !#en + Disabled contact for current time step or sub-step. + !#zh + 在当前时间步或子步中忽略此接触。 */ + disabledOnce: boolean; + /** + !#en + Is this contact touching? + !#zh + 返回碰撞体是否已经接触到。 + */ + isTouching(): boolean; + /** + !#en + Set the desired tangent speed for a conveyor belt behavior. + !#zh + 为传送带设置期望的切线速度 + @param tangentSpeed tangentSpeed + */ + setTangentSpeed(tangentSpeed: number): void; + /** + !#en + Get the desired tangent speed. + !#zh + 获取切线速度 + */ + getTangentSpeed(): number; + /** + !#en + Override the default friction mixture. You can call this in onPreSolve callback. + !#zh + 覆盖默认的摩擦力系数。你可以在 onPreSolve 回调中调用此函数。 + @param friction friction + */ + setFriction(friction: number): void; + /** + !#en + Get the friction. + !#zh + 获取当前摩擦力系数 + */ + getFriction(): number; + /** + !#en + Reset the friction mixture to the default value. + !#zh + 重置摩擦力系数到默认值 + */ + resetFriction(): void; + /** + !#en + Override the default restitution mixture. You can call this in onPreSolve callback. + !#zh + 覆盖默认的恢复系数。你可以在 onPreSolve 回调中调用此函数。 + @param restitution restitution + */ + setRestitution(restitution: number): void; + /** + !#en + Get the restitution. + !#zh + 获取当前恢复系数 + */ + getRestitution(): number; + /** + !#en + Reset the restitution mixture to the default value. + !#zh + 重置恢复系数到默认值 + */ + resetRestitution(): void; + } + /** !#en + Physics manager uses box2d as the inner physics system, and hide most box2d implement details(creating rigidbody, synchronize rigidbody info to node). + You can visit some common box2d function through physics manager(hit testing, raycast, debug info). + Physics manager distributes the collision information to each collision callback when collision is produced. + Note: You need first enable the collision listener in the rigidbody. + !#zh + 物理系统将 box2d 作为内部物理系统,并且隐藏了大部分 box2d 实现细节(比如创建刚体,同步刚体信息到节点中等)。 + 你可以通过物理系统访问一些 box2d 常用的功能,比如点击测试,射线测试,设置测试信息等。 + 物理系统还管理碰撞信息的分发,她会在产生碰撞时,将碰撞信息分发到各个碰撞回调中。 + 注意:你需要先在刚体中开启碰撞接听才会产生相应的碰撞回调。 */ + export class PhysicsManager implements EventTarget { + /** !#en + The draw bits for drawing physics debug information. + !#zh + 指定物理系统需要绘制哪些调试信息。 */ + static DrawBits: DrawBits; + /** !#en + The ratio transform between physics unit and pixel unit, generally is 32. + !#zh + 物理单位与像素单位互相转换的比率,一般是 32。 */ + static PTM_RATIO: number; + /** !#en + The velocity iterations for the velocity constraint solver. + !#zh + 速度更新迭代数 */ + static VELOCITY_ITERATIONS: number; + /** !#en + The position Iterations for the position constraint solver. + !#zh + 位置迭代更新数 */ + static POSITION_ITERATIONS: number; + /** !#en + If enabled accumulator, then will call step function with a fixed time step. + And if the update dt is bigger than the time step, then will call step function several times. + If disabled accumulator, then will call step function with a time step calculated with the frame rate. + !#zh + 如果开启此选项,那么将会以一个固定的时间步来更新物理引擎,如果一个 update 的间隔时间大于这个时间步,则会对物理引擎进行多次更新。 + 如果关闭此选项,那么将会根据设定的 frame rate 计算出一个时间步来更新物理引擎。 */ + enabledAccumulator: boolean; + /** + !#en + Test which collider contains the given world point + !#zh + 获取包含给定世界坐标系点的碰撞体 + @param point the world point + */ + testPoint(point: Vec2): PhysicsCollider; + /** + !#en + Test which colliders intersect the given world rect + !#zh + 获取与给定世界坐标系矩形相交的碰撞体 + @param rect the world rect + */ + testAABB(rect: Rect): [PhysicsCollider]; + /** + !#en + Raycast the world for all colliders in the path of the ray. + The raycast ignores colliders that contain the starting point. + !#zh + 检测哪些碰撞体在给定射线的路径上,射线检测将忽略包含起始点的碰撞体。 + @param p1 start point of the raycast + @param p2 end point of the raycast + @param type optional, default is RayCastType.Closest + */ + rayCast(p1: Vec2, p2: Vec2, type: RayCastType): [PhysicsRayCastResult]; + /** + !#en + Attach physics debug draw to camera + !#zh + 将物理的调试绘制信息附加到指定摄像机上 + @param camera camera + */ + attachDebugDrawToCamera(camera: Camera): void; + /** + !#en + Detach physics debug draw to camera + !#zh + 将物理的调试绘制信息从指定摄像机上移除 + @param camera camera + */ + detachDebugDrawFromCamera(camera: Camera): void; + /** !#en + Enabled the physics manager? + !#zh + 指定是否启用物理系统? */ + enabled: boolean; + /** !#en + Debug draw flags. + !#zh + 设置调试绘制标志 */ + debugDrawFlags: number; + /** !#en + The physics world gravity. + !#zh + 物理世界重力值 */ + gravity: Vec2; + /** + !#en + Register an callback of a specific event type on the EventTarget. + !#zh + 注册事件目标的特定事件类型回调。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + on(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + on(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Removes the listeners previously registered with the same type, callback, target and or useCapture, + if only type is passed as parameter, all listeners registered with that type will be removed. + !#zh + 删除之前用同类型,回调,目标或 useCapture 注册的事件监听器,如果只传递 type,将会删除 type 类型的所有事件监听器。 + @param type A string representing the event type being removed. + @param callback The callback to remove. + @param target The target (this object) to invoke the callback, if it's not given, only callback without target will be removed + @param useCapture Specifies whether the callback being removed was registered as a capturing callback or not. + If not specified, useCapture defaults to false. If a callback was registered twice, + one with capture and one without, each must be removed separately. Removal of a capturing callback + does not affect a non-capturing version of the same listener, and vice versa. + + @example + ```js + // register touchEnd eventListener + var touchEnd = node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + // remove touch end event listener + node.off(cc.Node.EventType.TOUCH_END, touchEnd, node); + // remove all touch end event listeners + node.off(cc.Node.EventType.TOUCH_END); + ``` + */ + off(type: string, callback?: Function, target?: any, useCapture?: boolean): void; + /** + !#en Removes all callbacks previously registered with the same target (passed as parameter). + This is not for removing all listeners in the current event target, + and this is not for removing all listeners the target parameter have registered. + It's only for removing all listeners (callback and target couple) registered on the current event target by the target parameter. + !#zh 在当前 EventTarget 上删除指定目标(target 参数)注册的所有事件监听器。 + 这个函数无法删除当前 EventTarget 的所有事件监听器,也无法删除 target 参数所注册的所有事件监听器。 + 这个函数只能删除 target 参数在当前 EventTarget 上注册的所有事件监听器。 + @param target The target to be searched for all related listeners + */ + targetOff(target: any): void; + /** + !#en + Register an callback of a specific event type on the EventTarget, + the callback will remove itself after the first time it is triggered. + !#zh + 注册事件目标的特定事件类型回调,回调会在第一时间被触发后删除自身。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.once(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + once(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + once(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Dispatches an event into the event flow. + The event target is the EventTarget object upon which the dispatchEvent() method is called. + !#zh 分发事件到事件流中。 + @param event The Event object that is dispatched into the event flow + */ + dispatchEvent(event: Event): void; + /** + !#en + Send an event to this object directly, this method will not propagate the event to any other objects. + The event will be created from the supplied message, you can get the "detail" argument from event.detail. + !#zh + 该对象直接发送事件, 这种方法不会对事件传播到任何其他对象。 + @param message the message to send + @param detail whatever argument the message needs + */ + emit(message: string, detail?: any): void; + } + /** undefined */ + export enum DrawBits { + e_aabbBit = 0, + e_pairBit = 0, + e_centerOfMassBit = 0, + e_jointBit = 0, + e_shapeBit = 0, + } + /** undefined */ + export class PhysicsRayCastResult { + /** !#en + The PhysicsCollider which intersects with the raycast + !#zh + 与射线相交的碰撞体 */ + collider: PhysicsCollider; + /** !#en + The intersection point + !#zh + 射线与碰撞体相交的点 */ + point: Vec2; + /** !#en + The normal vector at the point of intersection + !#zh + 射线与碰撞体相交的点的法向量 */ + normal: Vec2; + /** !#en + The fraction of the raycast path at the point of intersection + !#zh + 射线与碰撞体相交的点占射线长度的分数 */ + fraction: number; + } + /** !#en Enum for RigidBodyType. + !#zh 刚体类型 */ + export enum RigidBodyType { + Static = 0, + Kinematic = 0, + Dynamic = 0, + Animated = 0, + } + /** !#en Enum for RayCastType. + !#zh 射线检测类型 */ + export enum RayCastType { + Closest = 0, + Any = 0, + AllClosest = 0, + All = 0, + } + /** undefined */ + export class RigidBody extends Component { + /** !#en + Should enabled contact listener? + When a collision is trigger, the collision callback will only be called when enabled contact listener. + !#zh + 是否启用接触接听器。 + 当 collider 产生碰撞时,只有开启了接触接听器才会调用相应的回调函数 */ + enabledContactListener: boolean; + /** + !#en + Collision callback. + Called when two collider begin to touch. + !#zh + 碰撞回调。 + 如果你的脚本中实现了这个函数,那么它将会在两个碰撞体开始接触时被调用。 + @param contact contact information + @param selfCollider the collider belong to this rigidbody + @param otherCollider the collider belong to another rigidbody + */ + onBeginContact(contact: PhysicsContact, selfCollider: PhysicsCollider, otherCollider: PhysicsCollider): void; + /** + !#en + Collision callback. + Called when two collider cease to touch. + !#zh + 碰撞回调。 + 如果你的脚本中实现了这个函数,那么它将会在两个碰撞体停止接触时被调用。 + @param contact contact information + @param selfCollider the collider belong to this rigidbody + @param otherCollider the collider belong to another rigidbody + */ + onEndContact(contact: PhysicsContact, selfCollider: PhysicsCollider, otherCollider: PhysicsCollider): void; + /** + !#en + Collision callback. + This is called when a contact is updated. + This allows you to inspect a contact before it goes to the solver(e.g. disable contact). + Note: this is called only for awake bodies. + Note: this is called even when the number of contact points is zero. + Note: this is not called for sensors. + !#zh + 碰撞回调。 + 如果你的脚本中实现了这个函数,那么它将会在接触更新时被调用。 + 你可以在接触被处理前根据他包含的信息作出相应的处理,比如将这个接触禁用掉。 + 注意:回调只会为醒着的刚体调用。 + 注意:接触点为零的时候也有可能被调用。 + 注意:感知体(sensor)的回调不会被调用。 + @param contact contact information + @param selfCollider the collider belong to this rigidbody + @param otherCollider the collider belong to another rigidbody + */ + onPreSolve(contact: PhysicsContact, selfCollider: PhysicsCollider, otherCollider: PhysicsCollider): void; + /** + !#en + Collision callback. + This is called after a contact is updated. + You can get the impulses from the contact in this callback. + !#zh + 碰撞回调。 + 如果你的脚本中实现了这个函数,那么它将会在接触更新完后被调用。 + 你可以在这个回调中从接触信息中获取到冲量信息。 + @param contact contact information + @param selfCollider the collider belong to this rigidbody + @param otherCollider the collider belong to another rigidbody + */ + onPostSolve(contact: PhysicsContact, selfCollider: PhysicsCollider, otherCollider: PhysicsCollider): void; + /** !#en + Is this a fast moving body that should be prevented from tunneling through + other moving bodies? + Note : + - All bodies are prevented from tunneling through kinematic and static bodies. This setting is only considered on dynamic bodies. + - You should use this flag sparingly since it increases processing time. + !#zh + 这个刚体是否是一个快速移动的刚体,并且需要禁止穿过其他快速移动的刚体? + 需要注意的是 : + - 所有刚体都被禁止从 运动刚体 和 静态刚体 中穿过。此选项只关注于 动态刚体。 + - 应该尽量少的使用此选项,因为它会增加程序处理时间。 */ + bullet: boolean; + /** !#en + Rigidbody type : Static, Kinematic, Dynamic or Animated. + !#zh + 刚体类型: Static, Kinematic, Dynamic or Animated. */ + type: RigidBodyType; + /** !#en + Set this flag to false if this body should never fall asleep. + Note that this increases CPU usage. + !#zh + 如果此刚体永远都不应该进入睡眠,那么设置这个属性为 false。 + 需要注意这将使 CPU 占用率提高。 */ + allowSleep: boolean; + /** !#en + Scale the gravity applied to this body. + !#zh + 缩放应用在此刚体上的重力值 */ + gravityScale: number; + /** !#en + Linear damping is use to reduce the linear velocity. + The damping parameter can be larger than 1, but the damping effect becomes sensitive to the + time step when the damping parameter is large. + !#zh + Linear damping 用于衰减刚体的线性速度。衰减系数可以大于 1,但是当衰减系数比较大的时候,衰减的效果会变得比较敏感。 */ + linearDamping: number; + /** !#en + Angular damping is use to reduce the angular velocity. The damping parameter + can be larger than 1 but the damping effect becomes sensitive to the + time step when the damping parameter is large. + !#zh + Angular damping 用于衰减刚体的角速度。衰减系数可以大于 1,但是当衰减系数比较大的时候,衰减的效果会变得比较敏感。 */ + angularDamping: number; + /** !#en + The linear velocity of the body's origin in world co-ordinates. + !#zh + 刚体在世界坐标下的线性速度 */ + linearVelocity: Vec2; + /** !#en + The angular velocity of the body. + !#zh + 刚体的角速度 */ + angularVelocity: number; + /** !#en + Should this body be prevented from rotating? + !#zh + 是否禁止此刚体进行旋转 */ + fixedRotation: boolean; + /** !#en + Is this body initially awake or sleeping? + !#zh + 是否立刻唤醒此刚体 */ + awake: boolean; + /** !#en + Set the active state of the body. An inactive body is not + simulated and cannot be collided with or woken up. + If body is active, all fixtures will be added to the + broad-phase. + If body is inactive, all fixtures will be removed from + the broad-phase and all contacts will be destroyed. + Fixtures on an inactive body are implicitly inactive and will + not participate in collisions, ray-casts, or queries. + Joints connected to an inactive body are implicitly inactive. + !#zh + 设置刚体的激活状态。一个非激活状态下的刚体是不会被模拟和碰撞的,不管它是否处于睡眠状态下。 + 如果刚体处于激活状态下,所有夹具会被添加到 粗测阶段(broad-phase)。 + 如果刚体处于非激活状态下,所有夹具会被从 粗测阶段(broad-phase)中移除。 + 在非激活状态下的夹具不会参与到碰撞,射线,或者查找中 + 链接到非激活状态下刚体的关节也是非激活的。 */ + active: boolean; + /** + !#en + Gets a local point relative to the body's origin given a world point. + !#zh + 将一个给定的世界坐标系下的点转换为刚体本地坐标系下的点 + @param worldPoint a point in world coordinates. + @param out optional, the receiving point + */ + getLocalPoint(worldPoint: Vec2, out: Vec2): Vec2; + /** + !#en + Get the world coordinates of a point given the local coordinates. + !#zh + 将一个给定的刚体本地坐标系下的点转换为世界坐标系下的点 + @param localPoint a point in local coordinates. + @param out optional, the receiving point + */ + getWorldPoint(localPoint: Vec2, out: Vec2): Vec2; + /** + !#en + Get the world coordinates of a vector given the local coordinates. + !#zh + 将一个给定的世界坐标系下的向量转换为刚体本地坐标系下的向量 + @param localVector a vector in world coordinates. + @param out optional, the receiving vector + */ + getWorldVector(localVector: Vec2, out: Vec2): Vec2; + /** + !#en + Gets a local vector relative to the body's origin given a world vector. + !#zh + 将一个给定的世界坐标系下的点转换为刚体本地坐标系下的点 + @param worldVector a vector in world coordinates. + @param out optional, the receiving vector + */ + getLocalVector(worldVector: Vec2, out: Vec2): Vec2; + /** + !#en + Get the world body origin position. + !#zh + 获取刚体世界坐标系下的原点值 + @param out optional, the receiving point + */ + getWorldPosition(out: Vec2): Vec2; + /** + !#en + Get the world body rotation angle. + !#zh + 获取刚体世界坐标系下的旋转值。 + */ + getWorldRotation(): number; + /** + !#en + Get the local position of the center of mass. + !#zh + 获取刚体本地坐标系下的质心 + */ + getLocalCenter(): Vec2; + /** + !#en + Get the world position of the center of mass. + !#zh + 获取刚体世界坐标系下的质心 + */ + getWorldCenter(): Vec2; + /** + !#en + Get the world linear velocity of a world point attached to this body. + !#zh + 获取刚体上指定点的线性速度 + @param worldPoint a point in world coordinates. + @param out optional, the receiving point + */ + getLinearVelocityFromWorldPoint(worldPoint: Vec2, out: Vec2): Vec2; + /** + !#en + Get total mass of the body. + !#zh + 获取刚体的质量。 + */ + getMass(): number; + /** + !#en + Get the rotational inertia of the body about the local origin. + !#zh + 获取刚体本地坐标系下原点的旋转惯性 + */ + getInertia(): number; + /** + !#en + Get all the joints connect to the rigidbody. + !#zh + 获取链接到此刚体的所有关节 + */ + getJointList(): [Joint]; + /** + !#en + Apply a force at a world point. If the force is not + applied at the center of mass, it will generate a torque and + affect the angular velocity. + !#zh + 施加一个力到刚体上的一个点。如果力没有施加到刚体的质心上,还会产生一个扭矩并且影响到角速度。 + @param force the world force vector. + @param point the world position. + @param wake also wake up the body. + */ + applyForce(force: Vec2, point: Vec2, wake: boolean): void; + /** + !#en + Apply a force to the center of mass. + !#zh + 施加一个力到刚体上的质心上。 + @param force the world force vector. + @param wake also wake up the body. + */ + applyForceToCenter(force: Vec2, wake: boolean): void; + /** + !#en + Apply a torque. This affects the angular velocity. + !#zh + 施加一个扭矩力,将影响刚体的角速度 + @param torque about the z-axis (out of the screen), usually in N-m. + @param wake also wake up the body + */ + applyTorque(torque: number, wake: boolean): void; + /** + !#en + Apply a impulse at a world point, This immediately modifies the velocity. + If the impulse is not applied at the center of mass, it will generate a torque and + affect the angular velocity. + !#zh + 施加冲量到刚体上的一个点,将立即改变刚体的线性速度。 + 如果冲量施加到的点不是刚体的质心,那么将产生一个扭矩并影响刚体的角速度。 + @param impulse the world impulse vector, usually in N-seconds or kg-m/s. + @param point the world position + @param wake alse wake up the body + */ + applyLinearImpulse(impulse: Vec2, point: Vec2, wake: boolean): void; + /** + !#en + Apply an angular impulse. + !#zh + 施加一个角速度冲量。 + @param impulse the angular impulse in units of kg*m*m/s + @param wake also wake up the body + */ + applyAngularImpulse(impulse: number, wake: boolean): void; + /** + !#en + Synchronize node's world position to box2d rigidbody's position. + If enableAnimated is true and rigidbody's type is Animated type, + will set linear velocity instead of directly set rigidbody's position. + !#zh + 同步节点的世界坐标到 box2d 刚体的坐标上。 + 如果 enableAnimated 是 true,并且刚体的类型是 Animated ,那么将设置刚体的线性速度来代替直接设置刚体的位置。 + @param enableAnimated enableAnimated + */ + syncPosition(enableAnimated: boolean): void; + /** + !#en + Synchronize node's world angle to box2d rigidbody's angle. + If enableAnimated is true and rigidbody's type is Animated type, + will set angular velocity instead of directly set rigidbody's angle. + !#zh + 同步节点的世界旋转角度值到 box2d 刚体的旋转值上。 + 如果 enableAnimated 是 true,并且刚体的类型是 Animated ,那么将设置刚体的角速度来代替直接设置刚体的角度。 + @param enableAnimated enableAnimated + */ + syncRotation(enableAnimated: boolean): void; + } + /** !#en Key map for keyboard event + !#zh 键盘事件的按键值 */ + export enum KEY { + none = 0, + back = 0, + menu = 0, + backspace = 0, + tab = 0, + enter = 0, + shift = 0, + ctrl = 0, + alt = 0, + pause = 0, + capslock = 0, + escape = 0, + space = 0, + pageup = 0, + pagedown = 0, + end = 0, + home = 0, + left = 0, + up = 0, + right = 0, + down = 0, + select = 0, + insert = 0, + Delete = 0, + a = 0, + b = 0, + c = 0, + d = 0, + e = 0, + f = 0, + g = 0, + h = 0, + i = 0, + j = 0, + k = 0, + l = 0, + m = 0, + n = 0, + o = 0, + p = 0, + q = 0, + r = 0, + s = 0, + t = 0, + u = 0, + v = 0, + w = 0, + x = 0, + y = 0, + z = 0, + num0 = 0, + num1 = 0, + num2 = 0, + num3 = 0, + num4 = 0, + num5 = 0, + num6 = 0, + num7 = 0, + num8 = 0, + num9 = 0, + '*' = 0, + '+' = 0, + '-' = 0, + numdel = 0, + '/' = 0, + f1 = 0, + f2 = 0, + f3 = 0, + f4 = 0, + f5 = 0, + f6 = 0, + f7 = 0, + f8 = 0, + f9 = 0, + f10 = 0, + f11 = 0, + f12 = 0, + numlock = 0, + scrolllock = 0, + ';' = 0, + semicolon = 0, + equal = 0, + '=' = 0, + ',' = 0, + comma = 0, + dash = 0, + '.' = 0, + period = 0, + forwardslash = 0, + grave = 0, + '[' = 0, + openbracket = 0, + backslash = 0, + ']' = 0, + closebracket = 0, + quote = 0, + dpadLeft = 0, + dpadRight = 0, + dpadUp = 0, + dpadDown = 0, + dpadCenter = 0, + } + /** Image formats */ + export enum ImageFormat { + JPG = 0, + PNG = 0, + TIFF = 0, + WEBP = 0, + PVR = 0, + ETC = 0, + S3TC = 0, + ATITC = 0, + TGA = 0, + RAWDATA = 0, + UNKNOWN = 0, + getImageFormatByData = 0, + } + /** Predefined constants */ + export enum macro { + INVALID_INDEX = 0, + NODE_TAG_INVALID = 0, + PI = 0, + PI2 = 0, + FLT_MAX = 0, + FLT_MIN = 0, + RAD = 0, + DEG = 0, + UINT_MAX = 0, + REPEAT_FOREVER = 0, + FLT_EPSILON = 0, + ONE = 0, + ZERO = 0, + SRC_ALPHA = 0, + SRC_ALPHA_SATURATE = 0, + SRC_COLOR = 0, + DST_ALPHA = 0, + DST_COLOR = 0, + ONE_MINUS_SRC_ALPHA = 0, + ONE_MINUS_SRC_COLOR = 0, + ONE_MINUS_DST_ALPHA = 0, + ONE_MINUS_DST_COLOR = 0, + ONE_MINUS_CONSTANT_ALPHA = 0, + ONE_MINUS_CONSTANT_COLOR = 0, + LINEAR = 0, + BLEND_DST = 0, + WEB_ORIENTATION_PORTRAIT = 0, + WEB_ORIENTATION_LANDSCAPE_LEFT = 0, + WEB_ORIENTATION_PORTRAIT_UPSIDE_DOWN = 0, + WEB_ORIENTATION_LANDSCAPE_RIGHT = 0, + ORIENTATION_PORTRAIT = 0, + ORIENTATION_LANDSCAPE = 0, + ORIENTATION_AUTO = 0, + VERTEX_ATTRIB_FLAG_NONE = 0, + VERTEX_ATTRIB_FLAG_POSITION = 0, + VERTEX_ATTRIB_FLAG_COLOR = 0, + VERTEX_ATTRIB_FLAG_TEX_COORDS = 0, + VERTEX_ATTRIB_FLAG_POS_COLOR_TEX = 0, + GL_ALL = 0, + VERTEX_ATTRIB_POSITION = 0, + VERTEX_ATTRIB_COLOR = 0, + VERTEX_ATTRIB_TEX_COORDS = 0, + VERTEX_ATTRIB_MAX = 0, + UNIFORM_PMATRIX = 0, + UNIFORM_MVMATRIX = 0, + UNIFORM_MVPMATRIX = 0, + UNIFORM_TIME = 0, + UNIFORM_SINTIME = 0, + UNIFORM_COSTIME = 0, + UNIFORM_RANDOM01 = 0, + UNIFORM_SAMPLER = 0, + UNIFORM_MAX = 0, + SHADER_POSITION_TEXTURECOLOR = 0, + SHADER_SPRITE_POSITION_TEXTURECOLOR = 0, + SHADER_POSITION_TEXTURECOLORALPHATEST = 0, + SHADER_SPRITE_POSITION_TEXTURECOLORALPHATEST = 0, + SHADER_POSITION_COLOR = 0, + SHADER_SPRITE_POSITION_COLOR = 0, + SHADER_POSITION_TEXTURE = 0, + SHADER_POSITION_TEXTURE_UCOLOR = 0, + SHADER_POSITION_TEXTUREA8COLOR = 0, + SHADER_POSITION_UCOLOR = 0, + SHADER_POSITION_LENGTHTEXTURECOLOR = 0, + UNIFORM_PMATRIX_S = 0, + UNIFORM_MVMATRIX_S = 0, + UNIFORM_MVPMATRIX_S = 0, + UNIFORM_TIME_S = 0, + UNIFORM_SINTIME_S = 0, + UNIFORM_COSTIME_S = 0, + UNIFORM_RANDOM01_S = 0, + UNIFORM_SAMPLER_S = 0, + UNIFORM_ALPHA_TEST_VALUE_S = 0, + ATTRIBUTE_NAME_COLOR = 0, + ATTRIBUTE_NAME_POSITION = 0, + ATTRIBUTE_NAME_TEX_COORD = 0, + ITEM_SIZE = 0, + CURRENT_ITEM = 0, + ZOOM_ACTION_TAG = 0, + NORMAL_TAG = 0, + SELECTED_TAG = 0, + DISABLE_TAG = 0, + FIX_ARTIFACTS_BY_STRECHING_TEXEL = 0, + FIX_ARTIFACTS_BY_STRECHING_TEXEL_TMX = 0, + DIRECTOR_STATS_POSITION = 0, + DIRECTOR_FPS_INTERVAL = 0, + COCOSNODE_RENDER_SUBPIXEL = 0, + SPRITEBATCHNODE_RENDER_SUBPIXEL = 0, + AUTO_PREMULTIPLIED_ALPHA_FOR_PNG = 0, + OPTIMIZE_BLEND_FUNC_FOR_PREMULTIPLIED_ALPHA = 0, + TEXTURE_NPOT_SUPPORT = 0, + USE_LA88_LABELS = 0, + SPRITE_DEBUG_DRAW = 0, + LABELBMFONT_DEBUG_DRAW = 0, + LABELATLAS_DEBUG_DRAW = 0, + ENABLE_STACKABLE_ACTIONS = 0, + ENABLE_GL_STATE_CACHE = 0, + TOUCH_TIMEOUT = 0, + BATCH_VERTEX_COUNT = 0, + ENABLE_GC_FOR_NATIVE_OBJECTS = 0, + ENABLE_TILEDMAP_CULLING = 0, + DOWNLOAD_MAX_CONCURRENT = 0, + ENABLE_TRANSPARENT_CANVAS = 0, + ENABLE_CULLING = 0, + BLEND_SRC = 0, + } + /** The base class of most of all the objects in Fireball. */ + export class Object { + /** !#en The name of the object. + !#zh 该对象的名称。 */ + name: string; + /** !#en Indicates whether the object is not yet destroyed. + !#zh 表示该对象是否可用(被销毁后将不可用)。 */ + isValid: boolean; + /** + !#en + Destroy this Object, and release all its own references to other objects.
+ Actual object destruction will delayed until before rendering. +
+ After destroy, this CCObject is not usable any more. + You can use cc.isValid(obj) to check whether the object is destroyed before accessing it. + !#zh + 销毁该对象,并释放所有它对其它对象的引用。
+ 销毁后,CCObject 不再可用。您可以在访问对象之前使用 cc.isValid(obj) 来检查对象是否已被销毁。 + 实际销毁操作会延迟到当前帧渲染前执行。 + + @example + ```js + obj.destroy(); + ``` + */ + destroy(): boolean; + } + /** Bit mask that controls object states. */ + export enum Flags { + DontSave = 0, + EditorOnly = 0, + } + /** The fullscreen API provides an easy way for web content to be presented using the user's entire screen. + It's invalid on safari, QQbrowser and android browser */ + export class screen { + /** + initialize + */ + init(): void; + /** + return true if it's full now. + */ + fullScreen(): boolean; + /** + change the screen to full mode. + @param element element + @param onFullScreenChange onFullScreenChange + */ + requestFullScreen(element: Element, onFullScreenChange: Function): void; + /** + exit the full mode. + */ + exitFullScreen(): boolean; + /** + Automatically request full screen with a touch/click event + @param element element + @param onFullScreenChange onFullScreenChange + */ + autoFullScreen(element: Element, onFullScreenChange: Function): void; + } + /** System variables */ + export class sys { + /** English language code */ + static LANGUAGE_ENGLISH: string; + /** Chinese language code */ + static LANGUAGE_CHINESE: string; + /** French language code */ + static LANGUAGE_FRENCH: string; + /** Italian language code */ + static LANGUAGE_ITALIAN: string; + /** German language code */ + static LANGUAGE_GERMAN: string; + /** Spanish language code */ + static LANGUAGE_SPANISH: string; + /** Spanish language code */ + static LANGUAGE_DUTCH: string; + /** Russian language code */ + static LANGUAGE_RUSSIAN: string; + /** Korean language code */ + static LANGUAGE_KOREAN: string; + /** Japanese language code */ + static LANGUAGE_JAPANESE: string; + /** Hungarian language code */ + static LANGUAGE_HUNGARIAN: string; + /** Portuguese language code */ + static LANGUAGE_PORTUGUESE: string; + /** Arabic language code */ + static LANGUAGE_ARABIC: string; + /** Norwegian language code */ + static LANGUAGE_NORWEGIAN: string; + /** Polish language code */ + static LANGUAGE_POLISH: string; + /** Turkish language code */ + static LANGUAGE_TURKISH: string; + /** Ukrainian language code */ + static LANGUAGE_UKRAINIAN: string; + /** Romanian language code */ + static LANGUAGE_ROMANIAN: string; + /** Bulgarian language code */ + static LANGUAGE_BULGARIAN: string; + /** Unknown language code */ + static LANGUAGE_UNKNOWN: string; + static OS_IOS: string; + static OS_ANDROID: string; + static OS_WINDOWS: string; + static OS_MARMALADE: string; + static OS_LINUX: string; + static OS_BADA: string; + static OS_BLACKBERRY: string; + static OS_OSX: string; + static OS_WP8: string; + static OS_WINRT: string; + static OS_UNKNOWN: string; + static UNKNOWN: number; + static WIN32: number; + static LINUX: number; + static MACOS: number; + static ANDROID: number; + static IPHONE: number; + static IPAD: number; + static BLACKBERRY: number; + static NACL: number; + static EMSCRIPTEN: number; + static TIZEN: number; + static WINRT: number; + static WP8: number; + static MOBILE_BROWSER: number; + static DESKTOP_BROWSER: number; + /** Indicates whether executes in editor's window process (Electron's renderer context) */ + static EDITOR_PAGE: number; + /** Indicates whether executes in editor's main process (Electron's browser context) */ + static EDITOR_CORE: number; + static WECHAT_GAME: number; + /** BROWSER_TYPE_WECHAT */ + static BROWSER_TYPE_WECHAT: string; + /** BROWSER_TYPE_WECHAT_GAME */ + static BROWSER_TYPE_WECHAT_GAME: string; + static BROWSER_TYPE_ANDROID: string; + static BROWSER_TYPE_IE: string; + static BROWSER_TYPE_QQ: string; + static BROWSER_TYPE_MOBILE_QQ: string; + static BROWSER_TYPE_UC: string; + static BROWSER_TYPE_360: string; + static BROWSER_TYPE_BAIDU_APP: string; + static BROWSER_TYPE_BAIDU: string; + static BROWSER_TYPE_MAXTHON: string; + static BROWSER_TYPE_OPERA: string; + static BROWSER_TYPE_OUPENG: string; + static BROWSER_TYPE_MIUI: string; + static BROWSER_TYPE_FIREFOX: string; + static BROWSER_TYPE_SAFARI: string; + static BROWSER_TYPE_CHROME: string; + static BROWSER_TYPE_LIEBAO: string; + static BROWSER_TYPE_QZONE: string; + static BROWSER_TYPE_SOUGOU: string; + static BROWSER_TYPE_UNKNOWN: string; + /** Is native ? This is set to be true in jsb auto. */ + static isNative: boolean; + /** Is web browser ? */ + static isBrowser: boolean; + /** Indicate whether system is mobile system */ + static isMobile: boolean; + /** Indicate the running platform */ + static platform: number; + /** Indicate the current language of the running system */ + static language: string; + /** Indicate the running os name */ + static os: string; + /** Indicate the running os version */ + static osVersion: string; + /** Indicate the running os main version */ + static osMainVersion: number; + /** Indicate the running browser type */ + static browserType: string; + /** Indicate the running browser version */ + static browserVersion: string; + /** Indicate the real pixel resolution of the whole game window */ + static windowPixelResolution: Size; + /** cc.sys.localStorage is a local storage component. */ + static localStorage: any; + /** The capabilities of the current platform */ + static capabilities: any; + /** + Forces the garbage collection, only available in JSB + */ + static garbageCollect(): void; + /** + Dumps rooted objects, only available in JSB + */ + static dumpRoot(): void; + /** + Restart the JS VM, only available in JSB + */ + static restartVM(): void; + /** + Clean a script in the JS VM, only available in JSB + @param jsfile jsfile + */ + static cleanScript(jsfile: string): void; + /** + Check whether an object is valid, + In web engine, it will return true if the object exist + In native engine, it will return true if the JS object and the correspond native object are both valid + @param obj obj + */ + static isObjectValid(obj: any): boolean; + /** + Dump system informations + */ + static dump(): void; + /** + Open a url in browser + @param url url + */ + static openURL(url: string): void; + /** + Get the number of milliseconds elapsed since 1 January 1970 00:00:00 UTC. + */ + static now(): number; + } + /** cc.view is the singleton object which represents the game window.
+ It's main task include:
+ - Apply the design resolution policy
+ - Provide interaction with the window, like resize event on web, retina display support, etc...
+ - Manage the game view port which can be different with the window
+ - Manage the content scale and translation
+
+ Since the cc.view is a singleton, you don't need to call any constructor or create functions,
+ the standard way to use it is by calling:
+ - cc.view.methodName();
*/ + export class View { + /** +

+ Sets view's target-densitydpi for android mobile browser. it can be set to:
+ 1. cc.macro.DENSITYDPI_DEVICE, value is "device-dpi"
+ 2. cc.macro.DENSITYDPI_HIGH, value is "high-dpi" (default value)
+ 3. cc.macro.DENSITYDPI_MEDIUM, value is "medium-dpi" (browser's default value)
+ 4. cc.macro.DENSITYDPI_LOW, value is "low-dpi"
+ 5. Custom value, e.g: "480"
+

+ @param densityDPI densityDPI + */ + setTargetDensityDPI(densityDPI: string): void; + /** + Returns the current target-densitydpi value of cc.view. + */ + getTargetDensityDPI(): string; + /** + Sets whether resize canvas automatically when browser's size changed.
+ Useful only on web. + @param enabled Whether enable automatic resize with browser's resize event + */ + resizeWithBrowserSize(enabled: boolean): void; + /** + Sets the callback function for cc.view's resize action,
+ this callback will be invoked before applying resolution policy,
+ so you can do any additional modifications within the callback.
+ Useful only on web. + @param callback The callback function + */ + setResizeCallback(callback: Function|void): void; + /** + Sets the orientation of the game, it can be landscape, portrait or auto. + When set it to landscape or portrait, and screen w/h ratio doesn't fit, + cc.view will automatically rotate the game canvas using CSS. + Note that this function doesn't have any effect in native, + in native, you need to set the application orientation in native project settings + @param orientation Possible values: cc.macro.ORIENTATION_LANDSCAPE | cc.macro.ORIENTATION_PORTRAIT | cc.macro.ORIENTATION_AUTO + */ + setOrientation(orientation: number): void; + /** + Sets whether the engine modify the "viewport" meta in your web page.
+ It's enabled by default, we strongly suggest you not to disable it.
+ And even when it's enabled, you can still set your own "viewport" meta, it won't be overridden
+ Only useful on web + @param enabled Enable automatic modification to "viewport" meta + */ + adjustViewPort(enabled: boolean): void; + /** + Retina support is enabled by default for Apple device but disabled for other devices,
+ it takes effect only when you called setDesignResolutionPolicy
+ Only useful on web + @param enabled Enable or disable retina display + */ + enableRetina(enabled: boolean): void; + /** + Check whether retina display is enabled.
+ Only useful on web + */ + isRetinaEnabled(): boolean; + /** + !#en Whether to Enable on anti-alias + !#zh 控制抗锯齿是否开启 + @param enabled Enable or not anti-alias + */ + enableAntiAlias(enabled: boolean): void; + /** + !#en Returns whether the current enable on anti-alias + !#zh 返回当前是否抗锯齿 + */ + isAntiAliasEnabled(): boolean; + /** + If enabled, the application will try automatically to enter full screen mode on mobile devices
+ You can pass true as parameter to enable it and disable it by passing false.
+ Only useful on web + @param enabled Enable or disable auto full screen on mobile devices + */ + enableAutoFullScreen(enabled: boolean): void; + /** + Check whether auto full screen is enabled.
+ Only useful on web + */ + isAutoFullScreenEnabled(): boolean; + /** + Get whether render system is ready(no matter opengl or canvas),
+ this name is for the compatibility with cocos2d-x, subclass must implement this method. + */ + isViewReady(): boolean; + /** + Sets the resolution translate on View. + @param offsetLeft offsetLeft + @param offsetTop offsetTop + */ + setContentTranslateLeftTop(offsetLeft: number, offsetTop: number): void; + /** + Returns the resolution translate on View + */ + getContentTranslateLeftTop(): Size; + /** + Returns the frame size of the view.
+ On native platforms, it returns the screen size since the view is a fullscreen view.
+ On web, it returns the size of the canvas's outer DOM element. + */ + getFrameSize(): Size; + /** + On native, it sets the frame size of view.
+ On web, it sets the size of the canvas's outer DOM element. + @param width width + @param height height + */ + setFrameSize(width: number, height: number): void; + /** + Returns the visible area size of the view port. + */ + getVisibleSize(): Size; + /** + Returns the visible area size of the view port. + */ + getVisibleSizeInPixel(): Size; + /** + Returns the visible origin of the view port. + */ + getVisibleOrigin(): Vec2; + /** + Returns the visible origin of the view port. + */ + getVisibleOriginInPixel(): Vec2; + /** + Returns whether developer can set content's scale factor. + */ + canSetContentScaleFactor(): boolean; + /** + Returns the current resolution policy + */ + getResolutionPolicy(): ResolutionPolicy; + /** + Sets the current resolution policy + @param resolutionPolicy resolutionPolicy + */ + setResolutionPolicy(resolutionPolicy: ResolutionPolicy|number): void; + /** + Sets the resolution policy with designed view size in points.
+ The resolution policy include:
+ [1] ResolutionExactFit Fill screen by stretch-to-fit: if the design resolution ratio of width to height is different from the screen resolution ratio, your game view will be stretched.
+ [2] ResolutionNoBorder Full screen without black border: if the design resolution ratio of width to height is different from the screen resolution ratio, two areas of your game view will be cut.
+ [3] ResolutionShowAll Full screen with black border: if the design resolution ratio of width to height is different from the screen resolution ratio, two black borders will be shown.
+ [4] ResolutionFixedHeight Scale the content's height to screen's height and proportionally scale its width
+ [5] ResolutionFixedWidth Scale the content's width to screen's width and proportionally scale its height
+ [cc.ResolutionPolicy] [Web only feature] Custom resolution policy, constructed by cc.ResolutionPolicy
+ @param width Design resolution width. + @param height Design resolution height. + @param resolutionPolicy The resolution policy desired + */ + setDesignResolutionSize(width: number, height: number, resolutionPolicy: ResolutionPolicy|number): void; + /** + Returns the designed size for the view. + Default resolution size is the same as 'getFrameSize'. + */ + getDesignResolutionSize(): Size; + /** + Sets the container to desired pixel resolution and fit the game content to it. + This function is very useful for adaptation in mobile browsers. + In some HD android devices, the resolution is very high, but its browser performance may not be very good. + In this case, enabling retina display is very costy and not suggested, and if retina is disabled, the image may be blurry. + But this API can be helpful to set a desired pixel resolution which is in between. + This API will do the following: + 1. Set viewport's width to the desired width in pixel + 2. Set body width to the exact pixel resolution + 3. The resolution policy will be reset with designed view size in points. + @param width Design resolution width. + @param height Design resolution height. + @param resolutionPolicy The resolution policy desired + */ + setRealPixelResolution(width: number, height: number, resolutionPolicy: ResolutionPolicy|number): void; + /** + Sets view port rectangle with points. + @param x x + @param y y + @param w width + @param h height + */ + setViewPortInPoints(x: number, y: number, w: number, h: number): void; + /** + Sets Scissor rectangle with points. + @param x x + @param y y + @param w w + @param h h + */ + setScissorInPoints(x: number, y: number, w: number, h: number): void; + /** + Returns whether GL_SCISSOR_TEST is enable + */ + isScissorEnabled(): boolean; + /** + Returns the current scissor rectangle + */ + getScissorRect(): Rect; + /** + Sets the name of the view + @param viewName viewName + */ + setViewName(viewName: string): void; + /** + Returns the name of the view + */ + getViewName(): string; + /** + Returns the view port rectangle. + */ + getViewPortRect(): Rect; + /** + Returns scale factor of the horizontal direction (X axis). + */ + getScaleX(): number; + /** + Returns scale factor of the vertical direction (Y axis). + */ + getScaleY(): number; + /** + Returns device pixel ratio for retina display. + */ + getDevicePixelRatio(): number; + /** + Returns the real location in view for a translation based on a related position + @param tx The X axis translation + @param ty The Y axis translation + @param relatedPos The related position object including "left", "top", "width", "height" informations + */ + convertToLocationInView(tx: number, ty: number, relatedPos: any): Vec2; + } + /**

cc.ContainerStrategy class is the root strategy class of container's scale strategy, + it controls the behavior of how to scale the cc.container and cc.game.canvas object

*/ + export class ContainerStrategy { + /** + Manipulation before appling the strategy + @param view The target view + */ + preApply(view: View): void; + /** + Function to apply this strategy + @param view view + @param designedResolution designedResolution + */ + apply(view: View, designedResolution: Size): void; + /** + Manipulation after applying the strategy + @param view The target view + */ + postApply(view: View): void; + } + /**

cc.ContentStrategy class is the root strategy class of content's scale strategy, + it controls the behavior of how to scale the scene and setup the viewport for the game

*/ + export class ContentStrategy { + /** + Manipulation before applying the strategy + @param view The target view + */ + preApply(view: View): void; + /** + Function to apply this strategy + The return value is {scale: [scaleX, scaleY], viewport: {cc.Rect}}, + The target view can then apply these value to itself, it's preferred not to modify directly its private variables + @param view view + @param designedResolution designedResolution + */ + apply(view: View, designedResolution: Size): any; + /** + Manipulation after applying the strategy + @param view The target view + */ + postApply(view: View): void; + } + /** undefined */ + export class EqualToFrame extends ContainerStrategy { + } + /** undefined */ + export class ProportionalToFrame extends ContainerStrategy { + } + /** undefined */ + export class EqualToWindow extends EqualToFrame { + } + /** undefined */ + export class ProportionalToWindow extends ProportionalToFrame { + } + /** undefined */ + export class OriginalContainer extends ContainerStrategy { + } + /**

cc.ResolutionPolicy class is the root strategy class of scale strategy, + its main task is to maintain the compatibility with Cocos2d-x

*/ + export class ResolutionPolicy { + /** + + @param containerStg The container strategy + @param contentStg The content strategy + */ + constructor(containerStg: ContainerStrategy, contentStg: ContentStrategy); + /** + Manipulation before applying the resolution policy + @param view The target view + */ + preApply(view: View): void; + /** + Function to apply this resolution policy + The return value is {scale: [scaleX, scaleY], viewport: {cc.Rect}}, + The target view can then apply these value to itself, it's preferred not to modify directly its private variables + @param view The target view + @param designedResolution The user defined design resolution + */ + apply(view: View, designedResolution: Size): any; + /** + Manipulation after appyling the strategy + @param view The target view + */ + postApply(view: View): void; + /** + Setup the container's scale strategy + @param containerStg containerStg + */ + setContainerStrategy(containerStg: ContainerStrategy): void; + /** + Setup the content's scale strategy + @param contentStg contentStg + */ + setContentStrategy(contentStg: ContentStrategy): void; + /** The entire application is visible in the specified area without trying to preserve the original aspect ratio.
+ Distortion can occur, and the application may appear stretched or compressed. */ + static EXACT_FIT: number; + /** The entire application fills the specified area, without distortion but possibly with some cropping,
+ while maintaining the original aspect ratio of the application. */ + static NO_BORDER: number; + /** The entire application is visible in the specified area without distortion while maintaining the original
+ aspect ratio of the application. Borders can appear on two sides of the application. */ + static SHOW_ALL: number; + /** The application takes the height of the design resolution size and modifies the width of the internal
+ canvas so that it fits the aspect ratio of the device
+ no distortion will occur however you must make sure your application works on different
+ aspect ratios */ + static FIXED_HEIGHT: number; + /** The application takes the width of the design resolution size and modifies the height of the internal
+ canvas so that it fits the aspect ratio of the device
+ no distortion will occur however you must make sure your application works on different
+ aspect ratios */ + static FIXED_WIDTH: number; + /** Unknow policy */ + static UNKNOWN: number; + } + /** cc.visibleRect is a singleton object which defines the actual visible rect of the current view, + it should represent the same rect as cc.view.getViewportRect() */ + export class visibleRect { + /** + initialize + @param visibleRect visibleRect + */ + init(visibleRect: Rect): void; + /** Top left coordinate of the screen related to the game scene. */ + topLeft: Vec2; + /** Top right coordinate of the screen related to the game scene. */ + topRight: Vec2; + /** Top center coordinate of the screen related to the game scene. */ + top: Vec2; + /** Bottom left coordinate of the screen related to the game scene. */ + bottomLeft: Vec2; + /** Bottom right coordinate of the screen related to the game scene. */ + bottomRight: Vec2; + /** Bottom center coordinate of the screen related to the game scene. */ + bottom: Vec2; + /** Center coordinate of the screen related to the game scene. */ + center: Vec2; + /** Left center coordinate of the screen related to the game scene. */ + left: Vec2; + /** Right center coordinate of the screen related to the game scene. */ + right: Vec2; + /** Width of the screen. */ + width: number; + /** Height of the screen. */ + height: number; + } + /** The CallbacksHandler is an abstract class that can register and unregister callbacks by key. + Subclasses should implement their own methods about how to invoke the callbacks. */ + export class _CallbacksHandler { + /** + + @param key key + @param callback callback + @param target can be null + */ + add(key: string, callback: Function, target?: any): void; + /** + Check if the specified key has any registered callback. If a callback is also specified, + it will only return true if the callback is registered. + @param key key + @param callback callback + @param target target + */ + has(key: string, callback?: Function, target?: any): boolean; + /** + Removes all callbacks registered in a certain event type or all callbacks registered with a certain target + @param keyOrTarget The event key to be removed or the target to be removed + */ + removeAll(keyOrTarget: string|any): void; + /** + + @param key key + @param callback callback + @param target target + */ + remove(key: string, callback: Function, target?: any): void; + } + /** !#en The callbacks invoker to handle and invoke callbacks by key. + !#zh CallbacksInvoker 用来根据 Key 管理并调用回调方法。 */ + export class CallbacksInvoker extends _CallbacksHandler { + /** + + @param key key + @param p1 p1 + @param p2 p2 + @param p3 p3 + @param p4 p4 + @param p5 p5 + */ + invoke(key: string, p1?: any, p2?: any, p3?: any, p4?: any, p5?: any): void; + } + /** !#en Contains information collected during deserialization + !#zh 包含反序列化时的一些信息 */ + export class Details { + /** list of the depends assets' uuid */ + uuidList: string[]; + /** the obj list whose field needs to load asset by uuid */ + uuidObjList: any[]; + /** the corresponding field name which referenced to the asset */ + uuidPropList: string[]; + /** the corresponding field name which referenced to the raw object */ + rawProp: string; + reset(): void; + /** + + @param obj obj + @param propName propName + */ + getUuidOf(obj: any, propName: string): string; + /** + + @param obj obj + @param propName propName + @param uuid uuid + */ + push(obj: any, propName: string, uuid: string): void; + } + /** undefined */ + export class url { + /** + Returns the url of raw assets, you will only need this if the raw asset is inside the "resources" folder. + @param url url + + @example + ```js + --- + var url = cc.url.raw("textures/myTexture.png"); + console.log(url); // "resources/raw/textures/myTexture.png" + + ``` + */ + static raw(url: string): string; + /** + Returns the url of builtin raw assets. This method can only used in editor. + @param url url + + @example + ```js + --- + var url = cc.url.builtinRaw("textures/myTexture.png"); + console.log(url); // "resources/default-raw/textures/myTexture.png" + + ``` + */ + static builtinRaw(url: string): string; + } + /** !#en + A cc.SpriteFrame has:
+ - texture: A cc.Texture2D that will be used by the _ccsg.Sprite
+ - rectangle: A rectangle of the texture + + !#zh + 一个 SpriteFrame 包含:
+ - 纹理:会被 Sprite 使用的 Texture2D 对象。
+ - 矩形:在纹理中的矩形区域。 */ + export class SpriteFrame extends Asset implements EventTarget { + /** + !#en + Constructor of SpriteFrame class. + !#zh + SpriteFrame 类的构造函数。 + @param filename filename + @param rect rect + @param rotated Whether the frame is rotated in the texture + @param offset The offset of the frame in the texture + @param originalSize The size of the frame in the texture + */ + constructor(filename?: string|Texture2D, rect?: Rect, rotated?: boolean, offset?: Vec2, originalSize?: Size); + /** !#en Top border of the sprite + !#zh sprite 的顶部边框 */ + insetTop: number; + /** !#en Bottom border of the sprite + !#zh sprite 的底部边框 */ + insetBottom: number; + /** !#en Left border of the sprite + !#zh sprite 的左边边框 */ + insetLeft: number; + /** !#en Right border of the sprite + !#zh sprite 的左边边框 */ + insetRight: number; + /** + !#en Returns whether the texture have been loaded + !#zh 返回是否已加载纹理 + */ + textureLoaded(): boolean; + /** + Add a event listener for texture loaded event. + @param callback callback + @param target target + */ + addLoadedEventListener(callback: Function, target: any): void; + /** + !#en Returns whether the sprite frame is rotated in the texture. + !#zh 获取 SpriteFrame 是否旋转 + */ + isRotated(): boolean; + /** + !#en Set whether the sprite frame is rotated in the texture. + !#zh 设置 SpriteFrame 是否旋转 + @param bRotated bRotated + */ + setRotated(bRotated: boolean): void; + /** + !#en Returns the rect of the sprite frame in the texture. + !#zh 获取 SpriteFrame 的纹理矩形区域 + */ + getRect(): Rect; + /** + !#en Sets the rect of the sprite frame in the texture. + !#zh 设置 SpriteFrame 的纹理矩形区域 + @param rect rect + */ + setRect(rect: Rect): void; + /** + !#en Returns the original size of the trimmed image. + !#zh 获取修剪前的原始大小 + */ + getOriginalSize(): Size; + /** + !#en Sets the original size of the trimmed image. + !#zh 设置修剪前的原始大小 + @param size size + */ + setOriginalSize(size: Size): void; + /** + !#en Returns the texture of the frame. + !#zh 获取使用的纹理实例 + */ + getTexture(): Texture2D; + /** + !#en Returns the offset of the frame in the texture. + !#zh 获取偏移量 + */ + getOffset(): Vec2; + /** + !#en Sets the offset of the frame in the texture. + !#zh 设置偏移量 + @param offsets offsets + */ + setOffset(offsets: Vec2): void; + /** + !#en Clone the sprite frame. + !#zh 克隆 SpriteFrame + */ + clone(): SpriteFrame; + /** + #en Set SpriteFrame with Texture, rect, rotated, offset and originalSize.
+ #zh 通过 Texture,rect,rotated,offset 和 originalSize 设置 SpriteFrame + @param textureOrTextureFile textureOrTextureFile + @param rect rect + @param rotated rotated + @param offset offset + @param originalSize originalSize + */ + setTexture(textureOrTextureFile: string|Texture2D, rect?: Rect, rotated?: boolean, offset?: Vec2, originalSize?: Size): boolean; + /** + !#en If a loading scene (or prefab) is marked as `asyncLoadAssets`, all the textures of the SpriteFrame which + associated by user's custom Components in the scene, will not preload automatically. + These textures will be load when Sprite component is going to render the SpriteFrames. + You can call this method if you want to load the texture early. + !#zh 当加载中的场景或 Prefab 被标记为 `asyncLoadAssets` 时,用户在场景中由自定义组件关联到的所有 SpriteFrame 的贴图都不会被提前加载。 + 只有当 Sprite 组件要渲染这些 SpriteFrame 时,才会检查贴图是否加载。如果你希望加载过程提前,你可以手工调用这个方法。 + + @example + ```js + if (spriteFrame.textureLoaded()) { + this._onSpriteFrameLoaded(); + } + else { + spriteFrame.once('load', this._onSpriteFrameLoaded, this); + spriteFrame.ensureLoadTexture(); + } + ``` + */ + ensureLoadTexture(): void; + /** + !#en + If you do not need to use the SpriteFrame temporarily, you can call this method so that its texture could be garbage collected. Then when you need to render the SpriteFrame, you should call `ensureLoadTexture` manually to reload texture. + !#zh + 当你暂时不再使用这个 SpriteFrame 时,可以调用这个方法来保证引用的贴图对象能被 GC。然后当你要渲染 SpriteFrame 时,你需要手动调用 `ensureLoadTexture` 来重新加载贴图。 + + @example + ```js + spriteFrame.clearTexture(); + // when you need the SpriteFrame again... + spriteFrame.once('load', onSpriteFrameLoaded); + spriteFrame.ensureLoadTexture(); + ``` + */ + clearTexture(): void; + /** + !#en + Register an callback of a specific event type on the EventTarget. + !#zh + 注册事件目标的特定事件类型回调。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + on(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + on(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Removes the listeners previously registered with the same type, callback, target and or useCapture, + if only type is passed as parameter, all listeners registered with that type will be removed. + !#zh + 删除之前用同类型,回调,目标或 useCapture 注册的事件监听器,如果只传递 type,将会删除 type 类型的所有事件监听器。 + @param type A string representing the event type being removed. + @param callback The callback to remove. + @param target The target (this object) to invoke the callback, if it's not given, only callback without target will be removed + @param useCapture Specifies whether the callback being removed was registered as a capturing callback or not. + If not specified, useCapture defaults to false. If a callback was registered twice, + one with capture and one without, each must be removed separately. Removal of a capturing callback + does not affect a non-capturing version of the same listener, and vice versa. + + @example + ```js + // register touchEnd eventListener + var touchEnd = node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + // remove touch end event listener + node.off(cc.Node.EventType.TOUCH_END, touchEnd, node); + // remove all touch end event listeners + node.off(cc.Node.EventType.TOUCH_END); + ``` + */ + off(type: string, callback?: Function, target?: any, useCapture?: boolean): void; + /** + !#en Removes all callbacks previously registered with the same target (passed as parameter). + This is not for removing all listeners in the current event target, + and this is not for removing all listeners the target parameter have registered. + It's only for removing all listeners (callback and target couple) registered on the current event target by the target parameter. + !#zh 在当前 EventTarget 上删除指定目标(target 参数)注册的所有事件监听器。 + 这个函数无法删除当前 EventTarget 的所有事件监听器,也无法删除 target 参数所注册的所有事件监听器。 + 这个函数只能删除 target 参数在当前 EventTarget 上注册的所有事件监听器。 + @param target The target to be searched for all related listeners + */ + targetOff(target: any): void; + /** + !#en + Register an callback of a specific event type on the EventTarget, + the callback will remove itself after the first time it is triggered. + !#zh + 注册事件目标的特定事件类型回调,回调会在第一时间被触发后删除自身。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.once(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + once(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + once(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Dispatches an event into the event flow. + The event target is the EventTarget object upon which the dispatchEvent() method is called. + !#zh 分发事件到事件流中。 + @param event The Event object that is dispatched into the event flow + */ + dispatchEvent(event: Event): void; + /** + !#en + Send an event to this object directly, this method will not propagate the event to any other objects. + The event will be created from the supplied message, you can get the "detail" argument from event.detail. + !#zh + 该对象直接发送事件, 这种方法不会对事件传播到任何其他对象。 + @param message the message to send + @param detail whatever argument the message needs + */ + emit(message: string, detail?: any): void; + } + /**

+ This class allows to easily create OpenGL or Canvas 2D textures from images, text or raw data.
+ The created cc.Texture2D object will always have power-of-two dimensions.
+ Depending on how you create the cc.Texture2D object, the actual image area of the texture might be smaller than the texture dimensions
+ i.e. "contentSize" != (pixelsWide, pixelsHigh) and (maxS, maxT) != (1.0, 1.0).
+ Be aware that the content of the generated textures will be upside-down!

*/ + export class Texture2D extends RawAsset implements EventTarget { + /** !#en + The url of the texture, this coule be empty if the texture wasn't created via a file. + !#zh + 贴图文件的 url,当贴图不是由文件创建时值可能为空 */ + url: string; + /** !#en + Whether the texture is loaded or not + !#zh + 贴图是否已经成功加载 */ + loaded: boolean; + /** !#en + Texture width in pixel + !#zh + 贴图像素宽度 */ + width: number; + /** !#en + Texture height in pixel + !#zh + 贴图像素高度 */ + height: number; + /** + Update texture options, not available in Canvas render mode. + image, format, premultiplyAlpha can not be updated in native. + @param options options + */ + update(options: {image: DOMImageElement; mipmap: boolean; format: PixelFormat; minFilter: Filter; magFilter: Filter; wrapS: WrapMode; wrapT: WrapMode; premultiplyAlpha: boolean; }): void; + /** + Get width in pixels. + */ + getPixelWidth(): number; + /** + Get height of in pixels. + */ + getPixelHeight(): number; + /** + Get content size. + */ + getContentSize(): Size; + /** + Get content size in pixels. + */ + getContentSizeInPixels(): Size; + /** + Init with HTML element. + @param element element + + @example + ```js + var img = new Image(); + img.src = dataURL; + texture.initWithElement(img); + texture.handleLoadedTexture(); + ``` + */ + initWithElement(element: HTMLImageElement|HTMLCanvasElement): void; + /** + Intializes with a texture2d with data. + @param data data + @param pixelFormat pixelFormat + @param pixelsWidth pixelsWidth + @param pixelsHeight pixelsHeight + @param contentSize contentSize + */ + initWithData(data: TypedArray, pixelFormat: number, pixelsWidth: number, pixelsHeight: number, contentSize: Size): boolean; + /** + Initializes a texture from a UIImage object. + Extensions to make it easy to create a CCTexture2D object from an image file. + Note that RGBA type textures will have their alpha premultiplied - use the blending mode (gl.ONE, gl.ONE_MINUS_SRC_ALPHA). + @param uiImage uiImage + */ + initWithImage(uiImage: HTMLImageElement): boolean; + /** + HTMLElement Object getter, available only on web. + In most case, it will return null, because we are recycling the dom image element for better loading performance and lower image cache memory usage. + */ + getHtmlElementObj(): HTMLImageElement; + /** + Check whether texture is loaded. + */ + isLoaded(): boolean; + /** + Handler of texture loaded event. + @param premultiplied premultiplied + */ + handleLoadedTexture(premultiplied?: boolean): void; + /** + Description of cc.Texture2D. + */ + description(): string; + /** + Release texture. + */ + releaseTexture(): void; + /** + Pixel format of the texture. + */ + getPixelFormat(): number; + /** + Whether or not the texture has their Alpha premultiplied, + support only in WebGl rendering mode. + */ + hasPremultipliedAlpha(): boolean; + /** + Whether or not use mipmap, support only in WebGl rendering mode. + */ + hasMipmaps(): boolean; + /** + Sets the min filter, mag filter, wrap s and wrap t texture parameters.
+ If the texture size is NPOT (non power of 2), then in can only use gl.CLAMP_TO_EDGE in gl.TEXTURE_WRAP_{S,T}. + @param texParams texParams object or minFilter + @param magFilter magFilter + @param wrapS wrapS + @param wrapT wrapT + */ + setTexParameters(texParams: any|number, magFilter?: number, wrapS?: Texture2D.WrapMode, wrapT?: Texture2D.WrapMode): void; + /** + sets antialias texture parameters:
+ - GL_TEXTURE_MIN_FILTER = GL_NEAREST
+ - GL_TEXTURE_MAG_FILTER = GL_NEAREST
+ supported only in native or WebGl rendering mode + */ + setAntiAliasTexParameters(): void; + /** + Sets alias texture parameters:
+ GL_TEXTURE_MIN_FILTER = GL_NEAREST
+ GL_TEXTURE_MAG_FILTER = GL_NEAREST
+ supported only in native or WebGl rendering mode + */ + setAliasTexParameters(): void; + /** Pixel format of the texture. */ + pixelFormat: number; + /** Width in pixels. */ + pixelWidth: number; + /** Height in pixels. */ + pixelHeight: number; + /** + !#en + Register an callback of a specific event type on the EventTarget. + !#zh + 注册事件目标的特定事件类型回调。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + on(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + on(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Removes the listeners previously registered with the same type, callback, target and or useCapture, + if only type is passed as parameter, all listeners registered with that type will be removed. + !#zh + 删除之前用同类型,回调,目标或 useCapture 注册的事件监听器,如果只传递 type,将会删除 type 类型的所有事件监听器。 + @param type A string representing the event type being removed. + @param callback The callback to remove. + @param target The target (this object) to invoke the callback, if it's not given, only callback without target will be removed + @param useCapture Specifies whether the callback being removed was registered as a capturing callback or not. + If not specified, useCapture defaults to false. If a callback was registered twice, + one with capture and one without, each must be removed separately. Removal of a capturing callback + does not affect a non-capturing version of the same listener, and vice versa. + + @example + ```js + // register touchEnd eventListener + var touchEnd = node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + // remove touch end event listener + node.off(cc.Node.EventType.TOUCH_END, touchEnd, node); + // remove all touch end event listeners + node.off(cc.Node.EventType.TOUCH_END); + ``` + */ + off(type: string, callback?: Function, target?: any, useCapture?: boolean): void; + /** + !#en Removes all callbacks previously registered with the same target (passed as parameter). + This is not for removing all listeners in the current event target, + and this is not for removing all listeners the target parameter have registered. + It's only for removing all listeners (callback and target couple) registered on the current event target by the target parameter. + !#zh 在当前 EventTarget 上删除指定目标(target 参数)注册的所有事件监听器。 + 这个函数无法删除当前 EventTarget 的所有事件监听器,也无法删除 target 参数所注册的所有事件监听器。 + 这个函数只能删除 target 参数在当前 EventTarget 上注册的所有事件监听器。 + @param target The target to be searched for all related listeners + */ + targetOff(target: any): void; + /** + !#en + Register an callback of a specific event type on the EventTarget, + the callback will remove itself after the first time it is triggered. + !#zh + 注册事件目标的特定事件类型回调,回调会在第一时间被触发后删除自身。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.once(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + once(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + once(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Dispatches an event into the event flow. + The event target is the EventTarget object upon which the dispatchEvent() method is called. + !#zh 分发事件到事件流中。 + @param event The Event object that is dispatched into the event flow + */ + dispatchEvent(event: Event): void; + /** + !#en + Send an event to this object directly, this method will not propagate the event to any other objects. + The event will be created from the supplied message, you can get the "detail" argument from event.detail. + !#zh + 该对象直接发送事件, 这种方法不会对事件传播到任何其他对象。 + @param message the message to send + @param detail whatever argument the message needs + */ + emit(message: string, detail?: any): void; + } + /** cc.textureCache is a singleton object, it's the global cache for cc.Texture2D */ + export class textureCache { + /** + Description + */ + static description(): string; + /** + Returns an already created texture. Returns null if the texture doesn't exist. + @param textureKeyName textureKeyName + + @example + ```js + ------------------ + var key = cc.textureCache.textureForKey("hello.png"); + + ``` + */ + static textureForKey(textureKeyName: string): Texture2D; + /** + Returns an already created texture. Returns null if the texture doesn't exist. + @param textureKeyName textureKeyName + + @example + ```js + ------------------ + var key = cc.textureCache.getTextureForKey("hello.png"); + + ``` + */ + static getTextureForKey(textureKeyName: string): Texture2D; + /** + + @param texture texture + + @example + ```js + --------------- + var cacheTextureForColor = cc.textureCache.getTextureColors(texture); + + ``` + */ + static getTextureColors(texture: HTMLImageElement): any[]; + /** + #en get all textures + #zh 获取所有贴图 + */ + static getAllTextures(): Texture2D[]; + /** +

Purges the dictionary of loaded textures.
+ Call this method if you receive the "Memory Warning"
+ In the short term: it will free some resources preventing your app from being killed
+ In the medium term: it will allocate more resources
+ In the long term: it will be the same

+ + @example + ```js + -------- + cc.textureCache.removeAllTextures(); + + ``` + */ + static removeAllTextures(): void; + /** + Deletes a texture from the cache given a texture. + @param texture texture + + @example + ```js + ----- + cc.textureCache.removeTexture(texture); + + ``` + */ + static removeTexture(texture: HTMLImageElement): void; + /** + Deletes a texture from the cache given a its key name. + @param textureKeyName textureKeyName + + @example + ```js + ------ + cc.textureCache.removeTexture("hello.png"); + + ``` + */ + static removeTextureForKey(textureKeyName: string): void; + /** +

Returns a Texture2D object given an file image
+ If the file image was not previously loaded, it will create a new Texture2D
+ object and it will return it. It will use the filename as a key.
+ Otherwise it will return a reference of a previously loaded image.
+ Supported image extensions: .png, .jpg, .gif

+ @param url url + @param cb cb + @param target target + + @example + ```js + ---- + cc.textureCache.addImage("hello.png"); + + ``` + */ + static addImage(url: string, cb: Function, target: any): Texture2D; + /** + Cache the image data. + @param path path + @param texture texture + */ + static cacheImage(path: string, texture: HTMLImageElement|HTMLCanvasElement): void; + } + /** A base node for CCNode, it will: + - maintain scene hierarchy and active logic + - notifications if some properties changed + - define some interfaces shares between CCNode + - define machanisms for Enity Component Systems + - define prefab and serialize functions */ + export class _BaseNode extends Object implements EventTarget { + /** !#en Name of node. + !#zh 该节点名称。 */ + name: string; + /** !#en The uuid for editor, will be stripped before building project. + !#zh 主要用于编辑器的 uuid,在编辑器下可用于持久化存储,在项目构建之后将变成自增的 id。 */ + uuid: string; + /** !#en All children nodes. + !#zh 节点的所有子节点。 */ + children: Node[]; + /** !#en All children nodes. + !#zh 节点的子节点数量。 */ + childrenCount: number; + /** !#en + The local active state of this node.
+ Note that a Node may be inactive because a parent is not active, even if this returns true.
+ Use {{#crossLink "Node/activeInHierarchy:property"}}{{/crossLink}} if you want to check if the Node is actually treated as active in the scene. + !#zh + 当前节点的自身激活状态。
+ 值得注意的是,一个节点的父节点如果不被激活,那么即使它自身设为激活,它仍然无法激活。
+ 如果你想检查节点在场景中实际的激活状态可以使用 {{#crossLink "Node/activeInHierarchy:property"}}{{/crossLink}}。 */ + active: boolean; + /** !#en Indicates whether this node is active in the scene. + !#zh 表示此节点是否在场景中激活。 */ + activeInHierarchy: boolean; + /** !#en Tag of node. + !#zh 节点标签。 */ + tag: number; + /** + + @param name name + */ + constructor(name?: string); + /** !#en The parent of the node. + !#zh 该节点的父节点。 */ + parent: Node; + /** + !#en + Properties configuration function
+ All properties in attrs will be set to the node,
+ when the setter of the node is available,
+ the property will be set via setter function.
+ !#zh 属性配置函数。在 attrs 的所有属性将被设置为节点属性。 + @param attrs Properties to be set to node + + @example + ```js + var attrs = { key: 0, num: 100 }; + node.attr(attrs); + ``` + */ + attr(attrs: any): void; + /** + !#en Returns a child from the container given its tag. + !#zh 通过标签获取节点的子节点。 + @param aTag An identifier to find the child node. + + @example + ```js + var child = node.getChildByTag(1001); + ``` + */ + getChildByTag(aTag: number): Node; + /** + !#en Returns a child from the container given its uuid. + !#zh 通过 uuid 获取节点的子节点。 + @param uuid The uuid to find the child node. + + @example + ```js + var child = node.getChildByUuid(uuid); + ``` + */ + getChildByUuid(uuid: string): Node; + /** + !#en Returns a child from the container given its name. + !#zh 通过名称获取节点的子节点。 + @param name A name to find the child node. + + @example + ```js + var child = node.getChildByName("Test Node"); + ``` + */ + getChildByName(name: string): Node; + /** + !#en + Inserts a child to the node at a specified index. + !#zh + 插入子节点到指定位置 + @param child the child node to be inserted + @param siblingIndex the sibling index to place the child in + + @example + ```js + node.insertChild(child, 2); + ``` + */ + insertChild(child: Node, siblingIndex: number): void; + /** + !#en Get the sibling index. + !#zh 获取同级索引。 + + @example + ```js + var index = node.getSiblingIndex(); + ``` + */ + getSiblingIndex(): number; + /** + !#en Set the sibling index of this node. + !#zh 设置节点同级索引。 + @param index index + + @example + ```js + node.setSiblingIndex(1); + ``` + */ + setSiblingIndex(index: number): void; + /** + !#en + Remove itself from its parent node. If cleanup is `true`, then also remove all events and actions.
+ If the cleanup parameter is not passed, it will force a cleanup, so it is recommended that you always pass in the `false` parameter when calling this API.
+ If the node orphan, then nothing happens. + !#zh + 从父节点中删除该节点。如果不传入 cleanup 参数或者传入 `true`,那么这个节点上所有绑定的事件、action 都会被删除。
+ 因此建议调用这个 API 时总是传入 `false` 参数。
+ 如果这个节点是一个孤节点,那么什么都不会发生。 + @param cleanup true if all actions and callbacks on this node should be removed, false otherwise. + + @example + ```js + node.removeFromParent(); + node.removeFromParent(false); + ``` + */ + removeFromParent(cleanup?: boolean): void; + /** + !#en + Removes a child from the container. It will also cleanup all running actions depending on the cleanup parameter.

+ If the cleanup parameter is not passed, it will force a cleanup.
+ "remove" logic MUST only be on this method
+ If a class wants to extend the 'removeChild' behavior it only needs
+ to override this method. + !#zh + 移除节点中指定的子节点,是否需要清理所有正在运行的行为取决于 cleanup 参数。
+ 如果 cleanup 参数不传入,默认为 true 表示清理。
+ @param child The child node which will be removed. + @param cleanup true if all running actions and callbacks on the child node will be cleanup, false otherwise. + + @example + ```js + node.removeChild(newNode); + node.removeChild(newNode, false); + ``` + */ + removeChild(child: Node, cleanup?: boolean): void; + /** + !#en + Removes a child from the container by tag value. It will also cleanup all running actions depending on the cleanup parameter. + If the cleanup parameter is not passed, it will force a cleanup.
+ !#zh + 通过标签移除节点中指定的子节点,是否需要清理所有正在运行的行为取决于 cleanup 参数。
+ 如果 cleanup 参数不传入,默认为 true 表示清理。 + @param tag An integer number that identifies a child node + @param cleanup true if all running actions and callbacks on the child node will be cleanup, false otherwise. + + @example + ```js + node.removeChildByTag(1001); + node.removeChildByTag(1001, false); + ``` + */ + removeChildByTag(tag: number, cleanup?: boolean): void; + /** + !#en + Removes all children from the container and do a cleanup all running actions depending on the cleanup parameter.
+ If the cleanup parameter is not passed, it will force a cleanup. + !#zh + 移除节点所有的子节点,是否需要清理所有正在运行的行为取决于 cleanup 参数。
+ 如果 cleanup 参数不传入,默认为 true 表示清理。 + @param cleanup true if all running actions on all children nodes should be cleanup, false otherwise. + + @example + ```js + node.removeAllChildren(); + node.removeAllChildren(false); + ``` + */ + removeAllChildren(cleanup?: boolean): void; + /** + !#en Is this node a child of the given node? + !#zh 是否是指定节点的子节点? + @param parent parent + + @example + ```js + node.isChildOf(newNode); + ``` + */ + isChildOf(parent: Node): boolean; + /** + !#en + Returns the component of supplied type if the node has one attached, null if it doesn't.
+ You can also get component in the node by passing in the name of the script. + !#zh + 获取节点上指定类型的组件,如果节点有附加指定类型的组件,则返回,如果没有则为空。
+ 传入参数也可以是脚本的名称。 + @param typeOrClassName typeOrClassName + + @example + ```js + // get sprite component. + var sprite = node.getComponent(cc.Sprite); + // get custom test calss. + var test = node.getComponent("Test"); + ``` + */ + getComponent(type: {prototype: T}): T; + getComponent(className: string): any; + /** + !#en Returns all components of supplied type in the node. + !#zh 返回节点上指定类型的所有组件。 + @param typeOrClassName typeOrClassName + + @example + ```js + var sprites = node.getComponents(cc.Sprite); + var tests = node.getComponents("Test"); + ``` + */ + getComponents(type: {prototype: T}): T[]; + getComponents(className: string): any[]; + /** + !#en Returns the component of supplied type in any of its children using depth first search. + !#zh 递归查找所有子节点中第一个匹配指定类型的组件。 + @param typeOrClassName typeOrClassName + + @example + ```js + var sprite = node.getComponentInChildren(cc.Sprite); + var Test = node.getComponentInChildren("Test"); + ``` + */ + getComponentInChildren(type: {prototype: T}): T; + getComponentInChildren(className: string): any; + /** + !#en Returns all components of supplied type in self or any of its children. + !#zh 递归查找自身或所有子节点中指定类型的组件 + @param typeOrClassName typeOrClassName + + @example + ```js + var sprites = node.getComponentsInChildren(cc.Sprite); + var tests = node.getComponentsInChildren("Test"); + ``` + */ + getComponentsInChildren(type: {prototype: T}): T[]; + getComponentsInChildren(className: string): any[]; + /** + !#en Adds a component class to the node. You can also add component to node by passing in the name of the script. + !#zh 向节点添加一个指定类型的组件类,你还可以通过传入脚本的名称来添加组件。 + @param typeOrClassName The constructor or the class name of the component to add + + @example + ```js + var sprite = node.addComponent(cc.Sprite); + var test = node.addComponent("Test"); + ``` + */ + addComponent(type: {new(): T}): T; + addComponent(className: string): any; + /** + !#en + Removes a component identified by the given name or removes the component object given. + You can also use component.destroy() if you already have the reference. + !#zh + 删除节点上的指定组件,传入参数可以是一个组件构造函数或组件名,也可以是已经获得的组件引用。 + 如果你已经获得组件引用,你也可以直接调用 component.destroy() + @param component The need remove component. + + @example + ```js + node.removeComponent(cc.Sprite); + var Test = require("Test"); + node.removeComponent(Test); + ``` + */ + removeComponent(component: string|Function|Component): void; + /** + !#en + Destroy all children from the node, and release all their own references to other objects.
+ Actual destruct operation will delayed until before rendering. + !#zh + 销毁所有子节点,并释放所有它们对其它对象的引用。
+ 实际销毁操作会延迟到当前帧渲染前执行。 + + @example + ```js + node.destroyAllChildren(); + ``` + */ + destroyAllChildren(): void; + /** + !#en + Register an callback of a specific event type on the EventTarget. + !#zh + 注册事件目标的特定事件类型回调。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + on(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + on(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Removes the listeners previously registered with the same type, callback, target and or useCapture, + if only type is passed as parameter, all listeners registered with that type will be removed. + !#zh + 删除之前用同类型,回调,目标或 useCapture 注册的事件监听器,如果只传递 type,将会删除 type 类型的所有事件监听器。 + @param type A string representing the event type being removed. + @param callback The callback to remove. + @param target The target (this object) to invoke the callback, if it's not given, only callback without target will be removed + @param useCapture Specifies whether the callback being removed was registered as a capturing callback or not. + If not specified, useCapture defaults to false. If a callback was registered twice, + one with capture and one without, each must be removed separately. Removal of a capturing callback + does not affect a non-capturing version of the same listener, and vice versa. + + @example + ```js + // register touchEnd eventListener + var touchEnd = node.on(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + // remove touch end event listener + node.off(cc.Node.EventType.TOUCH_END, touchEnd, node); + // remove all touch end event listeners + node.off(cc.Node.EventType.TOUCH_END); + ``` + */ + off(type: string, callback?: Function, target?: any, useCapture?: boolean): void; + /** + !#en Removes all callbacks previously registered with the same target (passed as parameter). + This is not for removing all listeners in the current event target, + and this is not for removing all listeners the target parameter have registered. + It's only for removing all listeners (callback and target couple) registered on the current event target by the target parameter. + !#zh 在当前 EventTarget 上删除指定目标(target 参数)注册的所有事件监听器。 + 这个函数无法删除当前 EventTarget 的所有事件监听器,也无法删除 target 参数所注册的所有事件监听器。 + 这个函数只能删除 target 参数在当前 EventTarget 上注册的所有事件监听器。 + @param target The target to be searched for all related listeners + */ + targetOff(target: any): void; + /** + !#en + Register an callback of a specific event type on the EventTarget, + the callback will remove itself after the first time it is triggered. + !#zh + 注册事件目标的特定事件类型回调,回调会在第一时间被触发后删除自身。 + @param type A string representing the event type to listen for. + @param callback The callback that will be invoked when the event is dispatched. + The callback is ignored if it is a duplicate (the callbacks are unique). + @param target The target (this object) to invoke the callback, can be null + @param useCapture When set to true, the capture argument prevents callback + from being invoked when the event's eventPhase attribute value is BUBBLING_PHASE. + When false, callback will NOT be invoked when event's eventPhase attribute value is CAPTURING_PHASE. + Either way, callback will be invoked when event's eventPhase attribute value is AT_TARGET. + + @example + ```js + node.once(cc.Node.EventType.TOUCH_END, function (event) { + cc.log("this is callback"); + }, node); + ``` + */ + once(type: string, callback: (event: Event.EventCustom) => void, target?: any, useCapture?: boolean): (event: Event.EventCustom) => void; + once(type: string, callback: (event: T) => void, target?: any, useCapture?: boolean): (event: T) => void; + /** + !#en + Dispatches an event into the event flow. + The event target is the EventTarget object upon which the dispatchEvent() method is called. + !#zh 分发事件到事件流中。 + @param event The Event object that is dispatched into the event flow + */ + dispatchEvent(event: Event): void; + /** + !#en + Send an event to this object directly, this method will not propagate the event to any other objects. + The event will be created from the supplied message, you can get the "detail" argument from event.detail. + !#zh + 该对象直接发送事件, 这种方法不会对事件传播到任何其他对象。 + @param message the message to send + @param detail whatever argument the message needs + */ + emit(message: string, detail?: any): void; + } + /** !#en + cc.AffineTransform class represent an affine transform matrix. It's composed basically by translation, rotation, scale transformations.
+ Please do not use its constructor directly, use cc.affineTransformMake alias function instead. + !#zh + cc.AffineTransform 类代表一个仿射变换矩阵。它基本上是由平移旋转,缩放转变所组成。
+ 请不要直接使用它的构造,请使用 cc.affineTransformMake 函数代替。 */ + export class AffineTransform { + /** + !#en Create a cc.AffineTransform object with all contents in the matrix. + !#zh 用在矩阵中的所有内容创建一个 cc.AffineTransform 对象。 + @param a a + @param b b + @param c c + @param d d + @param tx tx + @param ty ty + */ + affineTransformMake(a: number, b: number, c: number, d: number, tx: number, ty: number): AffineTransform; + /** + !#en Clone a cc.AffineTransform object from the specified transform. + !#zh 克隆指定的 cc.AffineTransform 对象。 + @param t t + */ + affineTransformClone(t: AffineTransform): AffineTransform; + /** + !#en Apply the affine transformation on a point. + !#zh 对一个点应用矩阵变换。 + @param point or x. + @param transOrY transform matrix or y. + @param t transform matrix or y. + */ + pointApplyAffineTransform(point: Vec2|number, transOrY: AffineTransform|number, t: AffineTransform): Vec2; + /** + !#en Apply the affine transformation on a size. + !#zh 应用 Size 到仿射变换矩阵上。 + @param size size + @param t t + */ + sizeApplyAffineTransform(size: Size, t: AffineTransform): Size; + /** + !#en + Create a identity transformation matrix:
+ [ 1, 0, 0,
+ 0, 1, 0 ] + !#zh + 单位矩阵:
+ [ 1, 0, 0,
+ 0, 1, 0 ] + */ + affineTransformMakeIdentity(): AffineTransform; + /** + !#en Apply the affine transformation on a rect. + !#zh 应用 Rect 到仿射变换矩阵上。 + @param rect rect + @param anAffineTransform anAffineTransform + */ + rectApplyAffineTransform(rect: Rect, anAffineTransform: AffineTransform): Rect; + /** + !#en Apply the affine transformation on a rect, and truns to an Oriented Bounding Box. + !#zh 应用 Rect 到仿射变换矩阵上, 并转换为有向包围盒 + @param rect rect + @param anAffineTransform anAffineTransform + @param out_bl out_bl + @param out_tl out_tl + @param out_tr out_tr + @param out_br out_br + */ + obbApplyAffineTransform(rect: Rect, anAffineTransform: AffineTransform, out_bl: Vec2, out_tl: Vec2, out_tr: Vec2, out_br: Vec2): void; + /** + !#en Create a new affine transformation with a base transformation matrix and a translation based on it. + !#zh 基于一个基础矩阵加上一个平移操作来创建一个新的矩阵。 + @param t The base affine transform object. + @param tx The translation on x axis. + @param ty The translation on y axis. + */ + affineTransformTranslate(t: AffineTransform, tx: number, ty: number): AffineTransform; + /** + !#en Create a new affine transformation with a base transformation matrix and a scale based on it. + !#zh 创建一个基础变换矩阵,并在此基础上进行了 Scale 仿射变换。 + @param t The base affine transform object. + @param sx The scale on x axis. + @param sy The scale on y axis. + */ + affineTransformScale(t: AffineTransform, sx: number, sy: number): AffineTransform; + /** + !#en Create a new affine transformation with a base transformation matrix and a rotation based on it. + !#zh 创建一个基础变换矩阵,并在此基础上进行了 Rotation 仿射变换。 + @param aTransform The base affine transform object. + @param anAngle The angle to rotate. + */ + affineTransformRotate(aTransform: AffineTransform, anAngle: number): AffineTransform; + /** + !#en + Concatenate a transform matrix to another and return the result:
+ t' = t1 * t2 + !#zh 拼接两个矩阵,并返回结果:
+ t' = t1 * t2 + @param t1 The first transform object. + @param t2 The transform object to concatenate. + */ + affineTransformConcat(t1: AffineTransform, t2: AffineTransform): AffineTransform; + /** + !#en + Concatenate a transform matrix to another
+ The results are reflected in the first matrix.
+ t' = t1 * t2 + !#zh + 拼接两个矩阵,将结果保存到第一个矩阵。
+ t' = t1 * t2 + @param t1 The first transform object. + @param t2 The transform object to concatenate. + */ + affineTransformConcatIn(t1: AffineTransform, t2: AffineTransform): AffineTransform; + /** + !#en Return true if an affine transform equals to another, false otherwise. + !#zh 判断两个矩阵是否相等。 + @param t1 t1 + @param t2 t2 + */ + affineTransformEqualToTransform(t1: AffineTransform, t2: AffineTransform): boolean; + /** + !#en Get the invert transform of an AffineTransform object. + !#zh 求逆矩阵。 + @param t t + */ + affineTransformInvert(t: AffineTransform): AffineTransform; + /** + !#en Put the invert transform of an AffineTransform object into the out AffineTransform object. + !#zh 求逆矩阵并存入用户传入的矩阵对象参数。 + @param t t + @param out out + */ + affineTransformInvert(t: AffineTransform, out: AffineTransform): void; + } + /** !#en + Representation of RGBA colors. + + Each color component is a floating point value with a range from 0 to 255. + + You can also use the convenience method {{#crossLink "cc/color:method"}}cc.color{{/crossLink}} to create a new Color. + + !#zh + cc.Color 用于表示颜色。 + + 它包含 RGBA 四个以浮点数保存的颜色分量,每个的值都在 0 到 255 之间。 + + 您也可以通过使用 {{#crossLink "cc/color:method"}}cc.color{{/crossLink}} 的便捷方法来创建一个新的 Color。 */ + export class Color extends ValueType { + /** + + @param r red component of the color, default value is 0. + @param g green component of the color, defualt value is 0. + @param b blue component of the color, default value is 0. + @param a alpha component of the color, default value is 255. + */ + constructor(r?: number, g?: number, b?: number, a?: number); + /** !#en Solid white, RGBA is [255, 255, 255, 255]. + !#zh 纯白色,RGBA 是 [255, 255, 255, 255]。 */ + static WHITE: Color; + /** !#en Solid black, RGBA is [0, 0, 0, 255]. + !#zh 纯黑色,RGBA 是 [0, 0, 0, 255]。 */ + static BLACK: Color; + /** !#en Transparent, RGBA is [0, 0, 0, 0]. + !#zh 透明,RGBA 是 [0, 0, 0, 0]。 */ + static TRANSPARENT: Color; + /** !#en Grey, RGBA is [127.5, 127.5, 127.5]. + !#zh 灰色,RGBA 是 [127.5, 127.5, 127.5]。 */ + static GRAY: Color; + /** !#en Solid red, RGBA is [255, 0, 0]. + !#zh 纯红色,RGBA 是 [255, 0, 0]。 */ + static RED: Color; + /** !#en Solid green, RGBA is [0, 255, 0]. + !#zh 纯绿色,RGBA 是 [0, 255, 0]。 */ + static GREEN: Color; + /** !#en Solid blue, RGBA is [0, 0, 255]. + !#zh 纯蓝色,RGBA 是 [0, 0, 255]。 */ + static BLUE: Color; + /** !#en Yellow, RGBA is [255, 235, 4]. + !#zh 黄色,RGBA 是 [255, 235, 4]。 */ + static YELLOW: Color; + /** !#en Orange, RGBA is [255, 127, 0]. + !#zh 橙色,RGBA 是 [255, 127, 0]。 */ + static ORANGE: Color; + /** !#en Cyan, RGBA is [0, 255, 255]. + !#zh 青色,RGBA 是 [0, 255, 255]。 */ + static CYAN: Color; + /** !#en Magenta, RGBA is [255, 0, 255]. + !#zh 洋红色(品红色),RGBA 是 [255, 0, 255]。 */ + static MAGENTA: Color; + /** + !#en Clone a new color from the current color. + !#zh 克隆当前颜色。 + + @example + ```js + var color = new cc.Color(); + var newColor = color.clone();// Color {r: 0, g: 0, b: 0, a: 255} + ``` + */ + clone(): Color; + /** + !#en TODO + !#zh 判断两个颜色是否相等。 + @param other other + + @example + ```js + var color1 = cc.Color.WHITE; + var color2 = new cc.Color(255, 255, 255); + cc.log(color1.equals(color2)); // true; + color2 = cc.Color.RED; + cc.log(color2.equals(color1)); // false; + ``` + */ + equals(other: Color): boolean; + /** + !#en TODO + !#zh 线性插值 + @param to to + @param ratio the interpolation coefficient. + @param out optional, the receiving vector. + + @example + ```js + // Converts a white color to a black one trough time. + update: function (dt) { + var color = this.node.color; + if (color.equals(cc.Color.BLACK)) { + return; + } + this.ratio += dt * 0.1; + this.node.color = cc.Color.WHITE.lerp(cc.Color.BLACK, ratio); + } + + ``` + */ + lerp(to: Color, ratio: number, out?: Color): Color; + /** + !#en TODO + !#zh 转换为方便阅读的字符串。 + + @example + ```js + var color = cc.Color.WHITE; + color.toString(); // "rgba(255, 255, 255, 255)" + ``` + */ + toString(): string; + /** + !#en Gets red channel value + !#zh 获取当前颜色的红色值。 + */ + getR(): number; + /** + !#en Sets red value and return the current color object + !#zh 设置当前的红色值,并返回当前对象。 + @param red the new Red component. + + @example + ```js + var color = new cc.Color(); + color.setR(255); // Color {r: 255, g: 0, b: 0, a: 255} + ``` + */ + setR(red: number): Color; + /** + !#en Gets green channel value + !#zh 获取当前颜色的绿色值。 + */ + getG(): number; + /** + !#en Sets green value and return the current color object + !#zh 设置当前的绿色值,并返回当前对象。 + @param green the new Green component. + + @example + ```js + var color = new cc.Color(); + color.setG(255); // Color {r: 0, g: 255, b: 0, a: 255} + ``` + */ + setG(green: number): Color; + /** + !#en Gets blue channel value + !#zh 获取当前颜色的蓝色值。 + */ + getB(): number; + /** + !#en Sets blue value and return the current color object + !#zh 设置当前的蓝色值,并返回当前对象。 + @param blue the new Blue component. + + @example + ```js + var color = new cc.Color(); + color.setB(255); // Color {r: 0, g: 0, b: 255, a: 255} + ``` + */ + setB(blue: number): Color; + /** + !#en Gets alpha channel value + !#zh 获取当前颜色的透明度值。 + */ + getA(): number; + /** + !#en Sets alpha value and return the current color object + !#zh 设置当前的透明度,并返回当前对象。 + @param alpha the new Alpha component. + + @example + ```js + var color = new cc.Color(); + color.setA(0); // Color {r: 0, g: 0, b: 0, a: 0} + ``` + */ + setA(alpha: number): Color; + /** + !#en Convert color to css format. + !#zh 转换为 CSS 格式。 + @param opt "rgba", "rgb", "#rgb" or "#rrggbb". + + @example + ```js + var color = cc.Color.BLACK; + color.toCSS(); // "#000"; + color.toCSS("rgba"); // "rgba(0,0,0,1.00)"; + color.toCSS("rgb"); // "rgba(0,0,0)"; + color.toCSS("#rgb"); // "#000"; + color.toCSS("#rrggbb"); // "#000000"; + ``` + */ + toCSS(opt: string): string; + /** + !#en Clamp this color to make all components between 0 to 255。 + !#zh 限制颜色数值,在 0 到 255 之间。 + + @example + ```js + var color = new cc.Color(1000, 0, 0, 255); + color.clamp(); + cc.log(color); // (255, 0, 0, 255) + ``` + */ + clamp(): void; + /** + !#en Read hex string and store color data into the current color object, the hex string must be formated as rgba or rgb. + !#zh 读取 16 进制颜色。 + @param hexString hexString + + @example + ```js + var color = cc.Color.BLACK; + color.fromHEX("#FFFF33"); // Color {r: 255, g: 255, b: 51, a: 255}; + ``` + */ + fromHEX(hexString: string): Color; + /** + !#en TODO + !#zh 转换为 16 进制。 + @param fmt "#rgb" or "#rrggbb". + + @example + ```js + var color = cc.Color.BLACK; + color.toHEX("#rgb"); // "000"; + color.toHEX("#rrggbb"); // "000000"; + ``` + */ + toHEX(fmt: string): string; + /** + !#en Convert to 24bit rgb value. + !#zh 转换为 24bit 的 RGB 值。 + + @example + ```js + var color = cc.Color.YELLOW; + color.toRGBValue(); // 16771844; + ``` + */ + toRGBValue(): number; + /** + !#en TODO + !#zh 读取 HSV(色彩模型)格式。 + @param h h + @param s s + @param v v + + @example + ```js + var color = cc.Color.YELLOW; + color.fromHSV(0, 0, 1); // Color {r: 255, g: 255, b: 255, a: 255}; + ``` + */ + fromHSV(h: number, s: number, v: number): Color; + /** + !#en TODO + !#zh 转换为 HSV(色彩模型)格式。 + + @example + ```js + var color = cc.Color.YELLOW; + color.toHSV(); // Object {h: 0.1533864541832669, s: 0.9843137254901961, v: 1}; + ``` + */ + toHSV(): any; + /** + !#en TODO + !#zh RGB 转换为 HSV。 + @param r red, must be [0, 255]. + @param g red, must be [0, 255]. + @param b red, must be [0, 255]. + + @example + ```js + cc.Color.rgb2hsv(255, 255, 255); // Object {h: 0, s: 0, v: 1}; + ``` + */ + static rgb2hsv(r: number, g: number, b: number): any; + /** + !#en TODO + !#zh HSV 转换为 RGB。 + @param h h + @param s s + @param v v + + @example + ```js + cc.Color.hsv2rgb(0, 0, 1); // Object {r: 255, g: 255, b: 255}; + ``` + */ + static hsv2rgb(h: number, s: number, v: number): any; + } + /** !#en A 2D rectangle defined by x, y position and width, height. + !#zh 通过位置和宽高定义的 2D 矩形。 */ + export class Rect extends ValueType { + /** + !#en + Constructor of cc.Rect class. + see {{#crossLink "cc/rect:method"}} cc.rect {{/crossLink}} for convenience method. + !#zh + cc.Rect类的构造函数。可以通过 {{#crossLink "cc/rect:method"}} cc.rect {{/crossLink}} 简便方法进行创建。 + @param x x + @param y y + @param w w + @param h h + */ + constructor(x?: number, y?: number, w?: number, h?: number); + x: number; + y: number; + width: number; + height: number; + /** + !#en Creates a rectangle from two coordinate values. + !#zh 根据指定 2 个坐标创建出一个矩形区域。 + @param v1 v1 + @param v2 v2 + + @example + ```js + cc.Rect.fromMinMax(cc.v2(10, 10), cc.v2(20, 20)); // Rect {x: 10, y: 10, width: 10, height: 10}; + ``` + */ + static fromMinMax(v1: Vec2, v2: Vec2): Rect; + /** + !#en Checks if rect contains. + !#zh + 判断 2 个矩形是否有包含。
+ 返回 1 为 a 包含 b,如果 -1 为 b 包含 a, + 0 这则都不包含。 + @param a Rect a + @param b Rect b + + @example + ```js + var a = new cc.Rect(0, 0, 10, 10); + var b = new cc.Rect(5, 5, 5, 5); + var c = new cc.Rect(20, 20, 10, 10); + cc.Rect.contain(a, b); // 1; + cc.Rect.contain(b, a); // -1; + cc.Rect.contain(a, c); // 0; + ``` + */ + static contain(a: Rect, b: Rect): number; + /** + !#en TODO + !#zh 克隆一个新的 Rect。 + + @example + ```js + var a = new cc.Rect(0, 0, 10, 10); + a.clone();// Rect {x: 0, y: 0, width: 10, height: 10} + ``` + */ + clone(): Rect; + /** + !#en TODO + !#zh 是否等于指定的矩形。 + @param other other + + @example + ```js + var a = new cc.Rect(0, 0, 10, 10); + var b = new cc.Rect(0, 0, 10, 10); + a.equals(b);// true; + ``` + */ + equals(other: Rect): boolean; + /** + !#en TODO + !#zh 线性插值 + @param to to + @param ratio the interpolation coefficient. + @param out optional, the receiving vector. + + @example + ```js + var a = new cc.Rect(0, 0, 10, 10); + var b = new cc.Rect(50, 50, 100, 100); + update (dt) { + // method 1; + var c = a.lerp(b, dt * 0.1); + // method 2; + a.lerp(b, dt * 0.1, c); + } + ``` + */ + lerp(to: Rect, ratio: number, out?: Rect): Rect; + /** + !#en TODO + !#zh 转换为方便阅读的字符串 + + @example + ```js + var a = new cc.Rect(0, 0, 10, 10); + a.toString();// "(0.00, 0.00, 10.00, 10.00)"; + ``` + */ + toString(): string; + /** !#en TODO + !#zh 矩形 x 轴上的最小值。 */ + xMin: number; + /** !#en TODO + !#zh 矩形 y 轴上的最小值。 */ + yMin: number; + /** !#en TODO + !#zh 矩形 x 轴上的最大值。 */ + xMax: number; + /** !#en TODO + !#zh 矩形 y 轴上的最大值。 */ + yMax: number; + /** !#en The position of the center of the rectangle. + !#zh 矩形的中心点。 */ + center: Vec2; + /** !#en The X and Y position of the rectangle. + !#zh 矩形的 x 和 y 坐标。 */ + origin: Vec2; + /** !#en Width and height of the rectangle. + !#zh 矩形的大小。 */ + size: Size; + /** + !#en TODO + !#zh 当前矩形与指定矩形是否相交。 + @param rect rect + + @example + ```js + var a = new cc.Rect(0, 0, 10, 10); + var b = new cc.Rect(0, 0, 20, 20); + a.intersects(b);// true + ``` + */ + intersects(rect: Rect): void; + /** + !#en TODO + !#zh 当前矩形是否包含指定坐标点。 + Returns true if the point inside this rectangle. + @param point point + + @example + ```js + var a = new cc.Rect(0, 0, 10, 10); + var b = new cc.Vec2(0, 5); + a.contains(b);// true + ``` + */ + contains(point: Vec2): void; + /** + !#en Returns true if the other rect totally inside this rectangle. + !#zh 当前矩形是否包含指定矩形。 + @param rect rect + + @example + ```js + var a = new cc.Rect(0, 0, 10, 10); + var b = new cc.Rect(0, 0, 20, 20); + a.containsRect(b);// true + ``` + */ + containsRect(rect: Rect): void; + } + /** !#en + cc.Size is the class for size object,
+ please do not use its constructor to create sizes,
+ use {{#crossLink "cc/size:method"}}{{/crossLink}} alias function instead.
+ It will be deprecated soon, please use cc.Vec2 instead. + + !#zh + cc.Size 是 size 对象的类。
+ 请不要使用它的构造函数创建的 size,
+ 使用 {{#crossLink "cc/size:method"}}{{/crossLink}} 别名函数。
+ 它不久将被取消,请使用cc.Vec2代替。 */ + export class Size { + /** + + @param width width + @param height height + */ + constructor(width: number|Size, height?: number); + width: number; + height: number; + /** !#en return a Size object with width = 0 and height = 0. + !#zh 返回一个宽度为 0 和高度为 0 的 Size 对象。 */ + static ZERO: Size; + /** + !#en TODO + !#zh 克隆 size 对象。 + + @example + ```js + var a = new cc.size(10, 10); + a.clone();// return Size {width: 0, height: 0}; + ``` + */ + clone(): Size; + /** + !#en TODO + !#zh 当前 Size 对象是否等于指定 Size 对象。 + @param other other + + @example + ```js + var a = new cc.size(10, 10); + a.equals(new cc.size(10, 10));// return true; + ``` + */ + equals(other: Size): boolean; + /** + !#en TODO + !#zh 线性插值。 + @param to to + @param ratio the interpolation coefficient. + @param out optional, the receiving vector. + + @example + ```js + var a = new cc.size(10, 10); + var b = new cc.rect(50, 50, 100, 100); + update (dt) { + // method 1; + var c = a.lerp(b, dt * 0.1); + // method 2; + a.lerp(b, dt * 0.1, c); + } + ``` + */ + lerp(to: Rect, ratio: number, out?: Size): Size; + /** + !#en TODO + !#zh 转换为方便阅读的字符串。 + + @example + ```js + var a = new cc.size(10, 10); + a.toString();// return "(10.00, 10.00)"; + ``` + */ + toString(): string; + } + /** !#en the device accelerometer reports values for each axis in units of g-force. + !#zh 设备重力传感器传递的各个轴的数据。 */ + export class Acceleration { + /** + + @param x x + @param y y + @param z z + @param timestamp timestamp + */ + constructor(x: number, y: number, z: number, timestamp: number); + } + /** !#en Blend Function used for textures. + !#zh 图像的混合方式。 */ + export class BlendFunc { + /** + + @param src1 source blend function + @param dst1 destination blend function + */ + constructor(src1: number, dst1: number); + } + /** !#en + Enum for blend factor + Refer to: http://www.andersriggelsen.dk/glblendfunc.php + !#zh + 混合因子 + 可参考: http://www.andersriggelsen.dk/glblendfunc.php */ + export enum BlendFactor { + ONE = 0, + ZERO = 0, + SRC_ALPHA = 0, + SRC_COLOR = 0, + DST_ALPHA = 0, + DST_COLOR = 0, + ONE_MINUS_SRC_ALPHA = 0, + ONE_MINUS_SRC_COLOR = 0, + ONE_MINUS_DST_ALPHA = 0, + ONE_MINUS_DST_COLOR = 0, + blendFuncDisable = 0, + } + /** undefined */ + export enum TextAlignment { + LEFT = 0, + CENTER = 0, + RIGHT = 0, + } + /** undefined */ + export class WebGLColor { + /** + + @param r r + @param g g + @param b b + @param a a + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(r: number, g: number, b: number, a: number, arrayBuffer: any[], offset: number); + BYTES_PER_ELEMENT: number; + } + /** undefined */ + export class Vertex2F { + /** + + @param x x + @param y y + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(x: number, y: number, arrayBuffer: any[], offset: number); + BYTES_PER_ELEMENT: number; + } + /** undefined */ + export class Vertex3F { + /** + + @param x x + @param y y + @param z z + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(x: number, y: number, z: number, arrayBuffer: any[], offset: number); + BYTES_PER_ELEMENT: number; + } + /** undefined */ + export class Tex2F { + /** + + @param u u + @param v v + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(u: number, v: number, arrayBuffer: any[], offset: number); + BYTES_PER_ELEMENT: number; + } + /** undefined */ + export class Quad2 { + /** + + @param tl tl + @param tr tr + @param bl bl + @param br br + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(tl: Vertex2F, tr: Vertex2F, bl: Vertex2F, br: Vertex2F, arrayBuffer: any[], offset: number); + BYTES_PER_ELEMENT: number; + } + /** A 3D Quad. 4 * 3 floats */ + export class Quad3 { + /** + + @param bl1 bl1 + @param br1 br1 + @param tl1 tl1 + @param tr1 tr1 + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(bl1: Vertex3F, br1: Vertex3F, tl1: Vertex3F, tr1: Vertex3F, arrayBuffer: any[], offset: number); + } + /** undefined */ + export class V3F_C4B_T2F { + /** + + @param vertices vertices + @param colors colors + @param texCoords texCoords + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(vertices: Vertex3F, colors: Color, texCoords: Tex2F, arrayBuffer: any[], offset: number); + BYTES_PER_ELEMENT(): void; + } + /** undefined */ + export class V3F_C4B_T2F_Quad { + /** + + @param tl tl + @param bl bl + @param tr tr + @param br br + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(tl: V3F_C4B_T2F, bl: V3F_C4B_T2F, tr: V3F_C4B_T2F, br: V3F_C4B_T2F, arrayBuffer: any[], offset: number); + BYTES_PER_ELEMENT: number; + } + /** undefined */ + export class V2F_C4B_T2F { + /** + + @param vertices vertices + @param colors colors + @param texCoords texCoords + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(vertices: Vertex2F, colors: Color, texCoords: Tex2F, arrayBuffer: any[], offset: number); + BYTES_PER_ELEMENT: number; + } + /** undefined */ + export class V2F_C4B_T2F_Triangle { + /** + + @param a a + @param b b + @param c c + @param arrayBuffer arrayBuffer + @param offset offset + */ + constructor(a: V2F_C4B_T2F, b: V2F_C4B_T2F, c: V2F_C4B_T2F, arrayBuffer: any[], offset: number); + } + /** !#en The base class of all value types. + !#zh 所有值类型的基类。 */ + export class ValueType { + /** + !#en This method returns an exact copy of current value. + !#zh 克隆当前值,该方法返回一个新对象,新对象的值和原对象相等。 + */ + clone(): ValueType; + /** + !#en Compares this object with the other one. + !#zh 当前对象是否等于指定对象。 + @param other other + */ + equals(other: ValueType): boolean; + /** + !#en + Linearly interpolates between this value to to value by ratio which is in the range [0, 1]. + When ratio = 0 returns this. When ratio = 1 return to. When ratio = 0.5 returns the average of this and to. + !#zh + 线性插值。
+ 当 ratio = 0 时返回自身,ratio = 1 时返回目标,ratio = 0.5 返回自身和目标的平均值。。 + @param to the to value + @param ratio the interpolation coefficient + */ + lerp(to: ValueType, ratio: number): ValueType; + /** + !#en TODO + !#zh 转换为方便阅读的字符串。 + */ + toString(): string; + } + /** !#en Representation of 2D vectors and points. + !#zh 表示 2D 向量和坐标 */ + export class Vec2 extends ValueType { + /** + !#en + Constructor + see {{#crossLink "cc/vec2:method"}}cc.v2{{/crossLink}} or {{#crossLink "cc/p:method"}}cc.p{{/crossLink}} + !#zh + 构造函数,可查看 {{#crossLink "cc/vec2:method"}}cc.v2{{/crossLink}} 或者 {{#crossLink "cc/p:method"}}cc.p{{/crossLink}} + @param x x + @param y y + */ + constructor(x?: number, y?: number); + x: number; + y: number; + /** + !#en clone a Vec2 value + !#zh 克隆一个 Vec2 值 + */ + clone(): Vec2; + /** + !#en TODO + !#zh 设置向量值。 + @param newValue !#en new value to set. !#zh 要设置的新值 + */ + set(newValue: Vec2): Vec2; + /** + !#en TODO + !#zh 当前的向量是否与指定的向量相等。 + @param other other + */ + equals(other: Vec2): boolean; + /** + !#en TODO + !#zh 转换为方便阅读的字符串。 + */ + toString(): string; + /** + !#en TODO + !#zh 线性插值。 + @param to to + @param ratio the interpolation coefficient + @param out optional, the receiving vector + */ + lerp(to: Vec2, ratio: number, out?: Vec2): Vec2; + /** + !#en Adds this vector. If you want to save result to another vector, use add() instead. + !#zh 向量加法。如果你想保存结果到另一个向量,使用 add() 代替。 + @param vector vector + + @example + ```js + var v = cc.v2(10, 10); + v.addSelf(cc.v2(5, 5));// return Vec2 {x: 15, y: 15}; + ``` + */ + addSelf(vector: Vec2): Vec2; + /** + !#en Adds two vectors, and returns the new result. + !#zh 向量加法,并返回新结果。 + @param vector vector + @param out optional, the receiving vector + + @example + ```js + var v = cc.v2(10, 10); + v.add(cc.v2(5, 5)); // return Vec2 {x: 15, y: 15}; + var v1; + v.add(cc.v2(5, 5), v1); // return Vec2 {x: 15, y: 15}; + ``` + */ + add(vector: Vec2, out?: Vec2): Vec2; + /** + !#en Subtracts one vector from this. If you want to save result to another vector, use sub() instead. + !#zh 向量减法。如果你想保存结果到另一个向量,可使用 sub() 代替。 + @param vector vector + + @example + ```js + var v = cc.v2(10, 10); + v.subSelf(cc.v2(5, 5));// return Vec2 {x: 5, y: 5}; + ``` + */ + subSelf(vector: Vec2): Vec2; + /** + !#en Subtracts one vector from this, and returns the new result. + !#zh 向量减法,并返回新结果。 + @param vector vector + @param out optional, the receiving vector + + @example + ```js + var v = cc.v2(10, 10); + v.sub(cc.v2(5, 5)); // return Vec2 {x: 5, y: 5}; + var v1; + v.sub(cc.v2(5, 5), v1); // return Vec2 {x: 5, y: 5}; + ``` + */ + sub(vector: Vec2, out?: Vec2): Vec2; + /** + !#en Multiplies this by a number. If you want to save result to another vector, use mul() instead. + !#zh 缩放当前向量。如果你想结果保存到另一个向量,可使用 mul() 代替。 + @param num num + + @example + ```js + var v = cc.v2(10, 10); + v.mulSelf(5);// return Vec2 {x: 50, y: 50}; + ``` + */ + mulSelf(num: number): Vec2; + /** + !#en Multiplies by a number, and returns the new result. + !#zh 缩放当前向量,并返回新结果。 + @param num num + @param out optional, the receiving vector + + @example + ```js + var v = cc.v2(10, 10); + v.mul(5); // return Vec2 {x: 50, y: 50}; + var v1; + v.mul(5, v1); // return Vec2 {x: 50, y: 50}; + ``` + */ + mul(num: number, out?: Vec2): Vec2; + /** + !#en Multiplies two vectors. + !#zh 分量相乘。 + @param vector vector + + @example + ```js + var v = cc.v2(10, 10); + v.scaleSelf(cc.v2(5, 5));// return Vec2 {x: 50, y: 50}; + ``` + */ + scaleSelf(vector: Vec2): Vec2; + /** + !#en Multiplies two vectors, and returns the new result. + !#zh 分量相乘,并返回新的结果。 + @param vector vector + @param out optional, the receiving vector + + @example + ```js + var v = cc.v2(10, 10); + v.scale(cc.v2(5, 5)); // return Vec2 {x: 50, y: 50}; + var v1; + v.scale(cc.v2(5, 5), v1); // return Vec2 {x: 50, y: 50}; + ``` + */ + scale(vector: Vec2, out?: Vec2): Vec2; + /** + !#en Divides by a number. If you want to save result to another vector, use div() instead. + !#zh 向量除法。如果你想结果保存到另一个向量,可使用 div() 代替。 + @param vector vector + + @example + ```js + var v = cc.v2(10, 10); + v.divSelf(5); // return Vec2 {x: 2, y: 2}; + ``` + */ + divSelf(vector: Vec2): Vec2; + /** + !#en Divides by a number, and returns the new result. + !#zh 向量除法,并返回新的结果。 + @param vector vector + @param out optional, the receiving vector + + @example + ```js + var v = cc.v2(10, 10); + v.div(5); // return Vec2 {x: 2, y: 2}; + var v1; + v.div(5, v1); // return Vec2 {x: 2, y: 2}; + ``` + */ + div(vector: Vec2, out?: Vec2): Vec2; + /** + !#en Negates the components. If you want to save result to another vector, use neg() instead. + !#zh 向量取反。如果你想结果保存到另一个向量,可使用 neg() 代替。 + + @example + ```js + var v = cc.v2(10, 10); + v.negSelf(); // return Vec2 {x: -10, y: -10}; + ``` + */ + negSelf(): Vec2; + /** + !#en Negates the components, and returns the new result. + !#zh 返回取反后的新向量。 + @param out optional, the receiving vector + + @example + ```js + var v = cc.v2(10, 10); + var v1; + v.neg(v1); // return Vec2 {x: -10, y: -10}; + ``` + */ + neg(out?: Vec2): Vec2; + /** + !#en Dot product + !#zh 当前向量与指定向量进行点乘。 + @param vector vector + + @example + ```js + var v = cc.v2(10, 10); + v.dot(cc.v2(5, 5)); // return 100; + ``` + */ + dot(vector?: Vec2): number; + /** + !#en Cross product + !#zh 当前向量与指定向量进行叉乘。 + @param vector vector + + @example + ```js + var v = cc.v2(10, 10); + v.cross(cc.v2(5, 5)); // return 0; + ``` + */ + cross(vector?: Vec2): number; + /** + !#en Returns the length of this vector. + !#zh 返回该向量的长度。 + + @example + ```js + var v = cc.v2(10, 10); + v.mag(); // return 14.142135623730951; + ``` + */ + mag(): number; + /** + !#en Returns the squared length of this vector. + !#zh 返回该向量的长度平方。 + + @example + ```js + var v = cc.v2(10, 10); + v.magSqr(); // return 200; + ``` + */ + magSqr(): number; + /** + !#en Make the length of this vector to 1. + !#zh 向量归一化,让这个向量的长度为 1。 + + @example + ```js + var v = cc.v2(10, 10); + v.normalizeSelf(); // return Vec2 {x: 0.7071067811865475, y: 0.7071067811865475}; + ``` + */ + normalizeSelf(): Vec2; + /** + !#en + Returns this vector with a magnitude of 1.
+
+ Note that the current vector is unchanged and a new normalized vector is returned. If you want to normalize the current vector, use normalizeSelf function. + !#zh + 返回归一化后的向量。
+
+ 注意,当前向量不变,并返回一个新的归一化向量。如果你想来归一化当前向量,可使用 normalizeSelf 函数。 + @param out optional, the receiving vector + */ + normalize(out?: Vec2): Vec2; + /** + !#en Get angle in radian between this and vector. + !#zh 夹角的弧度。 + @param vector vector + */ + angle(vector: Vec2): number; + /** + !#en Get angle in radian between this and vector with direction. + !#zh 带方向的夹角的弧度。 + @param vector vector + */ + signAngle(vector: Vec2): number; + /** + !#en rotate + !#zh 返回旋转给定弧度后的新向量。 + @param radians radians + @param out optional, the receiving vector + */ + rotate(radians: number, out?: Vec2): Vec2; + /** + !#en rotate self + !#zh 按指定弧度旋转向量。 + @param radians radians + */ + rotateSelf(radians: number): Vec2; + /** !#en return a Vec2 object with x = 1 and y = 1. + !#zh 新 Vec2 对象。 */ + static ONE: Vec2; + /** !#en return a Vec2 object with x = 0 and y = 0. + !#zh 返回 x = 0 和 y = 0 的 Vec2 对象。 */ + static ZERO: Vec2; + /** !#en return a Vec2 object with x = 0 and y = 1. + !#zh 返回 x = 0 和 y = 1 的 Vec2 对象。 */ + static UP: Vec2; + /** !#en return a Vec2 object with x = 1 and y = 0. + !#zh 返回 x = 1 和 y = 0 的 Vec2 对象。 */ + static RIGHT: Vec2; + } + /** undefined */ + export class PhysicsBoxCollider extends PhysicsCollider implements Collider.Box { + /** !#en Position offset + !#zh 位置偏移量 */ + offset: Vec2; + /** !#en Box size + !#zh 包围盒大小 */ + size: Size; + } + /** undefined */ + export class PhysicsChainCollider extends PolygonCollider { + /** !#en Whether the chain is loop + !#zh 链条是否首尾相连 */ + loop: boolean; + /** !#en Chain points + !#zh 链条顶点数组 */ + points: [Vec2]; + } + /** undefined */ + export class PhysicsCircleCollider extends PhysicsCollider implements Collider.Circle { + /** !#en Position offset + !#zh 位置偏移量 */ + offset: Vec2; + /** !#en Circle radius + !#zh 圆形半径 */ + radius: number; + } + /** undefined */ + export class PhysicsCollider { + /** !#en + The density. + !#zh + 密度 */ + density: number; + /** !#en + A sensor collider collects contact information but never generates a collision response + !#zh + 一个传感器类型的碰撞体会产生碰撞回调,但是不会发生物理碰撞效果。 */ + sensor: boolean; + /** !#en + The friction coefficient, usually in the range [0,1]. + !#zh + 摩擦系数,取值一般在 [0, 1] 之间 */ + friction: number; + /** !#en + The restitution (elasticity) usually in the range [0,1]. + !#zh + 弹性系数,取值一般在 [0, 1]之间 */ + restitution: number; + /** !#en + Physics collider will find the rigidbody component on the node and set to this property. + !#zh + 碰撞体会在初始化时查找节点上是否存在刚体,如果查找成功则赋值到这个属性上。 */ + body: RigidBody; + /** + !#en + Apply current changes to collider, this will regenerate inner box2d fixtures. + !#zh + 应用当前 collider 中的修改,调用此函数会重新生成内部 box2d 的夹具。 + */ + apply(): void; + /** + !#en + Get the world aabb of the collider + !#zh + 获取碰撞体的世界坐标系下的包围盒 + */ + getAABB(): void; + } + /** undefined */ + export class PhysicsPolygonCollider extends PhysicsCollider implements Collider.Polygon { + /** !#en Position offset + !#zh 位置偏移量 */ + offset: Vec2; + /** !#en Polygon points + !#zh 多边形顶点数组 */ + points: [Vec2]; + } + /** !#en + A distance joint constrains two points on two bodies + to remain at a fixed distance from each other. You can view + this as a massless, rigid rod. + !#zh + 距离关节通过一个固定的长度来约束关节链接的两个刚体。你可以将它想象成一个无质量,坚固的木棍。 */ + export class DistanceJoint extends Joint { + /** !#en + The distance separating the two ends of the joint. + !#zh + 关节两端的距离 */ + distance: number; + /** !#en + The spring frequency. + !#zh + 弹性系数。 */ + frequency: number; + /** !#en + The damping ratio. + !#zh + 阻尼,表示关节变形后,恢复到初始状态受到的阻力。 */ + 0: number; + } + /** !#en + Base class for joints to connect rigidbody. + !#zh + 关节类的基类 */ + export class Joint extends Component { + /** !#en + The anchor of the rigidbody. + !#zh + 刚体的锚点。 */ + anchor: Vec2; + /** !#en + The anchor of the connected rigidbody. + !#zh + 关节另一端刚体的锚点。 */ + connectedAnchor: Vec2; + /** !#en + The rigidbody to which the other end of the joint is attached. + !#zh + 关节另一端链接的刚体 */ + connectedBody: RigidBody; + /** !#en + Should the two rigid bodies connected with this joint collide with each other? + !#zh + 链接到关节上的两个刚体是否应该相互碰撞? */ + collideConnected: boolean; + /** + !#en + Apply current changes to joint, this will regenerate inner box2d joint. + !#zh + 应用当前关节中的修改,调用此函数会重新生成内部 box2d 的关节。 + */ + apply(): void; + /** + !#en + Get the anchor point on rigidbody in world coordinates. + !#zh + 获取刚体世界坐标系下的锚点。 + */ + getWorldAnchor(): Vec2; + /** + !#en + Get the anchor point on connected rigidbody in world coordinates. + !#zh + 获取链接刚体世界坐标系下的锚点。 + */ + getWorldConnectedAnchor(): Vec2; + /** + !#en + Gets the reaction force of the joint. + !#zh + 获取关节的反作用力。 + @param timeStep The time to calculate the reaction force for. + */ + getReactionForce(timeStep: number): number; + /** + !#en + Gets the reaction torque of the joint. + !#zh + 获取关节的反扭矩。 + @param timeStep The time to calculate the reaction torque for. + */ + getReactionTorque(timeStep: number): number; + } + /** !#en + A motor joint is used to control the relative motion + between two bodies. A typical usage is to control the movement + of a dynamic body with respect to the ground. + !#zh + 马达关节被用来控制两个刚体间的相对运动。 + 一个典型的例子是用来控制一个动态刚体相对于地面的运动。 */ + export class MotorJoint extends Joint { + /** !#en + The anchor of the rigidbody. + !#zh + 刚体的锚点。 */ + anchor: Vec2; + /** !#en + The anchor of the connected rigidbody. + !#zh + 关节另一端刚体的锚点。 */ + connectedAnchor: Vec2; + /** !#en + The linear offset from connected rigidbody to rigidbody. + !#zh + 关节另一端的刚体相对于起始端刚体的位置偏移量 */ + linearOffset: Vec2; + /** !#en + The angular offset from connected rigidbody to rigidbody. + !#zh + 关节另一端的刚体相对于起始端刚体的角度偏移量 */ + angularOffset: number; + /** !#en + The maximum force can be applied to rigidbody. + !#zh + 可以应用于刚体的最大的力值 */ + maxForce: number; + /** !#en + The maximum torque can be applied to rigidbody. + !#zh + 可以应用于刚体的最大扭矩值 */ + maxTorque: number; + /** !#en + The position correction factor in the range [0,1]. + !#zh + 位置矫正系数,范围为 [0, 1] */ + correctionFactor: number; + } + /** !#en + A mouse joint is used to make a point on a body track a + specified world point. This a soft constraint with a maximum + force. This allows the constraint to stretch and without + applying huge forces. + Mouse Joint will auto register the touch event with the mouse region node, + and move the choosed rigidbody in touch move event. + Note : generally mouse joint only used in test bed. + !#zh + 鼠标关节用于使刚体上的一个点追踪一个指定的世界坐标系下的位置。 + 鼠标关节可以指定一个最大的里来施加一个柔和的约束。 + 鼠标关节会自动使用 mouse region 节点来注册鼠标事件,并且在触摸移动事件中移动选中的刚体。 + 注意:一般鼠标关节只在测试环境中使用。 */ + export class MouseJoint extends Joint { + /** !#en + The anchor of the rigidbody. + !#zh + 刚体的锚点。 */ + anchor: Vec2; + /** !#en + The anchor of the connected rigidbody. + !#zh + 关节另一端刚体的锚点。 */ + connectedAnchor: Vec2; + /** !#en + The node used to register touch evnet. + If this is null, it will be the joint's node. + !#zh + 用于注册触摸事件的节点。 + 如果没有设置这个值,那么将会使用关节的节点来注册事件。 */ + mouseRegion: Node; + /** !#en + The target point. + The mouse joint will move choosed rigidbody to target point. + !#zh + 目标点,鼠标关节将会移动选中的刚体到指定的目标点 */ + target: Vec2; + /** !#en + The spring frequency. + !#zh + 弹簧系数。 */ + frequency: number; + /** !#en + The damping ratio. + !#zh + 阻尼,表示关节变形后,恢复到初始状态受到的阻力。 */ + 0: number; + /** !#en + The maximum force + !#zh + 最大阻力值 */ + maxForce: number; + } + /** !#en + A prismatic joint. This joint provides one degree of freedom: translation + along an axis fixed in rigidbody. Relative rotation is prevented. You can + use a joint limit to restrict the range of motion and a joint motor to + drive the motion or to model joint friction. + !#zh + 移动关节指定了只能在一个方向上移动刚体。 + 你可以开启关节限制来设置刚体运行移动的间距,也可以开启马达来使用关节马达驱动刚体的运行。 */ + export class PrismaticJoint extends Joint { + /** !#en + The local joint axis relative to rigidbody. + !#zh + 指定刚体可以移动的方向。 */ + localAxisA: Vec2; + /** !#en + The reference angle. + !#zh + 相对角度 */ + referenceAngle: number; + /** !#en + Enable joint distance limit? + !#zh + 是否开启关节的距离限制? */ + enableLimit: boolean; + /** !#en + Enable joint motor? + !#zh + 是否开启关节马达? */ + enableMotor: boolean; + /** !#en + The lower joint limit. + !#zh + 刚体能够移动的最小值 */ + lowerLimit: number; + /** !#en + The upper joint limit. + !#zh + 刚体能够移动的最大值 */ + upperLimit: number; + /** !#en + The maxium force can be applied to rigidbody to rearch the target motor speed. + !#zh + 可以施加到刚体的最大力。 */ + maxMotorForce: number; + /** !#en + The expected motor speed. + !#zh + 期望的马达速度。 */ + motorSpeed: number; + } + /** !#en + A revolute joint constrains two bodies to share a common point while they + are free to rotate about the point. The relative rotation about the shared + point is the joint angle. You can limit the relative rotation with + a joint limit that specifies a lower and upper angle. You can use a motor + to drive the relative rotation about the shared point. A maximum motor torque + is provided so that infinite forces are not generated. + !#zh + 旋转关节可以约束两个刚体围绕一个点来进行旋转。 + 你可以通过开启关节限制来限制旋转的最大角度和最小角度。 + 你可以通过开启马达来施加一个扭矩力来驱动这两个刚体在这一点上的相对速度。 */ + export class RevoluteJoint extends Joint { + /** !#en + The reference angle. + An angle between bodies considered to be zero for the joint angle. + !#zh + 相对角度。 + 两个物体之间角度为零时可以看作相等于关节角度 */ + referenceAngle: number; + /** !#en + The lower angle. + !#zh + 角度的最低限制。 */ + lowerAngle: number; + /** !#en + The upper angle. + !#zh + 角度的最高限制。 */ + upperAngle: number; + /** !#en + The maxium torque can be applied to rigidbody to rearch the target motor speed. + !#zh + 可以施加到刚体的最大扭矩。 */ + maxMotorTorque: number; + /** !#en + The expected motor speed. + !#zh + 期望的马达速度。 */ + motorSpeed: number; + /** !#en + Enable joint limit? + !#zh + 是否开启关节的限制? */ + enableLimit: boolean; + /** !#en + Enable joint motor? + !#zh + 是否开启关节马达? */ + enableMotor: boolean; + /** + !#en + Get the joint angle. + !#zh + 获取关节角度。 + */ + getJointAngle(): number; + } + /** !#en + A rope joint enforces a maximum distance between two points + on two bodies. It has no other effect. + Warning: if you attempt to change the maximum length during + the simulation you will get some non-physical behavior. + !#zh + 绳子关节只指定两个刚体间的最大距离,没有其他的效果。 + 注意:如果你试图动态修改关节的长度,这有可能会得到一些意外的效果。 */ + export class RopeJoint extends Joint { + /** !#en + The max length. + !#zh + 最大长度。 */ + maxLength: number; + } + /** !#en + A weld joint essentially glues two bodies together. A weld joint may + distort somewhat because the island constraint solver is approximate. + !#zh + 熔接关节相当于将两个刚体粘在了一起。 + 熔接关节可能会使某些东西失真,因为约束求解器算出的都是近似值。 */ + export class WeldJoint extends Joint { + /** !#en + The reference angle. + !#zh + 相对角度。 */ + referenceAngle: number; + /** !#en + The frequency. + !#zh + 弹性系数。 */ + frequency: number; + /** !#en + The damping ratio. + !#zh + 阻尼,表示关节变形后,恢复到初始状态受到的阻力。 */ + 0: number; + } + /** !#en + A wheel joint. This joint provides two degrees of freedom: translation + along an axis fixed in bodyA and rotation in the plane. You can use a joint motor to drive + the rotation or to model rotational friction. + This joint is designed for vehicle suspensions. + !#zh + 轮子关节提供两个维度的自由度:旋转和沿着指定方向上位置的移动。 + 你可以通过开启关节马达来使用马达驱动刚体的旋转。 + 轮组关节是专门为机动车类型设计的。 */ + export class WheelJoint extends Joint { + /** !#en + The local joint axis relative to rigidbody. + !#zh + 指定刚体可以移动的方向。 */ + localAxisA: Vec2; + /** !#en + The maxium torque can be applied to rigidbody to rearch the target motor speed. + !#zh + 可以施加到刚体的最大扭矩。 */ + maxMotorTorque: number; + /** !#en + The expected motor speed. + !#zh + 期望的马达速度。 */ + motorSpeed: number; + /** !#en + Enable joint motor? + !#zh + 是否开启关节马达? */ + enableMotor: boolean; + /** !#en + The spring frequency. + !#zh + 弹性系数。 */ + frequency: number; + /** !#en + The damping ratio. + !#zh + 阻尼,表示关节变形后,恢复到初始状态受到的阻力。 */ + dampingRatio: number; + } + /**************************************************** + * audioEngine + *****************************************************/ + + export module audioEngine { + /** !#en Audio state. + !#zh 声音播放状态 */ + export enum AudioState { + ERROR = 0, + INITIALZING = 0, + PLAYING = 0, + PAUSED = 0, + } + } + + /**************************************************** + * ParticleSystem + *****************************************************/ + + export module ParticleSystem { + /** !#en Enum for emitter modes + !#zh 发射模式 */ + export enum EmitterMode { + GRAVITY = 0, + RADIUS = 0, + } + } + + /**************************************************** + * ParticleSystem + *****************************************************/ + + export module ParticleSystem { + /** !#en Enum for particles movement type. + !#zh 粒子位置类型 */ + export enum PositionType { + FREE = 0, + RELATIVE = 0, + GROUPED = 0, + } + } + + /**************************************************** + * TiledMap + *****************************************************/ + + export module TiledMap { + /** !#en The orientation of tiled map. + !#zh Tiled Map 地图方向。 */ + export enum Orientation { + ORTHO = 0, + HEX = 0, + ISO = 0, + NONE = 0, + MAP = 0, + LAYER = 0, + OBJECTGROUP = 0, + OBJECT = 0, + TILE = 0, + HORIZONTAL = 0, + VERTICAL = 0, + DIAGONAL = 0, + FLIPPED_ALL = 0, + FLIPPED_MASK = 0, + STAGGERAXIS_X = 0, + STAGGERAXIS_Y = 0, + STAGGERINDEX_ODD = 0, + STAGGERINDEX_EVEN = 0, + } + } + + /**************************************************** + * Node + *****************************************************/ + + export module Node { + /** !#en The event type supported by Node + !#zh Node 支持的事件类型 */ + export class EventType { + /** !#en The event type for touch start event, you can use its value directly: 'touchstart' + !#zh 当手指触摸到屏幕时。 */ + static TOUCH_START: string; + /** !#en The event type for touch move event, you can use its value directly: 'touchmove' + !#zh 当手指在屏幕上目标节点区域内移动时。 */ + static TOUCH_MOVE: string; + /** !#en The event type for touch end event, you can use its value directly: 'touchend' + !#zh 当手指在目标节点区域内离开屏幕时。 */ + static TOUCH_END: string; + /** !#en The event type for touch end event, you can use its value directly: 'touchcancel' + !#zh 当手指在目标节点区域外离开屏幕时。 */ + static TOUCH_CANCEL: string; + /** !#en The event type for mouse down events, you can use its value directly: 'mousedown' + !#zh 当鼠标按下时触发一次。 */ + static MOUSE_DOWN: string; + /** !#en The event type for mouse move events, you can use its value directly: 'mousemove' + !#zh 当鼠标在目标节点在目标节点区域中移动时,不论是否按下。 */ + static MOUSE_MOVE: string; + /** !#en The event type for mouse enter target events, you can use its value directly: 'mouseenter' + !#zh 当鼠标移入目标节点区域时,不论是否按下。 */ + static MOUSE_ENTER: string; + /** !#en The event type for mouse leave target events, you can use its value directly: 'mouseleave' + !#zh 当鼠标移出目标节点区域时,不论是否按下。 */ + static MOUSE_LEAVE: string; + /** !#en The event type for mouse up events, you can use its value directly: 'mouseup' + !#zh 当鼠标从按下状态松开时触发一次。 */ + static MOUSE_UP: string; + /** !#en The event type for mouse wheel events, you can use its value directly: 'mousewheel' + !#zh 当鼠标滚轮滚动时。 */ + static MOUSE_WHEEL: string; + } + } + + /**************************************************** + * Collider + *****************************************************/ + + export module Collider { + /** !#en Defines a Box Collider . + !#zh 用来定义包围盒碰撞体 */ + export class Box { + /** !#en Position offset + !#zh 位置偏移量 */ + offset: Vec2; + /** !#en Box size + !#zh 包围盒大小 */ + size: Size; + } + } + + /**************************************************** + * Collider + *****************************************************/ + + export module Collider { + /** !#en Defines a Circle Collider . + !#zh 用来定义圆形碰撞体 */ + export class Circle { + /** !#en Position offset + !#zh 位置偏移量 */ + offset: Vec2; + /** !#en Circle radius + !#zh 圆形半径 */ + radius: number; + } + } + + /**************************************************** + * Collider + *****************************************************/ + + export module Collider { + /** !#en Defines a Polygon Collider . + !#zh 用来定义多边形碰撞体 */ + export class Polygon { + /** !#en Position offset + !#zh 位置偏移量 */ + offset: Vec2; + /** !#en Polygon points + !#zh 多边形顶点数组 */ + points: [Vec2]; + } + } + + /**************************************************** + * Button + *****************************************************/ + + export module Button { + /** !#en Enum for transition type. + !#zh 过渡类型 */ + export enum Transition { + NONE = 0, + COLOR = 0, + SPRITE = 0, + SCALE = 0, + } + } + + /**************************************************** + * Component + *****************************************************/ + + export module Component { + /** !#en + Component will register a event to target component's handler. + And it will trigger the handler when a certain event occurs. + + !@zh + “EventHandler” 类用来设置场景中的事件回调, + 该类允许用户设置回调目标节点,目标组件名,组件方法名, + 并可通过 emit 方法调用目标函数。 */ + export class EventHandler { + /** !#en Event target + !#zh 目标节点 */ + target: Node; + /** !#en Component name + !#zh 目标组件名 */ + component: string; + /** !#en Event handler + !#zh 响应事件函数名 */ + handler: string; + /** !#en Custom Event Data + !#zh 自定义事件数据 */ + customEventData: string; + /** + + @param events events + @param params params + */ + static emitEvents(events: Component.EventHandler[], ...params: any[]): void; + /** + !#en Emit event with params + !#zh 触发目标组件上的指定 handler 函数,该参数是回调函数的参数值(可不填)。 + @param params params + + @example + ```js + // Call Function + var eventHandler = new cc.Component.EventHandler(); + eventHandler.target = newTarget; + eventHandler.component = "MainMenu"; + eventHandler.handler = "OnClick" + eventHandler.emit(["param1", "param2", ....]); + ``` + */ + emit(params: any[]): void; + } + } + + /**************************************************** + * EditBox + *****************************************************/ + + export module EditBox { + /** !#en Enum for keyboard return types + !#zh 键盘的返回键类型 */ + export enum KeyboardReturnType { + DEFAULT = 0, + DONE = 0, + SEND = 0, + SEARCH = 0, + GO = 0, + } + } + + /**************************************************** + * EditBox + *****************************************************/ + + export module EditBox { + /** !#en The EditBox's InputMode defines the type of text that the user is allowed to enter. + !#zh 输入模式 */ + export enum InputMode { + ANY = 0, + EMAIL_ADDR = 0, + NUMERIC = 0, + PHONE_NUMBER = 0, + URL = 0, + DECIMAL = 0, + SINGLE_LINE = 0, + } + } + + /**************************************************** + * EditBox + *****************************************************/ + + export module EditBox { + /** !#en Enum for the EditBox's input flags + !#zh 定义了一些用于设置文本显示和文本格式化的标志位。 */ + export enum InputFlag { + PASSWORD = 0, + SENSITIVE = 0, + INITIAL_CAPS_WORD = 0, + INITIAL_CAPS_SENTENCE = 0, + INITIAL_CAPS_ALL_CHARACTERS = 0, + } + } + + /**************************************************** + * Label + *****************************************************/ + + export module Label { + /** !#en Enum for text alignment. + !#zh 文本横向对齐类型 */ + export enum HorizontalAlign { + LEFT = 0, + CENTER = 0, + RIGHT = 0, + } + } + + /**************************************************** + * Label + *****************************************************/ + + export module Label { + /** !#en Enum for vertical text alignment. + !#zh 文本垂直对齐类型 */ + export enum VerticalAlign { + TOP = 0, + CENTER = 0, + BOTTOM = 0, + } + } + + /**************************************************** + * Label + *****************************************************/ + + export module Label { + /** !#en Enum for Overflow. + !#zh Overflow 类型 */ + export enum Overflow { + NONE = 0, + CLAMP = 0, + SHRINK = 0, + RESIZE_HEIGHT = 0, + } + } + + /**************************************************** + * Label + *****************************************************/ + + export module Label { + /** !#en Enum for font type. + !#zh Type 类型 */ + export enum Type { + TTF = 0, + BMFont = 0, + SystemFont = 0, + } + } + + /**************************************************** + * Layout + *****************************************************/ + + export module Layout { + /** !#en Enum for Layout type + !#zh 布局类型 */ + export enum Type { + NONE = 0, + HORIZONTAL = 0, + VERTICAL = 0, + GRID = 0, + } + } + + /**************************************************** + * Layout + *****************************************************/ + + export module Layout { + /** !#en Enum for Layout Resize Mode + !#zh 缩放模式 */ + export enum ResizeMode { + NONE = 0, + CONTAINER = 0, + CHILDREN = 0, + } + } + + /**************************************************** + * Layout + *****************************************************/ + + export module Layout { + /** !#en Enum for Grid Layout start axis direction. + The items in grid layout will be arranged in each axis at first.; + !#zh 布局轴向,只用于 GRID 布局。 */ + export enum AxisDirection { + HORIZONTAL = 0, + VERTICAL = 0, + } + } + + /**************************************************** + * Layout + *****************************************************/ + + export module Layout { + /** !#en Enum for vertical layout direction. + Used in Grid Layout together with AxisDirection is VERTICAL + !#zh 垂直方向布局方式 */ + export enum VerticalDirection { + BOTTOM_TO_TOP = 0, + TOP_TO_BOTTOM = 0, + } + } + + /**************************************************** + * Layout + *****************************************************/ + + export module Layout { + /** !#en Enum for horizontal layout direction. + Used in Grid Layout together with AxisDirection is HORIZONTAL + !#zh 水平方向布局方式 */ + export enum HorizontalDirection { + LEFT_TO_RIGHT = 0, + RIGHT_TO_LEFT = 0, + } + } + + /**************************************************** + * Mask + *****************************************************/ + + export module Mask { + /** !#en the type for mask. + !#zh 遮罩组件类型 */ + export enum Type { + RECT = 0, + ELLIPSE = 0, + IMAGE_STENCIL = 0, + } + } + + /**************************************************** + * PageView + *****************************************************/ + + export module PageView { + /** !#en The Page View Size Mode + !#zh 页面视图每个页面统一的大小类型 */ + export enum SizeMode { + Unified = 0, + Free = 0, + } + } + + /**************************************************** + * PageView + *****************************************************/ + + export module PageView { + /** !#en The Page View Direction + !#zh 页面视图滚动类型 */ + export enum Direction { + Horizontal = 0, + Vertical = 0, + } + } + + /**************************************************** + * PageView + *****************************************************/ + + export module PageView { + /** !#en Enum for ScrollView event type. + !#zh 滚动视图事件类型 */ + export enum EventType { + PAGE_TURNING = 0, + } + } + + /**************************************************** + * PageViewIndicator + *****************************************************/ + + export module PageViewIndicator { + /** !#en Enum for PageView Indicator direction + !#zh 页面视图指示器的摆放方向 */ + export enum Direction { + HORIZONTAL = 0, + VERTICAL = 0, + } + } + + /**************************************************** + * ProgressBar + *****************************************************/ + + export module ProgressBar { + /** !#en Enum for ProgressBar mode + !#zh 进度条模式 */ + export enum Mode { + HORIZONTAL = 0, + VERTICAL = 0, + FILLED = 0, + } + } + + /**************************************************** + * Scrollbar + *****************************************************/ + + export module Scrollbar { + /** Enum for Scrollbar direction */ + export enum Direction { + HORIZONTAL = 0, + VERTICAL = 0, + } + } + + /**************************************************** + * ScrollView + *****************************************************/ + + export module ScrollView { + /** !#en Enum for ScrollView event type. + !#zh 滚动视图事件类型 */ + export enum EventType { + SCROLL_TO_TOP = 0, + SCROLL_TO_BOTTOM = 0, + SCROLL_TO_LEFT = 0, + SCROLL_TO_RIGHT = 0, + SCROLLING = 0, + BOUNCE_TOP = 0, + BOUNCE_BOTTOM = 0, + BOUNCE_LEFT = 0, + BOUNCE_RIGHT = 0, + SCROLL_ENDED = 0, + TOUCH_UP = 0, + AUTOSCROLL_ENDED_WITH_THRESHOLD = 0, + SCROLL_BEGAN = 0, + } + } + + /**************************************************** + * Slider + *****************************************************/ + + export module Slider { + /** !#en The Slider Direction + !#zh 滑动器方向 */ + export enum Direction { + Horizontal = 0, + Vertical = 0, + } + } + + /**************************************************** + * Sprite + *****************************************************/ + + export module Sprite { + /** !#en Enum for sprite type. + !#zh Sprite 类型 */ + export enum Type { + SIMPLE = 0, + SLICED = 0, + TILED = 0, + FILLED = 0, + } + } + + /**************************************************** + * Sprite + *****************************************************/ + + export module Sprite { + /** !#en Enum for fill type. + !#zh 填充类型 */ + export enum FillType { + HORIZONTAL = 0, + VERTICAL = 0, + RADIAL = 0, + } + } + + /**************************************************** + * Sprite + *****************************************************/ + + export module Sprite { + /** !#en Sprite Size can track trimmed size, raw size or none. + !#zh 精灵尺寸调整模式 */ + export enum SizeMode { + CUSTOM = 0, + TRIMMED = 0, + RAW = 0, + } + } + + /**************************************************** + * VideoPlayer + *****************************************************/ + + export module VideoPlayer { + /** !#en Video event type + !#zh 视频事件类型 */ + export enum EventType { + PLAYING = 0, + PAUSED = 0, + STOPPED = 0, + COMPLETED = 0, + } + } + + /**************************************************** + * VideoPlayer + *****************************************************/ + + export module VideoPlayer { + /** !#en Enum for video resouce type type. + !#zh 视频来源 */ + export enum ResourceType { + REMOTE = 0, + LOCAL = 0, + } + } + + /**************************************************** + * WebView + *****************************************************/ + + export module WebView { + /** !#en WebView event type + !#zh 网页视图事件类型 */ + export enum EventType { + LOADED = 0, + LOADING = 0, + ERROR = 0, + } + } + + /**************************************************** + * Event + *****************************************************/ + + export module Event { + /** !#en The Custom event + !#zh 自定义事件 */ + export class EventCustom extends Event { + /** + + @param type The name of the event (case-sensitive), e.g. "click", "fire", or "submit" + @param bubbles A boolean indicating whether the event bubbles up through the tree or not + */ + constructor(type: string, bubbles: boolean); + /** !#en A reference to the detailed data of the event + !#zh 事件的详细数据 */ + detail: any; + /** + !#en Sets user data + !#zh 设置用户数据 + @param data data + */ + setUserData(data: any): void; + /** + !#en Gets user data + !#zh 获取用户数据 + */ + getUserData(): any; + /** + !#en Gets event name + !#zh 获取事件名称 + */ + getEventName(): string; + } + } + + /**************************************************** + * Event + *****************************************************/ + + export module Event { + /** !#en The mouse event + !#zh 鼠标事件类型 */ + export class EventMouse extends Event { + /** + !#en Sets scroll data. + !#zh 设置鼠标的滚动数据。 + @param scrollX scrollX + @param scrollY scrollY + */ + setScrollData(scrollX: number, scrollY: number): void; + /** + !#en Returns the x axis scroll value. + !#zh 获取鼠标滚动的X轴距离,只有滚动时才有效。 + */ + getScrollX(): number; + /** + !#en Returns the y axis scroll value. + !#zh 获取滚轮滚动的 Y 轴距离,只有滚动时才有效。 + */ + getScrollY(): number; + /** + !#en Sets cursor location. + !#zh 设置当前鼠标位置。 + @param x x + @param y y + */ + setLocation(x: number, y: number): void; + /** + !#en Returns cursor location. + !#zh 获取鼠标位置对象,对象包含 x 和 y 属性。 + */ + getLocation(): Vec2; + /** + !#en Returns the current cursor location in screen coordinates. + !#zh 获取当前事件在游戏窗口内的坐标位置对象,对象包含 x 和 y 属性。 + */ + getLocationInView(): Vec2; + /** + !#en Returns the previous touch location. + !#zh 获取鼠标点击在上一次事件时的位置对象,对象包含 x 和 y 属性。 + */ + getPreviousLocation(): Vec2; + /** + !#en Returns the delta distance from the previous location to current location. + !#zh 获取鼠标距离上一次事件移动的距离对象,对象包含 x 和 y 属性。 + */ + getDelta(): Vec2; + /** + !#en Returns the X axis delta distance from the previous location to current location. + !#zh 获取鼠标距离上一次事件移动的 X 轴距离。 + */ + getDeltaX(): number; + /** + !#en Returns the Y axis delta distance from the previous location to current location. + !#zh 获取鼠标距离上一次事件移动的 Y 轴距离。 + */ + getDeltaY(): number; + /** + !#en Sets mouse button. + !#zh 设置鼠标按键。 + @param button button + */ + setButton(button: number): void; + /** + !#en Returns mouse button. + !#zh 获取鼠标按键。 + */ + getButton(): number; + /** + !#en Returns location X axis data. + !#zh 获取鼠标当前位置 X 轴。 + */ + getLocationX(): number; + /** + !#en Returns location Y axis data. + !#zh 获取鼠标当前位置 Y 轴。 + */ + getLocationY(): number; + /** !#en The none event code of mouse event. + !#zh 无。 */ + static NONE: number; + /** !#en The event type code of mouse down event. + !#zh 鼠标按下事件。 */ + static DOWN: number; + /** !#en The event type code of mouse up event. + !#zh 鼠标按下后释放事件。 */ + static UP: number; + /** !#en The event type code of mouse move event. + !#zh 鼠标移动事件。 */ + static MOVE: number; + /** !#en The event type code of mouse scroll event. + !#zh 鼠标滚轮事件。 */ + static SCROLL: number; + /** !#en The tag of Mouse left button. + !#zh 鼠标左键的标签。 */ + static BUTTON_LEFT: number; + /** !#en The tag of Mouse right button (The right button number is 2 on browser). + !#zh 鼠标右键的标签。 */ + static BUTTON_RIGHT: number; + /** !#en The tag of Mouse middle button (The right button number is 1 on browser). + !#zh 鼠标中键的标签。 */ + static BUTTON_MIDDLE: number; + /** !#en The tag of Mouse button 4. + !#zh 鼠标按键 4 的标签。 */ + static BUTTON_4: number; + /** !#en The tag of Mouse button 5. + !#zh 鼠标按键 5 的标签。 */ + static BUTTON_5: number; + /** !#en The tag of Mouse button 6. + !#zh 鼠标按键 6 的标签。 */ + static BUTTON_6: number; + /** !#en The tag of Mouse button 7. + !#zh 鼠标按键 7 的标签。 */ + static BUTTON_7: number; + /** !#en The tag of Mouse button 8. + !#zh 鼠标按键 8 的标签。 */ + static BUTTON_8: number; + } + } + + /**************************************************** + * Event + *****************************************************/ + + export module Event { + /** !#en The touch event + !#zh 触摸事件 */ + export class EventTouch extends Event { + /** + + @param touchArr The array of the touches + @param bubbles A boolean indicating whether the event bubbles up through the tree or not + */ + constructor(touchArr: any[], bubbles: boolean); + /** !#en The current touch object + !#zh 当前触点对象 */ + touch: Touch; + /** + !#en Returns event code. + !#zh 获取事件类型。 + */ + getEventCode(): number; + /** + !#en Returns touches of event. + !#zh 获取触摸点的列表。 + */ + getTouches(): any[]; + /** + !#en Sets touch location. + !#zh 设置当前触点位置 + @param x x + @param y y + */ + setLocation(x: number, y: number): void; + /** + !#en Returns touch location. + !#zh 获取触点位置。 + */ + getLocation(): Vec2; + /** + !#en Returns the current touch location in screen coordinates. + !#zh 获取当前触点在游戏窗口中的位置。 + */ + getLocationInView(): Vec2; + /** + !#en Returns the previous touch location. + !#zh 获取触点在上一次事件时的位置对象,对象包含 x 和 y 属性。 + */ + getPreviousLocation(): Vec2; + /** + !#en Returns the start touch location. + !#zh 获获取触点落下时的位置对象,对象包含 x 和 y 属性。 + */ + getStartLocation(): Vec2; + /** + !#en Returns the id of cc.Touch. + !#zh 触点的标识 ID,可以用来在多点触摸中跟踪触点。 + */ + getID(): number; + /** + !#en Returns the delta distance from the previous location to current location. + !#zh 获取触点距离上一次事件移动的距离对象,对象包含 x 和 y 属性。 + */ + getDelta(): Vec2; + /** + !#en Returns the X axis delta distance from the previous location to current location. + !#zh 获取触点距离上一次事件移动的 x 轴距离。 + */ + getDeltaX(): number; + /** + !#en Returns the Y axis delta distance from the previous location to current location. + !#zh 获取触点距离上一次事件移动的 y 轴距离。 + */ + getDeltaY(): number; + /** + !#en Returns location X axis data. + !#zh 获取当前触点 X 轴位置。 + */ + getLocationX(): number; + /** + !#en Returns location Y axis data. + !#zh 获取当前触点 Y 轴位置。 + */ + getLocationY(): number; + } + } + + /**************************************************** + * Event + *****************************************************/ + + export module Event { + /** !#en The acceleration event + !#zh 加速度事件 */ + export class EventAcceleration extends Event { + } + } + + /**************************************************** + * Event + *****************************************************/ + + export module Event { + /** !#en The keyboard event + !#zh 键盘事件 */ + export class EventKeyboard extends Event { + } + } + + /**************************************************** + * SystemEvent + *****************************************************/ + + export module SystemEvent { + /** !#en The event type supported by SystemEvent + !#zh SystemEvent 支持的事件类型 */ + export class EventType { + /** !#en The event type for press the key down event, you can use its value directly: 'keydown' + !#zh 当按下按键时触发的事件 */ + static KEY_DOWN: string; + /** !#en The event type for press the key up event, you can use its value directly: 'keyup' + !#zh 当松开按键时触发的事件 */ + static KEY_UP: string; + /** !#en The event type for press the devicemotion event, you can use its value directly: 'devicemotion' + !#zh 重力感应 */ + static DEVICEMOTION: string; + } + } + + /**************************************************** + * Graphics + *****************************************************/ + + export module Graphics { + /** !#en Enum for LineCap. + !#zh 线段末端属性 */ + export enum LineCap { + BUTT = 0, + ROUND = 0, + SQUARE = 0, + } + } + + /**************************************************** + * Graphics + *****************************************************/ + + export module Graphics { + /** !#en Enum for LineJoin. + !#zh 线段拐角属性 */ + export enum LineJoin { + BEVEL = 0, + ROUND = 0, + MITER = 0, + } + } + + /**************************************************** + * Pipeline + *****************************************************/ + + export module Pipeline { + /** The downloader pipe, it can download several types of files: + 1. Text + 2. Image + 3. Script + 4. Audio + 5. Assets + All unknown type will be downloaded as plain text. + You can pass custom supported types in the constructor. */ + export class Downloader { + /** + Constructor of Downloader, you can pass custom supported types. + @param extMap Custom supported types with corresponded handler + + @example + ```js + var downloader = new Downloader({ + // This will match all url with `.scene` extension or all url with `scene` type + 'scene' : function (url, callback) {} + }); + ``` + */ + constructor(extMap: any); + /** + Add custom supported types handler or modify existing type handler. + @param extMap Custom supported types with corresponded handler + */ + addHandlers(extMap: any): void; + } + } + + /**************************************************** + * Pipeline + *****************************************************/ + + export module Pipeline { + /** The loader pipe, it can load several types of files: + 1. Images + 2. JSON + 3. Plist + 4. Audio + 5. Font + 6. Cocos Creator scene + It will not interfere with items of unknown type. + You can pass custom supported types in the constructor. */ + export class Loader { + /** + Constructor of Loader, you can pass custom supported types. + @param extMap Custom supported types with corresponded handler + + @example + ```js + var loader = new Loader({ + // This will match all url with `.scene` extension or all url with `scene` type + 'scene' : function (url, callback) {} + }); + ``` + */ + constructor(extMap: any); + /** + Add custom supported types handler or modify existing type handler. + @param extMap Custom supported types with corresponded handler + */ + addHandlers(extMap: any): void; + } + } + + /**************************************************** + * LoadingItems + *****************************************************/ + + export module LoadingItems { + /** !#en The item states of the LoadingItems, its value could be LoadingItems.ItemState.WORKING | LoadingItems.ItemState.COMPLETET | LoadingItems.ItemState.ERROR + !#zh LoadingItems 队列中的加载项状态,状态的值可能是 LoadingItems.ItemState.WORKING | LoadingItems.ItemState.COMPLETET | LoadingItems.ItemState.ERROR */ + export enum ItemState { + WORKING = 0, + COMPLETET = 0, + ERROR = 0, + } + } + + /**************************************************** + * Texture2D + *****************************************************/ + + export module Texture2D { + /** The texture pixel format, default value is RGBA8888 */ + export enum PixelFormat { + RGB565 = 0, + RGB5A1 = 0, + RGBA4444 = 0, + RGB888 = 0, + RGBA8888 = 0, + A8 = 0, + I8 = 0, + AI88 = 0, + } + } + + /**************************************************** + * Texture2D + *****************************************************/ + + export module Texture2D { + /** The texture wrap mode */ + export enum WrapMode { + REPEAT = 0, + CLAMP_TO_EDGE = 0, + MIRRORED_REPEAT = 0, + } + } + + /**************************************************** + * Texture2D + *****************************************************/ + + export module Texture2D { + /** The texture filter mode */ + export enum Filter { + LINEAR = 0, + NEAREST = 0, + } + } + +} + +/** !#en +AnySDK is a third party solution that offers game developers SDK integration without making changes to the SDK's features or parameters.It can do all of this while remaining invisible to your end user.Our goal is to handle all the tedious SDK integration work for you so that you can use your time to focus on the game itself.No matter if it’s the channel SDK, user system, payment system, ad system, statistics system, sharing system or any other type of SDK: we’ll take care of it for you. +!#zh +AnySDK 为 CP 提供一套第三方 SDK 接入解决方案,整个接入过程,不改变任何 SDK 的功能、特性、参数等,对于最终玩家而言是完全透明无感知的。 +目的是让 CP 商能有更多时间更专注于游戏本身的品质,所有 SDK 的接入工作统统交给我们吧。第三方 SDK 包括了渠道SDK、用户系统、支付系统、广告系统、统计系统、分享系统等等。 */ +declare module anysdk { + /** !#en + agent manager of plugin + !#zh + 插件管理对象 */ + export var agentManager: anysdk.AgentManager; + /** !#en + agent manager of plugin + !#zh + 插件管理类 */ + export class AgentManager { + /** + !#en + AppKey appSecret and privateKey are the only three parameters generated + after the packing tool client finishes creating the game. + The oauthLoginServer parameter is the API address provided by the game service + to login verification + !#zh + appKey、appSecret、privateKey是通过 AnySDK 客户端工具创建游戏后生成的。 + oauthLoginServer参数是游戏服务提供的用来做登陆验证转发的接口地址。 + @param appKey appKey + @param appSecret appSecret + @param privateKey privateKey + @param oauthLoginServer oauthLoginServer + */ + init(appKey: string, appSecret: string, privateKey: string, oauthLoginServer: string): void; + /** + !#en + load all plugins, the operation includes SDK`s initialization + !#zh + 加载所有插件,该操作包含了 SDKs 初始化 + @param callback callback + @param target The object to bind to. + */ + loadAllPlugins(callback: Function, target: any): void; + /** + !#en + unload all plugins + !#zh + 卸载插件 + */ + unloadAllPlugins(): void; + /** + !#en + get user system plugin + !#zh + 获取用户系统插件 + */ + getUserPlugin(): anysdk.ProtocolUser; + /** + !#en + get IAP system plugins + !#zh + 获取支付系统插件 + */ + getIAPPlugins(): anysdk.ProtocolIAP[]; + /** + !#en + get IAP system plugin + !#zh + 获取支付系统插件 + */ + getIAPPlugin(): anysdk.ProtocolIAP; + /** + !#en + get social system plugin + !#zh + 获取社交系统插件 + */ + getSocialPlugin(): anysdk.ProtocolSocial; + /** + !#en + get share system plugin + !#zh + 获取分享系统插件 + */ + getSharePlugin(): anysdk.ProtocolShare; + /** + !#en + get analytics system plugin + !#zh + 获取统计系统插件 + */ + getAnalyticsPlugin(): anysdk.ProtocolAnalytics; + /** + !#en + get ads system plugin + !#zh + 获取广告系统插件 + */ + getAdsPlugin(): anysdk.ProtocolAds; + /** + !#en + get push system plugin + !#zh + 获取推送系统插件 + */ + getPushPlugin(): anysdk.ProtocolPush; + /** + !#en + get REC system plugin + !#zh + 获取录屏系统插件 + */ + getRECPlugin(): anysdk.ProtocolREC; + /** + !#en + get crash system plugin + !#zh + 获取崩溃分析系统插件 + */ + getCrashPlugin(): anysdk.ProtocolCrash; + /** + !#en + get ad track system plugin + !#zh + 获取广告追踪系统插件 + */ + getAdTrackingPlugin(): anysdk.ProtocolAdTracking; + /** + !#en + get custom system plugin + !#zh + 获取自定义系统插件 + */ + getCustomPlugin(): anysdk.ProtocolCustom; + /** + !#en + get custom parameter + !#zh + 获取自定义参数 + */ + getCustomParam(): string; + /** + !#en + get channel id + !#zh + 获取渠道唯一表示符 + */ + getChannelId(): string; + /** + !#en + get status of analytics + !#zh + 获取统计状态 + */ + isAnaylticsEnabled(): boolean; + /** + !#en + set whether to analytics + !#zh + 设置是否统计 + @param enabled enabled + */ + setIsAnaylticsEnabled(enabled: boolean): void; + /** + !#en + destory instance + !#zh + 销毁单例 + */ + static end(): void; + /** + !#en + get instance + !#zh + 获取单例 + */ + static getInstance(): anysdk.AgentManager; + } + /** !#en + plugin protocol + !#zh + 插件协议 */ + export class PluginProtocol { + /** + !#en + Check whether the function is supported + !#zh + 判断函数是否支持 + @param functionName functionName + */ + isFunctionSupported(functionName: string): boolean; + /** + !#en + get plugin name + !#zh + 获取插件名称 + */ + getPluginName(): string; + /** + !#en + get plugin version + !#zh + 获取插件版本 + */ + getPluginVersion(): string; + /** + !#en + get SDK version + !#zh + 获取 SDK 版本 + */ + getSDKVersion(): string; + /** + !#en + void methods for reflections with parameter + !#zh + 反射调用带参数的void方法 + @param funName funName + @param args optional arguments + */ + callFuncWithParam(funName: string, ...args: any|anysdk.PluginParam[]): void; + /** + !#en + String methods for reflections with parameter + !#zh + 反射调用带参数的 String 方法 + @param funName funName + @param args optional arguments + */ + callStringFuncWithParam(funName: string, ...args: any|anysdk.PluginParam[]): string; + /** + !#en + int methods for reflections with parameter + !#zh + 反射调用带参数的 Int 方法 + @param funName funName + @param args optional arguments + */ + callIntFuncWithParam(funName: string, ...args: any|anysdk.PluginParam[]): number; + /** + !#en + boolean methods for reflections with parameter + !#zh + 反射调用带参数的 boolean 方法 + @param funName funName + @param args optional arguments + */ + callBoolFuncWithParam(funName: string, ...args: any|anysdk.PluginParam[]): boolean; + /** + !#en + float methods for reflections with parameter + !#zh + 反射调用带参数的 float 方法 + @param funName funName + @param args optional arguments + */ + callFloatFuncWithParam(funName: string, ...args: any|anysdk.PluginParam[]): number; + } + /** !#en + user protocol + !#zh + 用户系统协议接口 */ + export class ProtocolUser extends PluginProtocol { + /** + !#en + login interface + !#zh + 登录接口 + @param args optional arguments + */ + login(...args: string|any[]): void; + /** + !#en + get status of login + !#zh + 获取登录状态 + */ + isLogined(): boolean; + /** + !#en + get user ID + !#zh + 获取用户唯一标示符 + */ + getUserID(): string; + /** + !#en + get plugin ID + !#zh + 获取插件ID + */ + getPluginId(): string; + /** + !#en + set listener + !#zh + 设置用户系统的监听 + @param listener listener + @param target target + */ + setListener(listener: Function, target: any): void; + /** + !#en + get listener + !#zh + 获取用户系统的监听 + */ + getListener(): Function; + /** + !#en + logout + Before to invoke, you need to verdict whether this properties existed + !#zh + 登出,调用前需要判断属性是否存在 + */ + logout(): void; + /** + !#en + show toolbar + Before to invoke, you need to verdict whether this properties existed + !#zh + 显示悬浮窗,调用前需要判断属性是否存在 + @param place place + */ + showToolBar(place: anysdk.ToolBarPlace): void; + /** + !#en + hide toolbar + Before to invoke, you need to verdict whether this properties existed + !#zh + 隐藏悬浮窗,调用前需要判断属性是否存在 + */ + hideToolBar(): void; + /** + !#en + enter platform + Before to invoke, you need to verdict whether this properties existed + !#zh + 显示平台中心,调用前需要判断属性是否存在 + */ + enterPlatform(): void; + /** + !#en + show exit page + Before to invoke, you need to verdict whether this properties existed + !#zh + 显示退出界面,调用前需要判断属性是否存在 + */ + exit(): void; + /** + !#en + show pause page + Before to invoke, you need to verdict whether this properties existed + !#zh + 显示暂停界面,调用前需要判断属性是否存在 + */ + pause(): void; + /** + !#en + Real-name registration + Before to invoke, you need to verdict whether this properties existed + !#zh + 实名注册,调用前需要判断属性是否存在 + */ + realNameRegister(): void; + /** + !#en + Anti-addiction query + Before to invoke, you need to verdict whether this properties existed + !#zh + 防沉迷查询,调用前需要判断属性是否存在 + */ + antiAddictionQuery(): void; + /** + !#en + submit game role information + Before to invoke, you need to verdict whether this properties existed + !#zh + 提交角色信息,调用前需要判断属性是否存在 + @param data data + */ + submitLoginGameRole(data: any): void; + /** + !#en + get user information + Before to invoke, you need to verdict whether this properties existed + !#zh + 获取用户信息,调用前需要判断属性是否存在 + @param info info + */ + getUserInfo(info: any): void; + /** + !#en + set login type + Before to invoke, you need to verdict whether this properties existed + !#zh + 设置登录类型,调用前需要判断属性是否存在 + @param info info + */ + getAvailableLoginType(info: any): void; + /** + !#en + set login type + Before to invoke, you need to verdict whether this properties existed + !#zh + 设置登录类型,调用前需要判断属性是否存在 + @param loginType loginType + */ + setLoginType(loginType: string): void; + /** + !#en + send to desktop + Before to invoke, you need to verdict whether this properties existed + !#zh + 发送到桌面,调用前需要判断属性是否存在 + */ + sendToDesktop(): void; + /** + !#en + open bbs + Before to invoke, you need to verdict whether this properties existed + !#zh + 打开论坛,调用前需要判断属性是否存在 + */ + openBBS(): void; + } + /** !#en + IAP protocol + !#zh + 支付系统协议接口 */ + export class ProtocolIAP extends PluginProtocol { + /** + !#en + pay interface + !#zh + 支付接口 + @param info Type:map + */ + payForProduct(info: any): void; + /** + !#en + get order ID + !#zh + 获取订单ID + */ + getOrderId(): string; + /** + !#en + reset the pay status + !#zh + 重置支付状态 + */ + static resetPayState(): void; + /** + !#en + get plugin ID + !#zh + 获取插件ID + */ + getPluginId(): string; + /** + !#en + set listener + !#zh + 设置支付系统的监听 + @param listener listener + @param target target + */ + setListener(listener: Function, target: any): void; + /** + !#en + get listener + !#zh + 获取支付系统的监听 + */ + getListener(): Function; + } + /** !#en + analytics protocol + !#zh + 统计系统协议接口 */ + export class ProtocolAnalytics extends PluginProtocol { + /** + !#en + Start a new session. + !#zh + 启动会话 + */ + startSession(): void; + /** + !#en + Stop a session. + !#zh + 关闭会话 + */ + stopSession(): void; + /** + !#en + Set the timeout for expiring a session. + !#zh + 设置会话超时时间 + @param millis Type: long + */ + setSessionContinueMillis(millis: number): void; + /** + !#en + log an error + !#zh + 捕捉异常 + @param errorId errorId + @param message message + */ + logError(errorId: string, message: string): void; + /** + !#en + log an event. + !#zh + 捕捉事件 + @param errorId errorId + @param args optional arguments Type: map + */ + logEvent(errorId: string, ...args: any[]): void; + /** + !#en + Track an event begin. + !#zh + 统计事件开始 + @param eventId eventId + */ + logTimedEventBegin(eventId: string): void; + /** + !#en + Track an event end. + !#zh + 统计事件结束 + @param eventId eventId + */ + logTimedEventEnd(eventId: string): void; + /** + !#en + set Whether to catch uncaught exceptions to server. + !#zh + 设置是否开启自动异常捕捉 + @param enabled enabled + */ + setCaptureUncaughtException(enabled: boolean): void; + /** + !#en + analytics account information + !#zh + 统计玩家帐户信息 + @param paramMap Type: map + */ + setAccount(paramMap: any): void; + /** + !#en + track user to request payment + !#zh + 跟踪用户支付请求 + @param paramMap Type: map + */ + onChargeRequest(paramMap: any): void; + /** + !#en + track Successful payment + !#zh + 追踪用户支付成功 + @param orderID orderID + */ + onChargeSuccess(orderID: string): void; + /** + !#en + track failed payment + !#zh + 追踪用户支付失败 + @param paramMap Type: map + */ + onChargeFail(paramMap: any): void; + /** + !#en + track Successful payment + !#zh + 统计玩家支付成功 + @param paramMap Type: map + */ + onChargeOnlySuccess(paramMap: any): void; + /** + !#en + track user purchase + !#zh + 统计玩家消费 + @param paramMap Type: map + */ + onPurchase(paramMap: any): void; + /** + !#en + track user to use goods + !#zh + 统计玩家使用道具 + @param paramMap Type: map + */ + onUse(paramMap: any): void; + /** + !#en + track user to reward goods + !#zh + 统计玩家获取奖励 + @param paramMap Type: map + */ + onReward(paramMap: any): void; + /** + !#en + start level + !#zh + 开始关卡 + @param paramMap Type: map + */ + startLevel(paramMap: any): void; + /** + !#en + finish level + !#zh + 结束关卡 + @param levelID levelID + */ + finishLevel(levelID: string): void; + /** + !#en + failed level + !#zh + 关卡失败 + @param paramMap Type: map + */ + failLevel(paramMap: any): void; + /** + !#en + start task + !#zh + 开始任务 + @param paramMap Type: map + */ + startTask(paramMap: any): void; + /** + !#en + finish task + !#zh + 完成任务 + @param taskID taskID + */ + finishTask(taskID: string): void; + /** + !#en + failed task + !#zh + 任务失败 + @param paramMap Type: map + */ + failTask(paramMap: any): void; + } + /** !#en + share protocol + !#zh + 分享系统协议接口 */ + export class ProtocolShare extends PluginProtocol { + /** + !#en + share interface + !#zh + 分享 + @param info Type: map + */ + share(info: any): void; + /** + !#en + set listener + !#zh + 设置分享系统的监听 + @param listener listener + @param target target + */ + setListener(listener: Function, target: any): void; + /** + !#en + get listener + !#zh + 获取分享系统的监听 + */ + getListener(): Function; + } + /** !#en + ads protocol + !#zh + 广告系统协议接口 */ + export class ProtocolAds extends PluginProtocol { + /** + !#en + hide ads view + !#zh + 隐藏广告 + @param adstype adstype + @param idx idx + */ + hideAds(adstype: anysdk.AdsType, idx: number): void; + /** + !#en + preload ads view + !#zh + 预加载广告 + @param adstype adstype + @param idx idx + */ + preloadAds(adstype: anysdk.AdsType, idx: number): void; + /** + !#en + query points + !#zh + 查询分数 + */ + queryPoints(): number; + /** + !#en + get whether the ads type is supported + !#zh + 获取广告类型是否支持 + @param arg0 arg0 + */ + isAdTypeSupported(arg0: anysdk.AdsType): boolean; + /** + !#en + spend point + !#zh + 消费分数 + @param points points + */ + spendPoints(points: number): void; + /** + !#en + set listener + !#zh + 设置广告系统的监听 + @param listener listener + @param target target + */ + setListener(listener: Function, target: any): void; + /** + !#en + get listener + !#zh + 获取广告系统的监听 + */ + getListener(): Function; + } + /** !#en + social protocol + !#zh + 社交系统协议接口 */ + export class ProtocolSocial extends PluginProtocol { + /** + !#en + sign in + !#zh + 登录 + */ + signIn(): void; + /** + !#en + sign out + !#zh + 登出 + */ + signOut(): void; + /** + !#en + submit score + !#zh + 提交分数 + @param leadboardID leadboardID + @param score Type: long + */ + submitScore(leadboardID: string, score: number): void; + /** + !#en + show the id of Leaderboard page + !#zh + 根据唯一标识符显示排行榜 + @param leaderboardID leaderboardID + */ + showLeaderboard(leaderboardID: string): void; + /** + !#en + show the page of achievements + !#zh + 显示成就榜 + */ + showAchievements(): void; + /** + !#en + unlock achievement + !#zh + 解锁成就 + @param info Type: map + */ + share(info: any): void; + /** + !#en + set listener + !#zh + 设置社交系统的监听 + @param listener listener + @param target target + */ + setListener(listener: Function, target: any): void; + /** + !#en + get listener + !#zh + 获取社交系统的监听 + */ + getListener(): Function; + /** + !#en + get friends info + Before to invoke, you need to verdict whether this properties existed + !#zh + 获取好友信息,调用前需要判断属性是否存在 + */ + pauseRecording(): void; + /** + !#en + interact + Before to invoke, you need to verdict whether this properties existed + !#zh + 订阅,调用前需要判断属性是否存在 + */ + interact(): void; + /** + !#en + subscribe + Before to invoke, you need to verdict whether this properties existed + !#zh + 关注,调用前需要判断属性是否存在 + */ + subscribe(): void; + } + /** !#en + push protocol + !#zh + 推送系统协议接口 */ + export class ProtocolPush extends PluginProtocol { + /** + !#en + start Push services + !#zh + 启动推送服务 + */ + startPush(): void; + /** + !#en + close Push services + !#zh + 暂停推送服务 + */ + closePush(): void; + /** + !#en + delete alias + !#zh + 删除别名 + @param alias alias + */ + delAlias(alias: string): void; + /** + !#en + set alias + !#zh + 设置别名 + @param alias alias + */ + setAlias(alias: string): void; + /** + !#en + delete tags + !#zh + 删除标签 + @param tags Type: list + */ + delTags(tags: any): void; + /** + !#en + set tags + !#zh + 设置标签 + @param tags Type: list + */ + setTags(tags: any): void; + /** + !#en + set listener + !#zh + 设置推送系统的监听 + @param listener listener + @param target target + */ + setListener(listener: Function, target: any): void; + /** + !#en + get listener + !#zh + 获取推送系统的监听 + */ + getListener(): Function; + } + /** !#en + crash protocol + !#zh + 崩溃分析系统协议接口 */ + export class ProtocolCrash extends PluginProtocol { + /** + !#en + set user identifier + !#zh + 统计用户唯一标识符 + @param identifier identifier + */ + setUserIdentifier(identifier: string): void; + /** + !#en + The uploader captured in exception information + !#zh + 上报异常信息 + @param message message + @param exception exception + */ + reportException(message: string, exception: string): void; + /** + !#en + customize logging + !#zh + 自定义日志记录 + @param breadcrumb breadcrumb + */ + leaveBreadcrumb(breadcrumb: string): void; + } + /** !#en + REC protocol + !#zh + 录屏系统协议接口 */ + export class ProtocolREC extends PluginProtocol { + /** + !#en + share video + !#zh + 分享视频 + @param info Type: map + */ + share(info: any): void; + /** + !#en + Start to record video + !#zh + 开始录制视频 + */ + startRecording(): void; + /** + !#en + Start to record video + !#zh + 结束录制视频 + */ + stopRecording(): void; + /** + !#en + set listener + !#zh + 设置录屏系统的监听 + @param listener listener + @param target target + */ + setListener(listener: Function, target: any): void; + /** + !#en + get listener + !#zh + 获取录屏系统的监听 + */ + getListener(): Function; + /** + !#en + pause to record video + Before to invoke, you need to verdict whether this properties existed + !#zh + 暂停录制视频,调用前需要判断属性是否存在 + */ + pauseRecording(): void; + /** + !#en + resume to record video + Before to invoke, you need to verdict whether this properties existed + !#zh + 恢复录制视频,调用前需要判断属性是否存在 + */ + resumeRecording(): void; + /** + !#en + get whether the device is isAvailable + Before to invoke, you need to verdict whether this properties existed + !#zh + 获取设备是否可用,调用前需要判断属性是否存在 + */ + isAvailable(): boolean; + /** + !#en + get status of recording + Before to invoke, you need to verdict whether this properties existed + !#zh + 获取录制状态,调用前需要判断属性是否存在 + */ + isRecording(): boolean; + /** + !#en + show toolbar + Before to invoke, you need to verdict whether this properties existed + !#zh + 显示悬浮窗,调用前需要判断属性是否存在 + */ + showToolBar(): void; + /** + !#en + hide toolbar + Before to invoke, you need to verdict whether this properties existed + !#zh + 隐藏悬浮窗,调用前需要判断属性是否存在 + */ + hideToolBar(): void; + /** + !#en + show video center + Before to invoke, you need to verdict whether this properties existed + !#zh + 显示视频中心,调用前需要判断属性是否存在 + */ + showVideoCenter(): void; + /** + !#en + enter platform + Before to invoke, you need to verdict whether this properties existed + !#zh + 显示平台中心,调用前需要判断属性是否存在 + */ + enterPlatform(): void; + /** + !#en + Set the video data, it is recommended to check whether are recorded firstly + Before to invoke, you need to verdict whether this properties existed + !#zh + 设置视频相关数据,建议先检查是否是正在录制,调用前需要判断属性是否存在 + @param info Type: map + */ + setMetaData(info: any): void; + } + /** !#en + ad tracking protocol + !#zh + 广告追踪系统协议接口 */ + export class ProtocolAdTracking extends PluginProtocol { + /** + !#en + Call this method if you want to track register events as happening during a section. + !#zh + 统计用户注册信息 + @param productInfo Type: map + */ + onPay(productInfo: any): void; + /** + !#en + Call this method if you want to track register events as happening during a section. + !#zh + 统计用户注册信息 + @param userInfo Type: map + */ + onLogin(userInfo: any): void; + /** + !#en + Call this method if you want to track register events as happening during a section. + !#zh + 统计用户注册信息 + @param userId userId + */ + onRegister(userId: string): void; + /** + !#en + Call this method if you want to track custom events with parameters as happening during a section. + !#zh + 统计自定义事件 + @param eventId eventId + @param paramMap Type: map + */ + trackEvent(eventId: string, paramMap: any): void; + /** + !#en + Call this method with parameters if you want to create role as happening during a section. + !#zh + 统计创建角色事件,调用前需要判断属性是否存在 + @param userInfo Type: map + */ + onCreateRole(userInfo: any): void; + /** + !#en + Call this method if you want to track levelup events with parameters as happening during a section. + Before to invoke, you need to verdict whether this properties existed + !#zh + 统计角色升级事件,调用前需要判断属性是否存在 + @param info Type: map + */ + onLevelUp(info: any): void; + /** + !#en + Invoke this method with parameters if you want to start to pay as happening during a section. + Before to invoke, you need to verdict whether this properties existed + !#zh + 统计开始充值事件,调用前需要判断属性是否存在 + @param info Type: map + */ + onStartToPay(info: any): void; + } + /** !#en + custom protocol + !#zh + 自定义系统协议接口 */ + export class ProtocolCustom extends PluginProtocol { + /** + !#en + set listener + !#zh + 设置自定义系统的监听 + @param listener listener + @param target target + */ + setListener(listener: Function, target: any): void; + /** + !#en + get listener + !#zh + 获取自定义系统的监听 + */ + getListener(): Function; + } + /** !#en + Data structure class + !#zh + 数据结构类 */ + export class PluginParam { + /** + !#en + create plugin parameters + !#zh + 创建对象 + @param parameters parameters + */ + static create(parameters: number|string|any): anysdk.PluginParam; + } + /** !#en The callback of user system + !#zh 用户系统回调 */ + export enum UserActionResultCode { + kInitSuccess = 0, + kInitFail = 0, + kLoginSuccess = 0, + kLoginNetworkError = 0, + kLoginNoNeed = 0, + kLoginFail = 0, + kLoginCancel = 0, + kLogoutSuccess = 0, + kLogoutFail = 0, + kPlatformEnter = 0, + kPlatformBack = 0, + kPausePage = 0, + kExitPage = 0, + kAntiAddictionQuery = 0, + kRealNameRegister = 0, + kAccountSwitchSuccess = 0, + kAccountSwitchFail = 0, + kOpenShop = 0, + kAccountSwitchCancel = 0, + kUserExtension = 0, + kSendToDesktopSuccess = 0, + kSendToDesktopFail = 0, + kGetAvailableLoginTypeSuccess = 0, + kGetAvailableLoginTypeFail = 0, + kGetUserInfoSuccess = 0, + kGetUserInfoFail = 0, + kOpenBBSSuccess = 0, + kOpenBBSFail = 0, + } + /** !#en The toolbar position of user type + !#zh 用户系统悬浮窗位置 */ + export enum ToolBarPlace { + kToolBarTopLeft = 0, + kToolBarTopRight = 0, + kToolBarMidLeft = 0, + kToolBarMidRight = 0, + kToolBarBottomLeft = 0, + kToolBarBottomRight = 0, + } + /** !#en The callback of requesting reStringge + !#zh 支付系统支付请求回调 */ + export enum PayResultCode { + kPaySuccess = 0, + kPayFail = 0, + kPayCancel = 0, + kPayNetworkError = 0, + kPayProductionInforIncomplete = 0, + kPayInitSuccess = 0, + kPayInitFail = 0, + kPayNowPaying = 0, + kPayReStringgeSuccess = 0, + kPayExtension = 0, + kPayNeedLoginAgain = 0, + kRequestSuccess = 0, + kRequestFail = 0, + } + /** !#en The enum of account type + !#zh 统计系统的账号类型 */ + export enum AccountType { + ANONYMOUS = 0, + REGISTED = 0, + SINA_WEIBO = 0, + TENCENT_WEIBO = 0, + QQ = 0, + ND91 = 0, + } + /** !#en The enum of account operation + !#zh 统计系统的账号操作 */ + export enum AccountOperate { + LOGIN = 0, + LOGOUT = 0, + REGISTER = 0, + } + /** !#en The enum of gender + !#zh 统计系统的账号性别 */ + export enum AccountGender { + MALE = 0, + FEMALE = 0, + UNKNOWN = 0, + } + /** !#en The enum of task type + !#zh 统计系统的任务类型 */ + export enum TaskType { + GUIDE_LINE = 0, + MAIN_LINE = 0, + BRANCH_LINE = 0, + DAILY = 0, + ACTIVITY = 0, + OTHER = 0, + } + /** !#en The callback of share system + !#zh 分享系统回调 */ + export enum ShareResultCode { + kShareSuccess = 0, + kShareFail = 0, + kShareCancel = 0, + kShareNetworkError = 0, + kShareExtension = 0, + } + /** !#en The callback of social system + !#zh 社交系统回调 */ + export enum SocialRetCode { + kScoreSubmitSucceed = 0, + kScoreSubmitfail = 0, + kAchUnlockSucceed = 0, + kAchUnlockFail = 0, + kSocialSignInSucceed = 0, + kSocialSignInFail = 0, + kSocialSignOutSucceed = 0, + kSocialSignOutFail = 0, + kSocialGetGameFriends = 0, + kSocialExtensionCode = 0, + kSocialGetFriendsInfoSuccess = 0, + kSocialGetFriendsInfoFail = 0, + kSocialAlreadySubscription = 0, + kSocialNoSubscription = 0, + kSocialSubscriptionFail = 0, + } + /** !#en The callback of ads system + !#zh 广告系统回调 */ + export enum AdsResultCode { + kAdsReceived = 0, + kAdsShown = 0, + kAdsDismissed = 0, + kPointsSpendSucceed = 0, + kPointsSpendFailed = 0, + kNetworkError = 0, + kUnknownError = 0, + kOfferWallOnPointsChanged = 0, + kRewardedVideoWithReward = 0, + kInAppPurchaseFinished = 0, + kAdsClicked = 0, + kAdsExtension = 0, + } + /** !#en The enum of ads position + !#zh 广告位置 */ + export enum AdsPos { + kPosCenter = 0, + kPosTop = 0, + kPosTopLeft = 0, + kPosTopRight = 0, + kPosBottom = 0, + kPosBottomLeft = 0, + kPosBottomRight = 0, + } + /** !#en The enum of ads type + !#zh 广告类型 */ + export enum AdsType { + AD_TYPE_BANNER = 0, + AD_TYPE_FULLSCREEN = 0, + AD_TYPE_MOREAPP = 0, + AD_TYPE_OFFERWALL = 0, + AD_TYPE_REWARDEDVIDEO = 0, + AD_TYPE_NATIVEEXPRESS = 0, + AD_TYPE_NATIVEADVANCED = 0, + } + /** !#en The callback of push system + !#zh 推送系统回调 */ + export enum PushActionResultCode { + kPushReceiveMessage = 0, + kPushExtensionCode = 0, + } + /** !#en The callback of custom system + !#zh 自定义系统回调 */ + export enum CustomResultCode { + kCustomExtension = 0, + } + /** !#en The callback of REC system + !#zh 录屏系统回调 */ + export enum RECResultCode { + kRECInitSuccess = 0, + kRECInitFail = 0, + kRECStartRecording = 0, + kRECStopRecording = 0, + kRECPauseRecording = 0, + kRECResumeRecording = 0, + kRECEnterSDKPage = 0, + kRECQuitSDKPage = 0, + kRECShareSuccess = 0, + kRECShareFail = 0, + kRECExtension = 0, + } +} + +/** !#en +The global main namespace of Spine, all classes, functions, +properties and constants of Spine are defined in this namespace +!#zh +Spine 的全局的命名空间, +与 Spine 相关的所有的类,函数,属性,常量都在这个命名空间中定义。 */ +declare module sp { + /** !#en + The skeleton of Spine
+
+ (Skeleton has a reference to a SkeletonData and stores the state for skeleton instance, + which consists of the current pose's bone SRT, slot colors, and which slot attachments are visible.
+ Multiple skeletons can use the same SkeletonData which includes all animations, skins, and attachments.)
+ !#zh + Spine 骨骼动画
+
+ (Skeleton 具有对骨骼数据的引用并且存储了骨骼实例的状态, + 它由当前的骨骼动作,slot 颜色,和可见的 slot attachments 组成。
+ 多个 Skeleton 可以使用相同的骨骼数据,其中包括所有的动画,皮肤和 attachments。 */ + export class Skeleton extends cc._RendererUnderSG { + /** !#en The skeletal animation is paused? + !#zh 该骨骼动画是否暂停。 */ + paused: boolean; + /** !#en + The skeleton data contains the skeleton information (bind pose bones, slots, draw order, + attachments, skins, etc) and animations but does not hold any state.
+ Multiple skeletons can share the same skeleton data. + !#zh + 骨骼数据包含了骨骼信息(绑定骨骼动作,slots,渲染顺序, + attachments,皮肤等等)和动画但不持有任何状态。
+ 多个 Skeleton 可以共用相同的骨骼数据。 */ + skeletonData: SkeletonData; + /** !#en The name of default skin. + !#zh 默认的皮肤名称。 */ + defaultSkin: string; + /** !#en The name of default animation. + !#zh 默认的动画名称。 */ + defaultAnimation: string; + /** !#en The name of current playing animation. + !#zh 当前播放的动画名称。 */ + animation: string; + _defaultSkinIndex: number; + /** !#en TODO + !#zh 是否循环播放当前骨骼动画。 */ + loop: boolean; + /** !#en Indicates whether to enable premultiplied alpha. + You should disable this option when image's transparent area appears to have opaque pixels, + or enable this option when image's half transparent area appears to be darken. + !#zh 是否启用贴图预乘。 + 当图片的透明区域出现色块时需要关闭该选项,当图片的半透明区域颜色变黑时需要启用该选项。 */ + premultipliedAlpha: boolean; + /** !#en The time scale of this skeleton. + !#zh 当前骨骼中所有动画的时间缩放率。 */ + timeScale: number; + /** !#en Indicates whether open debug slots. + !#zh 是否显示 slot 的 debug 信息。 */ + debugSlots: boolean; + /** !#en Indicates whether open debug bones. + !#zh 是否显示 bone 的 debug 信息。 */ + debugBones: boolean; + /** + !#en Computes the world SRT from the local SRT for each bone. + !#zh 重新更新所有骨骼的世界 Transform, + 当获取 bone 的数值未更新时,即可使用该函数进行更新数值。 + + @example + ```js + var bone = spine.findBone('head'); + cc.log(bone.worldX); // return 0; + spine.updateWorldTransform(); + bone = spine.findBone('head'); + cc.log(bone.worldX); // return -23.12; + ``` + */ + updateWorldTransform(): void; + /** + !#en Sets the bones and slots to the setup pose. + !#zh 还原到起始动作 + */ + setToSetupPose(): void; + /** + !#en + Sets the bones to the setup pose, + using the values from the `BoneData` list in the `SkeletonData`. + !#zh + 设置 bone 到起始动作 + 使用 SkeletonData 中的 BoneData 列表中的值。 + */ + setBonesToSetupPose(): void; + /** + !#en + Sets the slots to the setup pose, + using the values from the `SlotData` list in the `SkeletonData`. + !#zh + 设置 slot 到起始动作。 + 使用 SkeletonData 中的 SlotData 列表中的值。 + */ + setSlotsToSetupPose(): void; + /** + !#en + Finds a bone by name. + This does a string comparison for every bone.
+ Returns a {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.Bone object. + !#zh + 通过名称查找 bone。 + 这里对每个 bone 的名称进行了对比。
+ 返回一个 {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.Bone 对象。 + @param boneName boneName + */ + findBone(boneName: string): sp.spine.Bone; + /** + !#en + Finds a slot by name. This does a string comparison for every slot.
+ Returns a {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.Slot object. + !#zh + 通过名称查找 slot。这里对每个 slot 的名称进行了比较。
+ 返回一个 {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.Slot 对象。 + @param slotName slotName + */ + findSlot(slotName: string): sp.spine.Slot; + /** + !#en + Finds a skin by name and makes it the active skin. + This does a string comparison for every skin.
+ Note that setting the skin does not change which attachments are visible.
+ Returns a {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.Skin object. + !#zh + 按名称查找皮肤,激活该皮肤。这里对每个皮肤的名称进行了比较。
+ 注意:设置皮肤不会改变 attachment 的可见性。
+ 返回一个 {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.Skin 对象。 + @param skinName skinName + */ + setSkin(skinName: string): sp.spine.Skin; + /** + !#en + Returns the attachment for the slot and attachment name. + The skeleton looks first in its skin, then in the skeleton data’s default skin.
+ Returns a {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.Attachment object. + !#zh + 通过 slot 和 attachment 的名称获取 attachment。Skeleton 优先查找它的皮肤,然后才是 Skeleton Data 中默认的皮肤。
+ 返回一个 {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.Attachment 对象。 + @param slotName slotName + @param attachmentName attachmentName + */ + getAttachment(slotName: string, attachmentName: string): sp.spine.Attachment; + /** + !#en + Sets the attachment for the slot and attachment name. + The skeleton looks first in its skin, then in the skeleton data’s default skin. + !#zh + 通过 slot 和 attachment 的名字来设置 attachment。 + Skeleton 优先查找它的皮肤,然后才是 Skeleton Data 中默认的皮肤。 + @param slotName slotName + @param attachmentName attachmentName + */ + setAttachment(slotName: string, attachmentName: string): void; + /** + !#en + Sets runtime skeleton data to sp.Skeleton.
+ This method is different from the `skeletonData` property. This method is passed in the raw data provided by the Spine runtime, and the skeletonData type is the asset type provided by Creator. + !#zh + 设置底层运行时用到的 SkeletonData。
+ 这个接口有别于 `skeletonData` 属性,这个接口传入的是 Spine runtime 提供的原始数据,而 skeletonData 的类型是 Creator 提供的资源类型。 + @param skeletonData skeletonData + @param ownsSkeletonData ownsSkeletonData + */ + setSkeletonData(skeletonData: sp.spine.SkeletonData, ownsSkeletonData: sp.spine.SkeletonData): void; + /** + !#en Sets animation state data.
+ The parameter type is {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.AnimationStateData. + !#zh 设置动画状态数据。
+ 参数是 {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.AnimationStateData。 + @param stateData stateData + */ + setAnimationStateData(stateData: sp.spine.AnimationStateData): void; + /** + !#en + Mix applies all keyframe values, + interpolated for the specified time and mixed with the current values. + !#zh 为所有关键帧设定混合及混合时间(从当前值开始差值)。 + @param fromAnimation fromAnimation + @param toAnimation toAnimation + @param duration duration + */ + setMix(fromAnimation: string, toAnimation: string, duration: number): void; + /** + !#en Sets event listener. + !#zh 设置动画事件监听器。 + @param target target + @param callback callback + */ + setAnimationListener(target: any, callback: Function): void; + /** + !#en Set the current animation. Any queued animations are cleared.
+ Returns a {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.TrackEntry object. + !#zh 设置当前动画。队列中的任何的动画将被清除。
+ 返回一个 {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.TrackEntry 对象。 + @param trackIndex trackIndex + @param name name + @param loop loop + */ + setAnimation(trackIndex: number, name: string, loop: boolean): sp.spine.TrackEntry; + /** + !#en Adds an animation to be played delay seconds after the current or last queued animation.
+ Returns a {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.TrackEntry object. + !#zh 添加一个动画到动画队列尾部,还可以延迟指定的秒数。
+ 返回一个 {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.TrackEntry 对象。 + @param trackIndex trackIndex + @param name name + @param loop loop + @param delay delay + */ + addAnimation(trackIndex: number, name: string, loop: boolean, delay?: number): sp.spine.TrackEntry; + /** + !#en Find animation with specified name. + !#zh 查找指定名称的动画 + @param name name + */ + findAnimation(name: string): sp.spine.Animation; + /** + !#en Returns track entry by trackIndex.
+ Returns a {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.TrackEntry object. + !#zh 通过 track 索引获取 TrackEntry。
+ 返回一个 {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.TrackEntry 对象。 + @param trackIndex trackIndex + */ + getCurrent(trackIndex: void): sp.spine.TrackEntry; + /** + !#en Clears all tracks of animation state. + !#zh 清除所有 track 的动画状态。 + */ + clearTracks(): void; + /** + !#en Clears track of animation state by trackIndex. + !#zh 清除出指定 track 的动画状态。 + @param trackIndex trackIndex + */ + clearTrack(trackIndex: number): void; + /** + !#en Set the start event listener. + !#zh 用来设置开始播放动画的事件监听。 + @param listener listener + */ + setStartListener(listener: Function): void; + /** + !#en Set the interrupt event listener. + !#zh 用来设置动画被打断的事件监听。 + @param listener listener + */ + setInterruptListener(listener: Function): void; + /** + !#en Set the end event listener. + !#zh 用来设置动画播放完后的事件监听。 + @param listener listener + */ + setEndListener(listener: Function): void; + /** + !#en Set the dispose event listener. + !#zh 用来设置动画将被销毁的事件监听。 + @param listener listener + */ + setDisposeListener(listener: Function): void; + /** + !#en Set the complete event listener. + !#zh 用来设置动画播放一次循环结束后的事件监听。 + @param listener listener + */ + setCompleteListener(listener: Function): void; + /** + !#en Set the animation event listener. + !#zh 用来设置动画播放过程中帧事件的监听。 + @param listener listener + */ + setEventListener(listener: Function): void; + /** + !#en Set the start event listener for specified TrackEntry (only supported on Web). + !#zh 用来为指定的 TrackEntry 设置动画开始播放的事件监听。(只支持 Web 平台) + @param entry entry + @param listener listener + */ + setTrackStartListener(entry: sp.spine.TrackEntry, listener: Function): void; + /** + !#en Set the interrupt event listener for specified TrackEntry (only supported on Web). + !#zh 用来为指定的 TrackEntry 设置动画被打断的事件监听。(只支持 Web 平台) + @param entry entry + @param listener listener + */ + setTrackInterruptListener(entry: sp.spine.TrackEntry, listener: Function): void; + /** + !#en Set the end event listener for specified TrackEntry (only supported on Web). + !#zh 用来为指定的 TrackEntry 设置动画播放结束的事件监听。(只支持 Web 平台) + @param entry entry + @param listener listener + */ + setTrackEndListener(entry: sp.spine.TrackEntry, listener: Function): void; + /** + !#en Set the dispose event listener for specified TrackEntry (only supported on Web). + !#zh 用来为指定的 TrackEntry 设置动画即将被销毁的事件监听。(只支持 Web 平台) + @param entry entry + @param listener listener + */ + setTrackDisposeListener(entry: sp.spine.TrackEntry, listener: Function): void; + /** + !#en Set the complete event listener for specified TrackEntry (only supported on Web). + !#zh 用来为指定的 TrackEntry 设置动画一次循环播放结束的事件监听。(只支持 Web 平台) + @param entry entry + @param listener listener + */ + setTrackCompleteListener(entry: sp.spine.TrackEntry, listener: Function): void; + /** + !#en Set the event listener for specified TrackEntry (only supported on Web). + !#zh 用来为指定的 TrackEntry 设置动画帧事件的监听。(只支持 Web 平台) + @param entry entry + @param listener listener + */ + setTrackEventListener(entry: sp.spine.TrackEntry, listener: Function): void; + } + /** !#en The skeleton data of spine. + !#zh Spine 的 骨骼数据。 */ + export class SkeletonData extends cc.Asset { + /** !#en See http://en.esotericsoftware.com/spine-json-format + !#zh 可查看 Spine 官方文档 http://zh.esotericsoftware.com/spine-json-format */ + skeletonJson: any; + atlasText: string; + textures: cc.Texture2D[]; + /** !#en + A scale can be specified on the JSON or binary loader which will scale the bone positions, + image sizes, and animation translations. + This can be useful when using different sized images than were used when designing the skeleton + in Spine. For example, if using images that are half the size than were used in Spine, + a scale of 0.5 can be used. This is commonly used for games that can run with either low or high + resolution texture atlases. + see http://en.esotericsoftware.com/spine-using-runtimes#Scaling + !#zh 可查看 Spine 官方文档: http://zh.esotericsoftware.com/spine-using-runtimes#Scaling */ + scale: number; + /** + !#en Get the included SkeletonData used in spine runtime.
+ Returns a {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.SkeletonData object. + !#zh 获取 Spine Runtime 使用的 SkeletonData。
+ 返回一个 {{#crossLinkModule "sp.spine"}}sp.spine{{/crossLinkModule}}.SkeletonData 对象。 + @param quiet quiet + */ + getRuntimeData(quiet?: boolean): sp.spine.SkeletonData; + } + /** !#en The event type of spine skeleton animation. + !#zh 骨骼动画事件类型。 */ + export enum AnimationEventType { + START = 0, + END = 0, + COMPLETE = 0, + EVENT = 0, + } +} + +/** !#en +`sp.spine` is the namespace for official Spine Runtime, which officially implemented and maintained by Spine.
+Please refer to the official documentation for its detailed usage: [http://en.esotericsoftware.com/spine-using-runtimes](http://en.esotericsoftware.com/spine-using-runtimes) +!#zh +sp.spine 模块是 Spine 官方运行库的 API 入口,由 Spine 官方统一实现和维护,具体用法请参考:[http://zh.esotericsoftware.com/spine-using-runtimes](http://zh.esotericsoftware.com/spine-using-runtimes) */ +declare module sp.spine { +} + +/** !#en +The global main namespace of DragonBones, all classes, functions, +properties and constants of DragonBones are defined in this namespace +!#zh +DragonBones 的全局的命名空间, +与 DragonBones 相关的所有的类,函数,属性,常量都在这个命名空间中定义。 */ +declare module dragonBones { + /** !#en + The Armature Display of DragonBones
+
+ (Armature Display has a reference to a DragonBonesAsset and stores the state for ArmatureDisplay instance, + which consists of the current pose's bone SRT, slot colors, and which slot attachments are visible.
+ Multiple Armature Display can use the same DragonBonesAsset which includes all animations, skins, and attachments.)
+ !#zh + DragonBones 骨骼动画
+
+ (Armature Display 具有对骨骼数据的引用并且存储了骨骼实例的状态, + 它由当前的骨骼动作,slot 颜色,和可见的 slot attachments 组成。
+ 多个 Armature Display 可以使用相同的骨骼数据,其中包括所有的动画,皮肤和 attachments。)
*/ + export class ArmatureDisplay extends cc._RendererUnderSG { + /** !#en + The DragonBones data contains the armatures information (bind pose bones, slots, draw order, + attachments, skins, etc) and animations but does not hold any state.
+ Multiple ArmatureDisplay can share the same DragonBones data. + !#zh + 骨骼数据包含了骨骼信息(绑定骨骼动作,slots,渲染顺序, + attachments,皮肤等等)和动画但不持有任何状态。
+ 多个 ArmatureDisplay 可以共用相同的骨骼数据。 */ + dragonAsset: DragonBonesAsset; + /** !#en + The atlas asset for the DragonBones. + !#zh + 骨骼数据所需的 Atlas Texture 数据。 */ + dragonAtlasAsset: DragonBonesAtlasAsset; + /** !#en The name of current armature. + !#zh 当前的 Armature 名称。 */ + armatureName: string; + /** !#en The name of current playing animation. + !#zh 当前播放的动画名称。 */ + animationName: string; + _defaultArmatureIndex: number; + /** !#en The time scale of this armature. + !#zh 当前骨骼中所有动画的时间缩放率。 */ + timeScale: number; + /** !#en The play times of the default animation. + -1 means using the value of config file; + 0 means repeat for ever + >0 means repeat times + !#zh 播放默认动画的循环次数 + -1 表示使用配置文件中的默认值; + 0 表示无限循环 + >0 表示循环次数 */ + playTimes: number; + /** !#en Indicates whether open debug bones. + !#zh 是否显示 bone 的 debug 信息。 */ + debugBones: boolean; + /** + !#en + Play the specified animation. + Parameter animName specify the animation name. + Parameter playTimes specify the repeat times of the animation. + -1 means use the value of the config file. + 0 means play the animation for ever. + >0 means repeat times. + !#zh + 播放指定的动画. + animName 指定播放动画的名称。 + playTimes 指定播放动画的次数。 + -1 为使用配置文件中的次数。 + 0 为无限循环播放。 + >0 为动画的重复次数。 + @param animName animName + @param playTimes playTimes + */ + playAnimation(animName: string, playTimes: number): dragonBones.AnimationState; + /** + !#en + Get the all armature names in the DragonBones Data. + !#zh + 获取 DragonBones 数据中所有的 armature 名称 + */ + getArmatureNames(): any[]; + /** + !#en + Get the all animation names of specified armature. + !#zh + 获取指定的 armature 的所有动画名称。 + @param armatureName armatureName + */ + getAnimationNames(armatureName: string): any[]; + /** + !#en + Add event listener for the DragonBones Event. + !#zh + 添加 DragonBones 事件监听器。 + @param eventType eventType + @param listener listener + @param target target + */ + addEventListener(eventType: dragonBones.EventObject, listener: Function, target: any): void; + /** + !#en + Remove the event listener for the DragonBones Event. + !#zh + 移除 DragonBones 事件监听器。 + @param eventType eventType + @param listener listener + @param target target + */ + removeEventListener(eventType: dragonBones.EventObject, listener: Function, target: any): void; + /** + !#en + Build the armature for specified name. + !#zh + 构建指定名称的 armature 对象 + @param armatureName armatureName + */ + buildArmature(armatureName: string): dragonBones.Armature; + /** + !#en + Get the current armature object of the ArmatureDisplay. + !#zh + 获取 ArmatureDisplay 当前使用的 Armature 对象 + */ + armature(): any; + } + /** !#en The skeleton data of dragonBones. + !#zh dragonBones 的 骨骼数据。 */ + export class DragonBonesAsset extends cc.Asset { + /** !#en See http://developer.egret.com/cn/github/egret-docs/DB/dbLibs/dataFormat/index.html + !#zh 可查看 DragonBones 官方文档 http://developer.egret.com/cn/github/egret-docs/DB/dbLibs/dataFormat/index.html */ + dragonBonesJson: string; + } + /** !#en The skeleton atlas data of dragonBones. + !#zh dragonBones 的骨骼纹理数据。 */ + export class DragonBonesAtlasAsset extends cc.Asset { + atlasJson: string; + texture: cc.Texture2D; + } +} + +/** !#en Some JavaScript decorators which can be accessed with "cc._decorator". +!#zh 一些 JavaScript 装饰器,目前可以通过 "cc._decorator" 来访问。 +(这些 API 仍不完全稳定,有可能随着 JavaScript 装饰器的标准实现而调整) */ +declare module cc._decorator { + /** + !#en + Declare the standard [ES6 Class](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes) + as CCClass, please see [Class](/docs/editors_and_tools/creator-chapters/scripting/class/) for details. + !#zh + 将标准写法的 [ES6 Class](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes) 声明为 CCClass,具体用法请参阅[类型定义](/docs/creator/scripting/class/)。 + @param name The class name used for serialization. + + @example + ```js + const {ccclass} = cc._decorator; + + // define a CCClass, omit the name + @ccclass + class NewScript extends cc.Component { + // ... + } + + // define a CCClass with a name + @ccclass('LoginData') + class LoginData { + // ... + } + ``` + */ + export function ccclass(name?: string): Function; + export function ccclass(_class?: Function): void; + /** + !#en + Declare property for [CCClass](/docs/editors_and_tools/creator-chapters/scripting/class/). + !#zh + 定义 [CCClass](/docs/creator/scripting/class/) 所用的属性。 + @param options an object with some property attributes + + @example + ```js + const {ccclass, property} = cc._decorator; + + @ccclass + class NewScript extends cc.Component { + @property({ + type: cc.Node + }) + targetNode1 = null; + + @property(cc.Node) + targetNode2 = null; + + @property(cc.Button) + targetButton = null; + + @property + _width = 100; + + @property + get width () { + return this._width; + } + + @property + set width (value) { + this._width = value; + } + + @property + offset = new cc.Vec2(100, 100); + + @property(cc.Vec2) + offsets = []; + + @property(cc.Texture2D) + texture = ""; + } + + // above is equivalent to (上面的代码相当于): + + var NewScript = cc.Class({ + properties: { + targetNode1: { + default: null, + type: cc.Node + }, + + targetNode2: { + default: null, + type: cc.Node + }, + + targetButton: { + default: null, + type: cc.Button + }, + + _width: 100, + + width: { + get () { + return this._width; + }, + set (value) { + this._width = value; + } + }, + + offset: new cc.Vec2(100, 100) + + offsets: { + default: [], + type: cc.Vec2 + } + + texture: { + default: "", + url: cc.Texture2D + }, + } + }); + ``` + */ + export function property(options?: {type?: any; url?: typeof cc.RawAsset; visible?: boolean|(() => boolean); displayName?: string; tooltip?: string; multiline?: boolean; readonly?: boolean; min?: number; max?: number; step?: number; range?: number[]; slide?: boolean; serializable?: boolean; formerlySerializedAs?: string; editorOnly?: boolean; override?: boolean; animatable?: boolean} | any[]|Function|cc.ValueType|number|string|boolean): Function; + export function property(_target: Object, _key: any, _desc?: any): void; + /** + !#en + Makes a CCClass that inherit from component execute in edit mode.
+ By default, all components are only executed in play mode, + which means they will not have their callback functions executed while the Editor is in edit mode. + !#zh + 允许继承自 Component 的 CCClass 在编辑器里执行。
+ 默认情况下,所有 Component 都只会在运行时才会执行,也就是说它们的生命周期回调不会在编辑器里触发。 + + @example + ```js + const {ccclass, executeInEditMode} = cc._decorator; + + @ccclass + @executeInEditMode + class NewScript extends cc.Component { + // ... + } + ``` + */ + export function executeInEditMode(): Function; + export function executeInEditMode(_class: Function): void; + /** + !#en + Automatically add required component as a dependency for the CCClass that inherit from component. + !#zh + 为声明为 CCClass 的组件添加依赖的其它组件。当组件添加到节点上时,如果依赖的组件不存在,引擎将会自动将依赖组件添加到同一个节点,防止脚本出错。该设置在运行时同样有效。 + @param requiredComponent requiredComponent + + @example + ```js + const {ccclass, requireComponent} = cc._decorator; + + @ccclass + @requireComponent(cc.Sprite) + class SpriteCtrl extends cc.Component { + // ... + } + ``` + */ + export function requireComponent(requiredComponent: typeof cc.Component): Function; + /** + !#en + The menu path to register a component to the editors "Component" menu. Eg. "Rendering/CameraCtrl". + !#zh + 将当前组件添加到组件菜单中,方便用户查找。例如 "Rendering/CameraCtrl"。 + @param path The path is the menu represented like a pathname. + For example the menu could be "Rendering/CameraCtrl". + + @example + ```js + const {ccclass, menu} = cc._decorator; + + @ccclass + @menu("Rendering/CameraCtrl") + class NewScript extends cc.Component { + // ... + } + ``` + */ + export function menu(path: string): Function; + /** + !#en + The execution order of lifecycle methods for Component. + Those less than 0 will execute before while those greater than 0 will execute after. + The order will only affect onLoad, onEnable, start, update and lateUpdate while onDisable and onDestroy will not be affected. + !#zh + 设置脚本生命周期方法调用的优先级。优先级小于 0 的组件将会优先执行,优先级大于 0 的组件将会延后执行。优先级仅会影响 onLoad, onEnable, start, update 和 lateUpdate,而 onDisable 和 onDestroy 不受影响。 + @param order The execution order of lifecycle methods for Component. Those less than 0 will execute before while those greater than 0 will execute after. + + @example + ```js + const {ccclass, executionOrder} = cc._decorator; + + @ccclass + @executionOrder(1) + class CameraCtrl extends cc.Component { + // ... + } + ``` + */ + export function executionOrder(order: number): Function; + /** + !#en + Prevents Component of the same type (or subtype) to be added more than once to a Node. + !#zh + 防止多个相同类型(或子类型)的组件被添加到同一个节点。 + + @example + ```js + const {ccclass, disallowMultiple} = cc._decorator; + + @ccclass + @disallowMultiple + class CameraCtrl extends cc.Component { + // ... + } + ``` + */ + export function disallowMultiple(): Function; + export function disallowMultiple(_class: Function): void; + /** + !#en + If specified, the editor's scene view will keep updating this node in 60 fps when it is selected, otherwise, it will update only if necessary.
+ This property is only available if executeInEditMode is true. + !#zh + 当指定了 "executeInEditMode" 以后,playOnFocus 可以在选中当前组件所在的节点时,提高编辑器的场景刷新频率到 60 FPS,否则场景就只会在必要的时候进行重绘。 + + @example + ```js + const {ccclass, playOnFocus, executeInEditMode} = cc._decorator; + + @ccclass + @executeInEditMode + @playOnFocus + class CameraCtrl extends cc.Component { + // ... + } + ``` + */ + export function playOnFocus(): Function; + export function playOnFocus(_class: Function): void; + /** + !#en + Specifying the url of the custom html to draw the component in **Properties**. + !#zh + 自定义当前组件在 **属性检查器** 中渲染时所用的网页 url。 + @param url url + + @example + ```js + const {ccclass, inspector} = cc._decorator; + + @ccclass + @inspector("packages://inspector/inspectors/comps/camera-ctrl.js") + class NewScript extends cc.Component { + // ... + } + ``` + */ + export function inspector(path: string): Function; + /** + !#en + The custom documentation URL. + !#zh + 指定当前组件的帮助文档的 url,设置过后,在 **属性检查器** 中就会出现一个帮助图标,用户点击将打开指定的网页。 + @param url url + + @example + ```js + const {ccclass, help} = cc._decorator; + + @ccclass + @help("app://docs/html/components/spine.html") + class NewScript extends cc.Component { + // ... + } + ``` + */ + export function help(path: string): Function; + /** + NOTE:
+ The old mixins implemented in cc.Class(ES5) behaves exact the same as multiple inheritance. + But since ES6, class constructor can't be function-called and class methods become non-enumerable, + so we can not mix in ES6 Classes.
+ See:
+ [https://esdiscuss.org/topic/traits-are-now-impossible-in-es6-until-es7-since-rev32](https://esdiscuss.org/topic/traits-are-now-impossible-in-es6-until-es7-since-rev32)
+ One possible solution (but IDE unfriendly):
+ [http://justinfagnani.com/2015/12/21/real-mixins-with-javascript-classes](http://justinfagnani.com/2015/12/21/real-mixins-with-javascript-classes/)
+
+ NOTE:
+ You must manually call mixins constructor, this is different from cc.Class(ES5). + @param ctor constructors to mix, only support ES5 constructors or classes defined by using `cc.Class`, + not support ES6 Classes. + + @example + ```js + const {ccclass, mixins} = cc._decorator; + + class Animal { ... } + + const Fly = cc.Class({ + constructor () { ... } + }); + + @ccclass + @mixins(cc.EventTarget, Fly) + class Bird extends Animal { + constructor () { + super(); + + // You must manually call mixins constructor, this is different from cc.Class(ES5) + cc.EventTarget.call(this); + Fly.call(this); + } + // ... + } + ``` + */ + export function mixins(ctor: Function, ...rest: Function[]): Function; +} + +/** This module provides some JavaScript utilities. +All members can be accessed with "cc.js". */ +declare module cc.js { + /** + Check the obj whether is number or not + If a number is created by using 'new Number(10086)', the typeof it will be "object"... + Then you can use this function if you care about this case. + @param obj obj + */ + export function isNumber(obj: any): boolean; + /** + Check the obj whether is string or not. + If a string is created by using 'new String("blabla")', the typeof it will be "object"... + Then you can use this function if you care about this case. + @param obj obj + */ + export function isString(obj: any): boolean; + /** + This method is deprecated, use cc.js.mixin please.
+ Copy all properties not defined in obj from arguments[1...n] + @param obj object to extend its properties + @param sourceObj source object to copy properties from + */ + export function addon(obj: any, ...sourceObj: any[]): any; + /** + copy all properties from arguments[1...n] to obj + @param obj obj + @param sourceObj sourceObj + */ + export function mixin(obj: any, ...sourceObj: any[]): any; + /** + Derive the class from the supplied base class. + Both classes are just native javascript constructors, not created by cc.Class, so + usually you will want to inherit using {{#crossLink "cc/Class:method"}}cc.Class {{/crossLink}} instead. + @param cls cls + @param base the baseclass to inherit + */ + export function extend(cls: Function, base: Function): Function; + /** + Get super class + @param ctor the constructor of subclass + */ + export function getSuper(ctor: Function): Function; + /** + Removes all enumerable properties from object + @param obj obj + */ + export function clear(obj: any): void; + /** + Get property descriptor in object and all its ancestors + @param obj obj + @param name name + */ + export function getPropertyDescriptor(obj: any, name: string): any; + /** + Define value, just help to call Object.defineProperty.
+ The configurable will be true. + @param obj obj + @param prop prop + @param value value + @param writable writable + @param enumerable enumerable + */ + export function value(obj: any, prop: string, value: any, writable?: boolean, enumerable?: boolean): void; + /** + Define get set accessor, just help to call Object.defineProperty(...) + @param obj obj + @param prop prop + @param getter getter + @param setter setter + @param enumerable enumerable + */ + export function getset(obj: any, prop: string, getter: Function, setter: Function, enumerable?: boolean): void; + /** + Define get accessor, just help to call Object.defineProperty(...) + @param obj obj + @param prop prop + @param getter getter + @param enumerable enumerable + @param configurable configurable + */ + export function get(obj: any, prop: string, getter: Function, enumerable?: boolean, configurable?: boolean): void; + /** + Define set accessor, just help to call Object.defineProperty(...) + @param obj obj + @param prop prop + @param setter setter + @param enumerable enumerable + @param configurable configurable + */ + export function set(obj: any, prop: string, setter: Function, enumerable?: boolean, configurable?: boolean): void; + /** + Get class name of the object, if object is just a {} (and which class named 'Object'), it will return "". + (modified from
the code from this stackoverflow post) + @param objOrCtor instance or constructor + */ + export function getClassName(objOrCtor: any|Function): string; + /** + Register the class by specified name manually + @param className className + @param constructor constructor + */ + export function setClassName(className: string, constructor: Function): void; + /** + Unregister a class from fireball. + + If you dont need a registered class anymore, you should unregister the class so that Fireball will not keep its reference anymore. + Please note that its still your responsibility to free other references to the class. + @param constructor the class you will want to unregister, any number of classes can be added + */ + export function unregisterClass(...constructor: Function[]): void; + /** + Get the registered class by name + @param classname classname + */ + export function getClassByName(classname: string): Function; + /** + Defines a polyfill field for obsoleted codes. + @param obj YourObject or YourClass.prototype + @param obsoleted "OldParam" or "YourClass.OldParam" + @param newPropName "NewParam" + @param writable writable + */ + export function obsolete(obj: any, obsoleted: string, newPropName: string, writable?: boolean): void; + /** + Defines all polyfill fields for obsoleted codes corresponding to the enumerable properties of props. + @param obj YourObject or YourClass.prototype + @param objName "YourObject" or "YourClass" + @param props props + @param writable writable + */ + export function obsoletes(obj: any, objName: any, props: any, writable?: boolean): void; + /** + A string tool to construct a string with format string. + @param msg A JavaScript string containing zero or more substitution strings. + @param subst JavaScript objects with which to replace substitution strings within msg. This gives you additional control over the format of the output. + + @example + ```js + cc.js.formatStr("a: %s, b: %s", a, b); + cc.js.formatStr(a, b, c); + ``` + */ + export function formatStr(msg: string|any, ...subst: any[]): string; + /** + #en + A simple wrapper of `Object.create(null)` which ensures the return object have no prototype (and thus no inherited members). So we can skip `hasOwnProperty` calls on property lookups. It is a worthwhile optimization than the `{}` literal when `hasOwnProperty` calls are necessary. + #zh + 该方法是对 `Object.create(null)` 的简单封装。`Object.create(null)` 用于创建无 prototype (也就无继承)的空对象。这样我们在该对象上查找属性时,就不用进行 `hasOwnProperty` 判断。在需要频繁判断 `hasOwnProperty` 时,使用这个方法性能会比 `{}` 更高。 + @param forceDictMode Apply the delete operator to newly created map object. This causes V8 to put the object in "dictionary mode" and disables creation of hidden classes which are very expensive for objects that are constantly changing shape. + */ + export function createMap(forceDictMode?: boolean): any; + /** undefined */ + export class array { + /** + Removes the array item at the specified index. + @param array array + @param index index + */ + static removeAt(array: any[], index: number): void; + /** + Removes the array item at the specified index. + It's faster but the order of the array will be changed. + @param array array + @param index index + */ + static fastRemoveAt(array: any[], index: number): void; + /** + Removes the first occurrence of a specific object from the array. + @param array array + @param value value + */ + static remove(array: any[], value: any): boolean; + /** + Removes the first occurrence of a specific object from the array. + It's faster but the order of the array will be changed. + @param array array + @param value value + */ + static fastRemove(array: any[], value: number): void; + /** + Verify array's Type + @param array array + @param type type + */ + static verifyType(array: any[], type: Function): boolean; + /** + Removes from array all values in minusArr. For each Value in minusArr, the first matching instance in array will be removed. + @param array Source Array + @param minusArr minus Array + */ + static removeArray(array: any[], minusArr: any[]): void; + /** + Inserts some objects at index + @param array array + @param addObjs addObjs + @param index index + */ + static appendObjectsAt(array: any[], addObjs: any[], index: number): any[]; + /** + Exact same function as Array.prototype.indexOf.
+ HACK: ugliy hack for Baidu mobile browser compatibility, stupid Baidu guys modify Array.prototype.indexOf for all pages loaded, their version changes strict comparison to non-strict comparison, it also ignores the second parameter of the original API, and this will cause event handler enter infinite loop.
+ Baidu developers, if you ever see this documentation, here is the standard: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/indexOf, Seriously! + @param searchElement Element to locate in the array. + @param fromIndex The index to start the search at + */ + static indexOf(searchElement: any, fromIndex?: number): number; + /** + Determines whether the array contains a specific value. + @param array array + @param value value + */ + static contains(array: any[], value: any): boolean; + /** + Copy an array's item to a new array (its performance is better than Array.slice) + @param array array + */ + static copy(array: any[]): any[]; + } + /** !#en + A fixed-length object pool designed for general type.
+ The implementation of this object pool is very simple, + it can helps you to improve your game performance for objects which need frequent release and recreate operations
+ !#zh + 长度固定的对象缓存池,可以用来缓存各种对象类型。
+ 这个对象池的实现非常精简,它可以帮助您提高游戏性能,适用于优化对象的反复创建和销毁。 */ + export class Pool { + /** + !#en + Constructor for creating an object pool for the specific object type. + You can pass a callback argument for process the cleanup logic when the object is recycled. + !#zh + 使用构造函数来创建一个指定对象类型的对象池,您可以传递一个回调函数,用于处理对象回收时的清理逻辑。 + @param cleanupFunc the callback method used to process the cleanup logic when the object is recycled. + @param size initializes the length of the array + */ + constructor(cleanupFunc: (obj: any) => void, size: number); + constructor(size: number); + /** + !#en + Get and initialize an object from pool. This method defaults to null and requires the user to implement it. + !#zh + 获取并初始化对象池中的对象。这个方法默认为空,需要用户自己实现。 + @param params parameters to used to initialize the object + */ + get(...params: any[]): any; + /** !#en + The current number of available objects, the default is 0, it will gradually increase with the recycle of the object, + the maximum will not exceed the size specified when the constructor is called. + !#zh + 当前可用对象数量,一开始默认是 0,随着对象的回收会逐渐增大,最大不会超过调用构造函数时指定的 size。 */ + count: number; + /** + !#en + Get an object from pool, if no available object in the pool, null will be returned. + !#zh + 获取对象池中的对象,如果对象池没有可用对象,则返回空。 + */ + _get(): any; + /** + !#en Put an object into the pool. + !#zh 向对象池返还一个不再需要的对象。 + */ + put(): void; + /** + !#en Resize the pool. + !#zh 设置对象池容量。 + */ + resize(): void; + } +} +declare namespace dragonBones { + /** + * @private + */ + const enum ArmatureType { + Armature = 0, + MovieClip = 1, + Stage = 2, + } + /** + * @private + */ + const enum DisplayType { + Image = 0, + Armature = 1, + Mesh = 2, + } + /** + * @private + */ + const enum ExtensionType { + FFD = 0, + AdjustColor = 10, + BevelFilter = 11, + BlurFilter = 12, + DropShadowFilter = 13, + GlowFilter = 14, + GradientBevelFilter = 15, + GradientGlowFilter = 16, + } + /** + * @private + */ + const enum EventType { + Frame = 10, + Sound = 11, + } + /** + * @private + */ + const enum ActionType { + Play = 0, + Stop = 1, + GotoAndPlay = 2, + GotoAndStop = 3, + FadeIn = 4, + FadeOut = 5, + } + /** + * @private + */ + const enum BlendMode { + Normal = 0, + Add = 1, + Alpha = 2, + Darken = 3, + Difference = 4, + Erase = 5, + HardLight = 6, + Invert = 7, + Layer = 8, + Lighten = 9, + Multiply = 10, + Overlay = 11, + Screen = 12, + Subtract = 13, + } + /** + * @private + */ + interface Map { + [key: string]: T; + } + /** + * DragonBones + */ + class DragonBones { + /** + * @private + */ + static PI_D: number; + /** + * @private + */ + static PI_H: number; + /** + * @private + */ + static PI_Q: number; + /** + * @private + */ + static ANGLE_TO_RADIAN: number; + /** + * @private + */ + static RADIAN_TO_ANGLE: number; + /** + * @private + */ + static SECOND_TO_MILLISECOND: number; + static VERSION: string; + /** + * @private + */ + static debug: boolean; + /** + * @private + */ + static debugDraw: boolean; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 基础对象。 + * @version DragonBones 4.5 + */ + abstract class BaseObject { + private static _hashCode; + private static _defaultMaxCount; + private static _maxCountMap; + private static _poolsMap; + private static _returnObject(object); + /** + * @language zh_CN + * 设置每种对象池的最大缓存数量。 + * @param objectConstructor 对象类。 + * @param maxCount 最大缓存数量。 (设置为 0 则不缓存) + * @version DragonBones 4.5 + */ + static setMaxCount(objectConstructor: typeof BaseObject, maxCount: number): void; + /** + * @language zh_CN + * 清除对象池缓存的对象。 + * @param objectConstructor 对象类。 (不设置则清除所有缓存) + * @version DragonBones 4.5 + */ + static clearPool(objectConstructor?: typeof BaseObject): void; + /** + * @language zh_CN + * 从对象池中创建指定对象。 + * @param objectConstructor 对象类。 + * @version DragonBones 4.5 + */ + static borrowObject(objectConstructor: { + new (): T; + }): T; + /** + * @language zh_CN + * 对象的唯一标识。 + * @version DragonBones 4.5 + */ + hashCode: number; + /** + * @private + */ + protected abstract _onClear(): void; + /** + * @language zh_CN + * 清除数据并返还对象池。 + * @version DragonBones 4.5 + */ + returnToPool(): void; + } +} +declare namespace dragonBones { +} +declare namespace dragonBones { + /** + * @language zh_CN + * 动画混合时,使用的淡出方式。 + * @see dragonBones.Animation#fadeIn() + * @version DragonBones 4.5 + */ + const enum AnimationFadeOutMode { + /** + * @language zh_CN + * 不淡出动画。 + * @version DragonBones 4.5 + */ + None = 0, + /** + * @language zh_CN + * 淡出同层的动画。 + * @version DragonBones 4.5 + */ + SameLayer = 1, + /** + * @language zh_CN + * 淡出同组的动画。 + * @version DragonBones 4.5 + */ + SameGroup = 2, + /** + * @language zh_CN + * 淡出同层并且同组的动画。 + * @version DragonBones 4.5 + */ + SameLayerAndGroup = 3, + /** + * @language zh_CN + * 淡出所有动画。 + * @version DragonBones 4.5 + */ + All = 4, + } + /** + * @language zh_CN + * 播放动画组件接口。 (Armature 和 WordClock 都实现了该接口) + * 任何实现了此接口的实例都可以加到 WorldClock 时钟中,由时钟统一控制动画的播放。 + * @see dragonBones.WorldClock + * @see dragonBones.Armature + * @version DragonBones 3.0 + */ + interface IAnimateble { + /** + * @language zh_CN + * 更新一个指定的时间。 + * @param passedTime 前进的时间。 (以秒为单位) + * @version DragonBones 3.0 + */ + advanceTime(passedTime: number): void; + } + /** + * @language zh_CN + * 动画控制器,用来播放动画数据,管理动画状态。 + * @see dragonBones.AnimationData + * @see dragonBones.AnimationState + * @version DragonBones 3.0 + */ + class Animation extends BaseObject { + /** + * @private + */ + private static _sortAnimationState(a, b); + /** + * @private + */ + static toString(): string; + /** + * @language zh_CN + * 动画的播放速度。 [(-N~0): 倒转播放, 0: 停止播放, (0~1): 慢速播放, 1: 正常播放, (1~N): 快速播放] + * @default 1 + * @version DragonBones 3.0 + */ + timeScale: number; + /** + * @private + */ + _armature: Armature; + private _isPlaying; + private _time; + private _duration; + private _lastAnimationState; + private _animations; + private _animationNames; + private _animationStates; + /** + * @inheritDoc + */ + protected _onClear(): void; + private _fadeOut(fadeOutTime, layer, group, fadeOutMode, pauseFadeOut); + /** + * @language zh_CN + * 清除所有正在播放的动画状态。 + * @version DragonBones 4.5 + */ + reset(): void; + /** + * @language zh_CN + * 暂停播放动画。 + * @param animationName 动画状态的名称,如果未设置,则暂停所有动画状态。 + * @see dragonBones.AnimationState + * @version DragonBones 3.0 + */ + stop(animationName?: string): void; + /** + * @language zh_CN + * 播放动画。 + * @param animationName 动画数据的名称,如果未设置,则播放默认动画,或将暂停状态切换为播放状态,或重新播放上一个正在播放的动画。 + * @param playTimes 动画需要播放的次数。 [-1: 使用动画数据默认值, 0: 无限循环播放, [1~N]: 循环播放 N 次] + * @returns 返回控制这个动画数据的动画状态。 + * @see dragonBones.AnimationState + * @version DragonBones 3.0 + */ + play(animationName?: string, playTimes?: number): AnimationState; + /** + * @language zh_CN + * 淡入播放指定名称的动画。 + * @param animationName 动画数据的名称。 + * @param playTimes 循环播放的次数。 [-1: 使用数据默认值, 0: 无限循环播放, [1~N]: 循环播放 N 次] + * @param fadeInTime 淡入的时间。 [-1: 使用数据默认值, [0~N]: N 秒淡入完毕] (以秒为单位) + * @param layer 混合的图层,图层高会优先获取混合权重。 + * @param group 混合的组,用于给动画状态编组,方便混合淡出控制。 + * @param fadeOutMode 淡出的模式。 + * @param additiveBlending 以叠加的形式混合。 + * @param displayControl 是否对显示对象属性可控。 + * @param pauseFadeOut 暂停需要淡出的动画。 + * @param pauseFadeIn 暂停需要淡入的动画,直到淡入结束才开始播放。 + * @returns 返回控制这个动画数据的动画状态。 + * @see dragonBones.AnimationFadeOutMode + * @see dragonBones.AnimationState + * @version DragonBones 4.5 + */ + fadeIn(animationName: string, fadeInTime?: number, playTimes?: number, layer?: number, group?: string, fadeOutMode?: AnimationFadeOutMode, additiveBlending?: boolean, displayControl?: boolean, pauseFadeOut?: boolean, pauseFadeIn?: boolean): AnimationState; + /** + * @language zh_CN + * 指定名称的动画从指定时间开始播放。 + * @param animationName 动画数据的名称。 + * @param time 时间。 (以秒为单位) + * @param playTimes 动画循环播放的次数。 [-1: 使用动画数据默认值, 0: 无限循环播放, [1~N]: 循环播放 N 次] + * @param toTime 播放到指定的时间,如果未设置则播放整个动画。 + * @returns 返回控制这个动画数据的动画状态。 + * @see dragonBones.AnimationState + * @version DragonBones 4.5 + */ + gotoAndPlayByTime(animationName: string, time?: number, playTimes?: number, toTime?: number): AnimationState; + /** + * @language zh_CN + * 指定名称的动画从指定帧开始播放。 + * @param animationName 动画数据的名称。 + * @param frame 帧。 + * @param playTimes 动画循环播放的次数。[-1: 使用动画数据默认值, 0: 无限循环播放, [1~N]: 循环播放 N 次] + * @param toFrame 播放到指定的帧,如果未设置则播放整个动画。 + * @returns 返回控制这个动画数据的动画状态。 + * @see dragonBones.AnimationState + * @version DragonBones 4.5 + */ + gotoAndPlayByFrame(animationName: string, frame?: number, playTimes?: number, toFrame?: number): AnimationState; + /** + * @language zh_CN + * 指定名称的动画从指定进度开始播放。 + * @param animationName 动画数据的名称。 + * @param progress 进度。 [0~1] + * @param playTimes 动画循环播放的次数。[-1: 使用动画数据默认值, 0: 无限循环播放, [1~N]: 循环播放 N 次] + * @param toProgress 播放到指定的进度,如果未设置则播放整个动画。 + * @returns 返回控制这个动画数据的动画状态。 + * @see dragonBones.AnimationState + * @version DragonBones 4.5 + */ + gotoAndPlayByProgress(animationName: string, progress?: number, playTimes?: number, toProgress?: number): AnimationState; + /** + * @language zh_CN + * 播放指定名称的动画到指定的时间并停止。 + * @param animationName 动画数据的名称。 + * @param time 时间。 (以秒为单位) + * @returns 返回控制这个动画数据的动画状态。 + * @see dragonBones.AnimationState + * @version DragonBones 4.5 + */ + gotoAndStopByTime(animationName: string, time?: number): AnimationState; + /** + * @language zh_CN + * 播放指定名称的动画到指定的帧并停止。 + * @param animationName 动画数据的名称。 + * @param frame 帧。 + * @returns 返回控制这个动画数据的动画状态。 + * @see dragonBones.AnimationState + * @version DragonBones 4.5 + */ + gotoAndStopByFrame(animationName: string, frame?: number): AnimationState; + /** + * @language zh_CN + * 播放指定名称的动画到指定的进度并停止。 + * @param animationName 动画数据的名称。 + * @param progress 进度。 [0~1] + * @returns 返回控制这个动画数据的动画状态。 + * @see dragonBones.AnimationState + * @version DragonBones 4.5 + */ + gotoAndStopByProgress(animationName: string, progress?: number): AnimationState; + /** + * @language zh_CN + * 获取指定名称的动画状态。 + * @param animationName 动画状态的名称。 + * @see dragonBones.AnimationState + * @version DragonBones 3.0 + */ + getState(animationName: string): AnimationState; + /** + * @language zh_CN + * 是否包含指定名称的动画数据。 + * @param animationName 动画数据的名称。 + * @see dragonBones.AnimationData + * @version DragonBones 3.0 + */ + hasAnimation(animationName: string): boolean; + /** + * @language zh_CN + * 动画是否处于播放状态。 + * @version DragonBones 3.0 + */ + isPlaying: boolean; + /** + * @language zh_CN + * 所有动画状态是否均已播放完毕。 + * @see dragonBones.AnimationState + * @version DragonBones 3.0 + */ + isCompleted: boolean; + /** + * @language zh_CN + * 上一个正在播放的动画状态的名称。 + * @see #lastAnimationState + * @version DragonBones 3.0 + */ + lastAnimationName: string; + /** + * @language zh_CN + * 上一个正在播放的动画状态。 + * @see dragonBones.AnimationState + * @version DragonBones 3.0 + */ + lastAnimationState: AnimationState; + /** + * @language zh_CN + * 所有动画数据名称。 + * @see #animations + * @version DragonBones 4.5 + */ + animationNames: Array; + /** + * @language zh_CN + * 所有的动画数据。 + * @see dragonBones.AnimationData + * @version DragonBones 4.5 + */ + animations: Map; + /** + * @deprecated + * @see #play() + * @see #fadeIn() + * @see #gotoAndPlayByTime() + * @see #gotoAndPlayByFrame() + * @see #gotoAndPlayByProgress() + */ + gotoAndPlay(animationName: string, fadeInTime?: number, duration?: number, playTimes?: number, layer?: number, group?: string, fadeOutMode?: AnimationFadeOutMode, pauseFadeOut?: boolean, pauseFadeIn?: boolean): AnimationState; + /** + * @deprecated + * @see #gotoAndStopByTime() + * @see #gotoAndStopByFrame() + * @see #gotoAndStopByProgress() + */ + gotoAndStop(animationName: string, time?: number): AnimationState; + /** + * @deprecated + * @see #animationNames + * @see #animations + */ + animationList: Array; + /** + * @language zh_CN + * @deprecated + * @see #animationNames + * @see #animations + */ + animationDataList: Array; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 动画状态,播放动画时产生,可以对单个动画的播放进行更细致的控制和调节。 + * @see dragonBones.Animation + * @see dragonBones.AnimationData + * @version DragonBones 3.0 + */ + class AnimationState extends BaseObject { + /** + * @private + */ + static stateActionEnabled: boolean; + /** + * @private + */ + static toString(): string; + /** + * @language zh_CN + * 是否对插槽的颜色,显示序列索引,深度排序,行为等拥有控制的权限。 + * @see dragonBones.Slot#displayController + * @version DragonBones 3.0 + */ + displayControl: boolean; + /** + * @language zh_CN + * 是否以叠加的方式混合动画。 + * @version DragonBones 3.0 + */ + additiveBlending: boolean; + /** + * @private + */ + actionEnabled: boolean; + /** + * @language zh_CN + * 需要播放的次数。 [0: 无限循环播放, [1~N]: 循环播放 N 次] + * @version DragonBones 3.0 + */ + playTimes: number; + /** + * @language zh_CN + * 播放速度。 [(-N~0): 倒转播放, 0: 停止播放, (0~1): 慢速播放, 1: 正常播放, (1~N): 快速播放] + * @default 1 + * @version DragonBones 3.0 + */ + timeScale: number; + /** + * @language zh_CN + * 进行动画混合时的权重。 + * @default 1 + * @version DragonBones 3.0 + */ + weight: number; + /** + * @language zh_CN + * 自动淡出时需要的时间,当设置一个大于等于 0 的值,动画状态将会在播放完成后自动淡出。 (以秒为单位) + * @default -1 + * @version DragonBones 3.0 + */ + autoFadeOutTime: number; + /** + * @private + */ + fadeTotalTime: number; + /** + * @private + */ + private _isPlaying; + /** + * @private + */ + private _isPausePlayhead; + /** + * @private + */ + private _fadeTime; + /** + * @private + */ + private _time; + /** + * @private + */ + private _name; + /** + * @private + */ + private _armature; + /** + * @private + */ + private _animationData; + /** + * @private + */ + private _zOrderTimeline; + /** + * @private + */ + private _boneMask; + /** + * @private + */ + private _boneTimelines; + /** + * @private + */ + private _slotTimelines; + /** + * @private + */ + private _ffdTimelines; + /** + * @inheritDoc + */ + protected _onClear(): void; + private _updateTimelineStates(); + private _advanceFadeTime(passedTime); + /** + * @language zh_CN + * 继续播放。 + * @version DragonBones 3.0 + */ + play(): void; + /** + * @language zh_CN + * 暂停播放。 + * @version DragonBones 3.0 + */ + stop(): void; + /** + * @language zh_CN + * 淡出动画。 + * @param fadeOutTime 淡出时间。 (以秒为单位) + * @param pausePlayhead 淡出时是否暂停动画。 [true: 暂停, false: 不暂停] + * @version DragonBones 3.0 + */ + fadeOut(fadeOutTime: number, pausePlayhead?: boolean): void; + /** + * @language zh_CN + * 是否包含指定的骨骼遮罩。 + * @param name 指定的骨骼名称。 + * @version DragonBones 3.0 + */ + containsBoneMask(name: string): boolean; + /** + * @language zh_CN + * 添加指定的骨骼遮罩。 + * @param boneName 指定的骨骼名称。 + * @param recursive 是否为该骨骼的子骨骼添加遮罩。 + * @version DragonBones 3.0 + */ + addBoneMask(name: string, recursive?: boolean): void; + /** + * @language zh_CN + * 删除指定的骨骼遮罩。 + * @param boneName 指定的骨骼名称。 + * @param recursive 是否删除该骨骼的子骨骼遮罩。 + * @version DragonBones 3.0 + */ + removeBoneMask(name: string, recursive?: boolean): void; + /** + * @language zh_CN + * 删除所有骨骼遮罩。 + * @version DragonBones 3.0 + */ + removeAllBoneMask(): void; + /** + * @language zh_CN + * 动画图层。 + * @see dragonBones.Animation#fadeIn() + * @version DragonBones 3.0 + */ + layer: number; + /** + * @language zh_CN + * 动画组。 + * @see dragonBones.Animation#fadeIn() + * @version DragonBones 3.0 + */ + group: string; + /** + * @language zh_CN + * 动画名称。 + * @see dragonBones.AnimationData#name + * @version DragonBones 3.0 + */ + name: string; + /** + * @language zh_CN + * 动画数据。 + * @see dragonBones.AnimationData + * @version DragonBones 3.0 + */ + animationData: AnimationData; + /** + * @language zh_CN + * 是否播放完毕。 + * @version DragonBones 3.0 + */ + isCompleted: boolean; + /** + * @language zh_CN + * 是否正在播放。 + * @version DragonBones 3.0 + */ + isPlaying: boolean; + /** + * @language zh_CN + * 当前动画的播放次数。 + * @version DragonBones 3.0 + */ + currentPlayTimes: number; + /** + * @language zh_CN + * 当前动画的总时间。 (以秒为单位) + * @version DragonBones 3.0 + */ + totalTime: number; + /** + * @language zh_CN + * 当前动画的播放时间。 (以秒为单位) + * @version DragonBones 3.0 + */ + currentTime: number; + /** + * @deprecated + */ + autoTween: boolean; + /** + * @deprecated + * @see #animationData + */ + clip: AnimationData; + } +} +declare namespace dragonBones { +} +declare namespace dragonBones { + /** + * @language zh_CN + * WorldClock 提供时钟的支持,为每个加入到时钟的 IAnimatable 对象更新时间。 + * @see dragonBones.IAnimatable + * @see dragonBones.Armature + * @version DragonBones 3.0 + */ + class WorldClock implements IAnimateble { + private static _clock; + /** + * @language zh_CN + * 一个可以直接使用的全局 WorldClock 实例. + * @version DragonBones 3.0 + */ + static clock: WorldClock; + /** + * @language zh_CN + * 当前的时间。 (以秒为单位) + * @version DragonBones 3.0 + */ + time: number; + /** + * @language zh_CN + * 时间流逝的速度,用于实现动画的变速播放。 [0: 停止播放, (0~1): 慢速播放, 1: 正常播放, (1~N): 快速播放] + * @default 1 + * @version DragonBones 3.0 + */ + timeScale: number; + private _animatebles; + /** + * @language zh_CN + * 创建一个新的 WorldClock 实例。 + * 通常并不需要单独创建 WorldClock 的实例,可以直接使用 WorldClock.clock 静态实例。 + * (创建更多独立的 WorldClock 可以更灵活的为需要更新的 IAnimateble 实例分组,实现不同组不同速度的动画播放) + * @version DragonBones 3.0 + */ + constructor(); + /** + * @language zh_CN + * 为所有的 IAnimatable 实例向前播放一个指定的时间。 (通常这个方法需要在 ENTER_FRAME 事件的响应函数中被调用) + * @param passedTime 前进的时间。 (以秒为单位,当设置为 -1 时将自动计算当前帧与上一帧的时间差) + * @version DragonBones 3.0 + */ + advanceTime(passedTime: number): void; + /** + * 是否包含指定的 IAnimatable 实例 + * @param value 指定的 IAnimatable 实例。 + * @returns [true: 包含,false: 不包含]。 + * @version DragonBones 3.0 + */ + contains(value: IAnimateble): boolean; + /** + * @language zh_CN + * 添加指定的 IAnimatable 实例。 + * @param value IAnimatable 实例。 + * @version DragonBones 3.0 + */ + add(value: IAnimateble): void; + /** + * @language zh_CN + * 移除指定的 IAnimatable 实例。 + * @param value IAnimatable 实例。 + * @version DragonBones 3.0 + */ + remove(value: IAnimateble): void; + /** + * @language zh_CN + * 清除所有的 IAnimatable 实例。 + * @version DragonBones 3.0 + */ + clear(): void; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 基础变换对象。 + * @version DragonBones 4.5 + */ + abstract class TransformObject extends BaseObject { + /** + * @language zh_CN + * 可以用于存储临时数据。 + * @version DragonBones 3.0 + */ + userData: any; + /** + * @language zh_CN + * 对象的名称。 + * @version DragonBones 3.0 + */ + name: string; + /** + * @language zh_CN + * 相对于骨架坐标系的矩阵。 + * @version DragonBones 3.0 + */ + globalTransformMatrix: Matrix; + /** + * @language zh_CN + * 相对于骨架坐标系的变换。 + * @see dragonBones.Transform + * @version DragonBones 3.0 + */ + global: Transform; + /** + * @language zh_CN + * 相对于骨架或父骨骼坐标系的绑定变换。 + * @see dragonBones.Transform + * @version DragonBones 3.0 + */ + origin: Transform; + /** + * @language zh_CN + * 相对于骨架或父骨骼坐标系的偏移变换。 + * @see dragonBones.Transform + * @version DragonBones 3.0 + */ + offset: Transform; + /** + * @private + */ + _armature: Armature; + /** + * @private + */ + _parent: Bone; + /** + * @private + */ + protected _globalTransformMatrix: Matrix; + /** + * @inheritDoc + */ + protected _onClear(): void; + /** + * @language zh_CN + * 所属的骨架。 + * @see dragonBones.Armature + * @version DragonBones 3.0 + */ + armature: Armature; + /** + * @language zh_CN + * 所属的父骨骼。 + * @see dragonBones.Bone + * @version DragonBones 3.0 + */ + parent: Bone; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 骨架,是骨骼动画系统的核心,由显示容器、骨骼、插槽、动画、事件系统构成。 + * @see dragonBones.ArmatureData + * @see dragonBones.Bone + * @see dragonBones.Slot + * @see dragonBones.Animation + * @see dragonBones.IArmatureDisplay + * @version DragonBones 3.0 + */ + class Armature extends BaseObject implements IAnimateble { + /** + * @private + */ + static toString(): string; + private static _onSortSlots(a, b); + /** + * @language zh_CN + * 可以用于存储临时数据。 + * @version DragonBones 3.0 + */ + userData: any; + /** + * @private + */ + _cacheFrameIndex: number; + /** + * @private + */ + _armatureData: ArmatureData; + /** + * @private + */ + _skinData: SkinData; + /** + * @private + */ + _animation: Animation; + /** + * @private + */ + _display: IArmatureDisplay; + /** + * @private + */ + _eventManager: IEventDispatcher; + private _delayDispose; + private _lockDispose; + private _slotsDirty; + private _replacedTexture; + private _bones; + private _slots; + private _actions; + private _events; + /** + * @inheritDoc + */ + protected _onClear(): void; + private _sortBones(); + private _sortSlots(); + private _doAction(value); + /** + * @private + */ + _sortZOrder(slotIndices: Array): void; + /** + * @private + */ + _bufferAction(value: ActionData): void; + /** + * @language zh_CN + * 释放骨架。 (会回收到内存池) + * @version DragonBones 3.0 + */ + dispose(): void; + /** + * @language zh_CN + * 更新骨架和动画。 (可以使用时钟实例或显示容器来更新) + * @param passedTime 两帧之前的时间间隔。 (以秒为单位) + * @see dragonBones.IAnimateble + * @see dragonBones.WorldClock + * @see dragonBones.IArmatureDisplay + * @version DragonBones 3.0 + */ + advanceTime(passedTime: number): void; + /** + * @language zh_CN + * 更新骨骼和插槽的变换。 (当骨骼没有动画状态或动画状态播放完成时,骨骼将不在更新) + * @param boneName 指定的骨骼名称,如果未设置,将更新所有骨骼。 + * @param updateSlotDisplay 是否更新插槽的显示对象。 + * @see dragonBones.Bone + * @see dragonBones.Slot + * @version DragonBones 3.0 + */ + invalidUpdate(boneName?: string, updateSlotDisplay?: boolean): void; + /** + * @language zh_CN + * 获取指定名称的骨骼。 + * @param name 骨骼的名称。 + * @returns 骨骼。 + * @see dragonBones.Bone + * @version DragonBones 3.0 + */ + getBone(name: string): Bone; + /** + * @language zh_CN + * 通过显示对象获取骨骼。 + * @param display 显示对象。 + * @returns 包含这个显示对象的骨骼。 + * @see dragonBones.Bone + * @version DragonBones 3.0 + */ + getBoneByDisplay(display: any): Bone; + /** + * @language zh_CN + * 获取指定名称的插槽。 + * @param name 插槽的名称。 + * @returns 插槽。 + * @see dragonBones.Slot + * @version DragonBones 3.0 + */ + getSlot(name: string): Slot; + /** + * @language zh_CN + * 通过显示对象获取插槽。 + * @param display 显示对象。 + * @returns 包含这个显示对象的插槽。 + * @see dragonBones.Slot + * @version DragonBones 3.0 + */ + getSlotByDisplay(display: any): Slot; + /** + * @language zh_CN + * 替换骨架的主贴图,根据渲染引擎的不同,提供不同的贴图数据。 + * @param texture 贴图。 + * @version DragonBones 4.5 + */ + replaceTexture(texture: any): void; + /** + * @language zh_CN + * 获取所有骨骼。 + * @see dragonBones.Bone + * @version DragonBones 3.0 + */ + getBones(): Array; + /** + * @language zh_CN + * 获取所有插槽。 + * @see dragonBones.Slot + * @version DragonBones 3.0 + */ + getSlots(): Array; + /** + * @language zh_CN + * 骨架名称。 + * @see dragonBones.ArmatureData#name + * @version DragonBones 3.0 + */ + name: string; + /** + * @language zh_CN + * 获取骨架数据。 + * @see dragonBones.ArmatureData + * @version DragonBones 4.5 + */ + armatureData: ArmatureData; + /** + * @language zh_CN + * 获得动画控制器。 + * @see dragonBones.Animation + * @version DragonBones 3.0 + */ + animation: Animation; + /** + * @language zh_CN + * 获取显示容器,插槽的显示对象都会以此显示容器为父级,根据渲染平台的不同,类型会不同,通常是 DisplayObjectContainer 类型。 + * @version DragonBones 3.0 + */ + display: IArmatureDisplay | any; + /** + * @language zh_CN + * 获取父插槽。 (当此骨架是某个骨架的子骨架时,可以通过此属性向上查找从属关系) + * @see dragonBones.Slot + * @version DragonBones 4.5 + */ + parent: Slot; + /** + * @language zh_CN + * 动画缓存的帧率,当设置一个大于 0 的帧率时,将会开启动画缓存。 + * 通过将动画数据缓存在内存中来提高运行性能,会有一定的内存开销。 + * 帧率不宜设置的过高,通常跟动画的帧率相当且低于程序运行的帧率。 + * 开启动画缓存后,某些功能将会失效,比如 Bone 和 Slot 的 offset 属性等。 + * @see dragonBones.DragonBonesData#frameRate + * @see dragonBones.ArmatureData#frameRate + * @version DragonBones 4.5 + */ + cacheFrameRate: number; + /** + * @language zh_CN + * 替换骨架的主贴图,根据渲染引擎的不同,提供不同的贴图数据。 + * @version DragonBones 4.5 + */ + replacedTexture: any; + /** + * @language zh_CN + * 开启动画缓存。 + * @param frameRate 动画缓存的帧率 + * @see #cacheFrameRate + * @version DragonBones 4.5 + */ + enableAnimationCache(frameRate: number): void; + /** + * @language zh_CN + * 是否包含指定类型的事件。 + * @param type 事件类型。 + * @returns [true: 包含, false: 不包含] + * @version DragonBones 3.0 + */ + hasEventListener(type: EventStringType): void; + /** + * @language zh_CN + * 添加事件。 + * @param type 事件类型。 + * @param listener 事件回调。 + * @version DragonBones 3.0 + */ + addEventListener(type: EventStringType, listener: Function, target: any): void; + /** + * @language zh_CN + * 移除事件。 + * @param type 事件类型。 + * @param listener 事件回调。 + * @version DragonBones 3.0 + */ + removeEventListener(type: EventStringType, listener: Function, target: any): void; + /** + * @deprecated + */ + addBone(value: Bone, parentName?: string): void; + /** + * @deprecated + */ + addSlot(value: Slot, parentName: string): void; + /** + * @deprecated + */ + removeBone(value: Bone): void; + /** + * @deprecated + */ + removeSlot(value: Slot): void; + /** + * @deprecated + * @see #display + */ + getDisplay(): any; + /** + * @deprecated + * @see #cacheFrameRate + */ + enableCache: boolean; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 骨骼,一个骨架中可以包含多个骨骼,骨骼以树状结构组成骨架。 + * 骨骼在骨骼动画体系中是最重要的逻辑单元之一,负责动画中的平移旋转缩放的实现。 + * @see dragonBones.BoneData + * @see dragonBones.Armature + * @see dragonBones.Slot + * @version DragonBones 3.0 + */ + class Bone extends TransformObject { + /** + * @private + */ + static toString(): string; + /** + * @language zh_CN + * 是否继承父骨骼的平移。 [true: 继承, false: 不继承] + * @version DragonBones 3.0 + */ + inheritTranslation: boolean; + /** + * @language zh_CN + * 是否继承父骨骼的旋转。 [true: 继承, false: 不继承] + * @version DragonBones 3.0 + */ + inheritRotation: boolean; + /** + * @language zh_CN + * 是否继承父骨骼的缩放。 [true: 继承, false: 不继承] + * @version DragonBones 4.5 + */ + inheritScale: boolean; + /** + * @language zh_CN + * IK 约束时骨骼方向是否为顺时针方向。 [true: 顺时针, false: 逆时针] + * @version DragonBones 4.5 + */ + ikBendPositive: boolean; + /** + * @language zh_CN + * IK 约束的权重。 + * @version DragonBones 4.5 + */ + ikWeight: number; + /** + * @language zh_CN + * 骨骼长度。 + * @version DragonBones 4.5 + */ + length: number; + /** + * @private + */ + private _visible; + /** + * @private + */ + private _ikChain; + /** + * @private + */ + private _ikChainIndex; + /** + * @private + */ + private _ik; + /** + * @private + */ + private _bones; + /** + * @private + */ + private _slots; + /** + * @inheritDoc + */ + protected _onClear(): void; + /** + * @private + */ + private _updateGlobalTransformMatrix(); + /** + * @private + */ + private _computeIKA(); + /** + * @private + */ + private _computeIKB(); + /** + * @inheritDoc + */ + _setArmature(value: Armature): void; + /** + * @language zh_CN + * 下一帧更新变换。 (当骨骼没有动画状态或动画状态播放完成时,骨骼将不在更新) + * @version DragonBones 3.0 + */ + invalidUpdate(): void; + /** + * @language zh_CN + * 是否包含某个指定的骨骼或插槽。 + * @returns [true: 包含,false: 不包含] + * @see dragonBones.TransformObject + * @version DragonBones 3.0 + */ + contains(child: TransformObject): boolean; + /** + * @language zh_CN + * 所有的子骨骼。 + * @version DragonBones 3.0 + */ + getBones(): Array; + /** + * @language zh_CN + * 所有的插槽。 + * @see dragonBones.Slot + * @version DragonBones 3.0 + */ + getSlots(): Array; + /** + * @private + */ + ikChain: number; + /** + * @private + */ + ikChainIndex: number; + /** + * @language zh_CN + * 当前的 IK 约束目标。 + * @version DragonBones 4.5 + */ + ik: Bone; + /** + * @language zh_CN + * 控制此骨骼所有插槽的显示。 + * @default true + * @see dragonBones.Slot + * @version DragonBones 3.0 + */ + visible: boolean; + /** + * @deprecated + * @see dragonBones.Armature#getSlot() + */ + slot: Slot; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 骨架显示容器和事件的接口。 + * @see dragonBones.Armature#display + * @version DragonBones 4.5 + */ + interface IArmatureDisplay extends IEventDispatcher { + /** + * @language zh_CN + * 释放显示对象和骨架。 + * @version DragonBones 4.5 + */ + dispose(): void; + /** + * @language zh_CN + * 获取使用这个显示容器的骨架。 + * @readOnly + * @see dragonBones.Armature + * @version DragonBones 4.5 + */ + armature: Armature; + /** + * @language zh_CN + * 获取使用骨架的动画控制器。 + * @readOnly + * @see dragonBones.Animation + * @version DragonBones 4.5 + */ + animation: Animation; + /** + * @language zh_CN + * 由显示容器来更新骨架和动画。 + * @param on 开启或关闭显示容器对骨架与动画的更新。 + * @version DragonBones 4.5 + */ + advanceTimeBySelf(on: boolean): void; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 插槽,附着在骨骼上,控制显示对象的显示状态和属性。 + * 一个骨骼上可以包含多个插槽。 + * 一个插槽中可以包含多个显示对象,同一时间只能显示其中的一个显示对象,但可以在动画播放的过程中切换显示对象实现帧动画。 + * 显示对象可以是普通的图片纹理,也可以是子骨架的显示容器,网格显示对象,还可以是自定义的其他显示对象。 + * @see dragonBones.Armature + * @see dragonBones.Bone + * @see dragonBones.SlotData + * @version DragonBones 3.0 + */ + abstract class Slot extends TransformObject { + private static _helpPoint; + private static _helpMatrix; + /** + * @language zh_CN + * 子骨架是否继承父骨架的动画。 [true: 继承, false: 不继承] + * @default true + * @version DragonBones 4.5 + */ + inheritAnimation: boolean; + /** + * @language zh_CN + * 显示对象受到控制的对象,应设置为动画状态的名称或组名称,设置为 null 则表示受所有的动画状态控制。 + * @default null + * @see dragonBones.AnimationState#displayControl + * @see dragonBones.AnimationState#name + * @see dragonBones.AnimationState#group + * @version DragonBones 4.5 + */ + displayController: string; + /** + * @private + */ + _zOrder: number; + /** + * @private + */ + _pivotX: number; + /** + * @private + */ + _pivotY: number; + /** + * @private + */ + _displayDataSet: SlotDisplayDataSet; + /** + * @private + */ + _meshData: MeshData; + /** + * @private + */ + _childArmature: Armature; + /** + * @private + */ + _rawDisplay: any; + /** + * @private + */ + _meshDisplay: any; + /** + * @private + */ + _cacheFrames: Array; + /** + * @private + */ + _colorTransform: ColorTransform; + /** + * @private + */ + _ffdVertices: Array; + /** + * @private + */ + _replacedDisplayDataSet: Array; + /** + * @private + */ + protected _displayDirty: boolean; + /** + * @private + */ + protected _blendModeDirty: boolean; + /** + * @private + */ + protected _originDirty: boolean; + /** + * @private + */ + protected _transformDirty: boolean; + /** + * @private + */ + protected _displayIndex: number; + /** + * @private + */ + protected _blendMode: BlendMode; + /** + * @private + */ + protected _display: any; + /** + * @private + */ + protected _localMatrix: Matrix; + /** + * @private + */ + protected _displayList: Array; + /** + * @private + */ + protected _meshBones: Array; + /** + * @inheritDoc + */ + protected _onClear(): void; + /** + * @private + */ + protected abstract _initDisplay(value: any): void; + /** + * @private + */ + protected abstract _disposeDisplay(value: any): void; + /** + * @private + */ + protected abstract _onUpdateDisplay(): void; + /** + * @private + */ + protected abstract _addDisplay(): void; + /** + * @private + */ + protected abstract _replaceDisplay(value: any): void; + /** + * @private + */ + protected abstract _removeDisplay(): void; + /** + * @private + */ + protected abstract _updateZOrder(): void; + /** + * @private + */ + protected abstract _updateBlendMode(): void; + /** + * @private + */ + protected abstract _updateColor(): void; + /** + * @private + */ + protected abstract _updateFilters(): void; + /** + * @private + */ + protected abstract _updateFrame(): void; + /** + * @private + */ + protected abstract _updateMesh(): void; + /** + * @private + */ + protected abstract _updateTransform(): void; + private _isMeshBonesUpdate(); + /** + * @private + */ + protected _updatePivot(rawDisplayData: DisplayData, currentDisplayData: DisplayData, currentTextureData: TextureData): void; + /** + * @private + */ + protected _updateDisplay(): void; + /** + * @private + */ + protected _updateLocalTransformMatrix(): void; + /** + * @private + */ + protected _updateGlobalTransformMatrix(): void; + /** + * @private Factory + */ + _setDisplayList(value: Array): boolean; + /** + * @language zh_CN + * 在下一帧更新显示对象的状态。 + * @version DragonBones 4.5 + */ + invalidUpdate(): void; + /** + * @private + */ + rawDisplay: any; + /** + * @private + */ + MeshDisplay: any; + /** + * @language zh_CN + * 此时显示的显示对象在显示列表中的索引。 + * @version DragonBones 4.5 + */ + displayIndex: number; + /** + * @language zh_CN + * 包含显示对象或子骨架的显示列表。 + * @version DragonBones 3.0 + */ + displayList: Array; + /** + * @language zh_CN + * 此时显示的显示对象。 + * @version DragonBones 3.0 + */ + display: any; + /** + * @language zh_CN + * 此时显示的子骨架。 + * @see dragonBones.Armature + * @version DragonBones 3.0 + */ + childArmature: Armature; + /** + * @deprecated + * @see #display + */ + getDisplay(): any; + /** + * @deprecated + * @see #display + */ + setDisplay(value: any): void; + } +} +declare namespace dragonBones { + /** + * @private + */ + type EventStringType = string | "start" | "loopComplete" | "complete" | "fadeIn" | "fadeInComplete" | "fadeOut" | "fadeOutComplete" | "frameEvent" | "soundEvent"; + /** + * @language zh_CN + * 事件接口。 + * @version DragonBones 4.5 + */ + interface IEventDispatcher { + /** + * @language zh_CN + * 是否包含指定类型的事件。 + * @param type 事件类型。 + * @returns [true: 包含, false: 不包含] + * @version DragonBones 4.5 + */ + hasEvent(type: EventStringType): boolean; + /** + * @language zh_CN + * 添加事件。 + * @param type 事件类型。 + * @param listener 事件回调。 + * @version DragonBones 4.5 + */ + addEvent(type: EventStringType, listener: Function, target: any): void; + /** + * @language zh_CN + * 移除事件。 + * @param type 事件类型。 + * @param listener 事件回调。 + * @version DragonBones 4.5 + */ + removeEvent(type: EventStringType, listener: Function, target: any): void; + } + /** + * @language zh_CN + * 事件数据。 + * @version DragonBones 4.5 + */ + class EventObject extends BaseObject { + /** + * @language zh_CN + * 动画开始。 + * @version DragonBones 4.5 + */ + static START: string; + /** + * @language zh_CN + * 动画循环播放一次完成。 + * @version DragonBones 4.5 + */ + static LOOP_COMPLETE: string; + /** + * @language zh_CN + * 动画播放完成。 + * @version DragonBones 4.5 + */ + static COMPLETE: string; + /** + * @language zh_CN + * 动画淡入开始。 + * @version DragonBones 4.5 + */ + static FADE_IN: string; + /** + * @language zh_CN + * 动画淡入完成。 + * @version DragonBones 4.5 + */ + static FADE_IN_COMPLETE: string; + /** + * @language zh_CN + * 动画淡出开始。 + * @version DragonBones 4.5 + */ + static FADE_OUT: string; + /** + * @language zh_CN + * 动画淡出完成。 + * @version DragonBones 4.5 + */ + static FADE_OUT_COMPLETE: string; + /** + * @language zh_CN + * 动画帧事件。 + * @version DragonBones 4.5 + */ + static FRAME_EVENT: string; + /** + * @language zh_CN + * 动画声音事件。 + * @version DragonBones 4.5 + */ + static SOUND_EVENT: string; + /** + * @private + */ + static toString(): string; + /** + * @language zh_CN + * 事件类型。 + * @version DragonBones 4.5 + */ + type: EventStringType; + /** + * @language zh_CN + * 事件名称。 (帧标签的名称或声音的名称) + * @version DragonBones 4.5 + */ + name: string; + /** + * @language zh_CN + * 扩展的数据。 + * @version DragonBones 4.5 + */ + data: any; + /** + * @language zh_CN + * 发出事件的骨架。 + * @version DragonBones 4.5 + */ + armature: Armature; + /** + * @language zh_CN + * 发出事件的骨骼。 + * @version DragonBones 4.5 + */ + bone: Bone; + /** + * @language zh_CN + * 发出事件的插槽。 + * @version DragonBones 4.5 + */ + slot: Slot; + /** + * @language zh_CN + * 发出事件的动画状态。 + * @version DragonBones 4.5 + */ + animationState: AnimationState; + /** + * @private + */ + frame: AnimationFrameData; + /** + * @language zh_CN + * 用户数据。 + * @version DragonBones 4.5 + */ + userData: any; + /** + * @inheritDoc + */ + protected _onClear(): void; + } +} +declare namespace dragonBones { + /** + * @private + */ + class ColorTransform { + alphaMultiplier: number; + redMultiplier: number; + greenMultiplier: number; + blueMultiplier: number; + alphaOffset: number; + redOffset: number; + greenOffset: number; + blueOffset: number; + constructor(alphaMultiplier?: number, redMultiplier?: number, greenMultiplier?: number, blueMultiplier?: number, alphaOffset?: number, redOffset?: number, greenOffset?: number, blueOffset?: number); + copyFrom(value: ColorTransform): void; + identity(): void; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 2D 矩阵。 + * @version DragonBones 3.0 + */ + class Matrix { + a: number; + b: number; + c: number; + d: number; + tx: number; + ty: number; + constructor(a?: number, b?: number, c?: number, d?: number, tx?: number, ty?: number); + /** + * @private + */ + toString(): string; + /** + * @language zh_CN + * 复制矩阵。 + * @param value 需要复制的矩阵。 + * @version DragonBones 3.0 + */ + copyFrom(value: Matrix): void; + /** + * @language zh_CN + * 转换为恒等矩阵。 + * @version DragonBones 3.0 + */ + identity(): void; + /** + * @language zh_CN + * 将当前矩阵与另一个矩阵相乘。 + * @param value 需要相乘的矩阵。 + * @version DragonBones 3.0 + */ + concat(value: Matrix): void; + /** + * @language zh_CN + * 转换为逆矩阵。 + * @version DragonBones 3.0 + */ + invert(): void; + /** + * @language zh_CN + * 将矩阵转换应用于指定点。 + * @param x 横坐标。 + * @param y 纵坐标。 + * @param result 应用转换之后的坐标。 + * @params delta 是否忽略 tx,ty 对坐标的转换。 + * @version DragonBones 3.0 + */ + transformPoint(x: number, y: number, result: { + x: number; + y: number; + }, delta?: boolean): void; + } +} +declare namespace dragonBones { + /** + * @private + */ + class Point { + x: number; + y: number; + constructor(x?: number, y?: number); + copyFrom(value: Point): void; + clear(): void; + } +} +declare namespace dragonBones { + /** + * @private + */ + class Rectangle { + x: number; + y: number; + width: number; + height: number; + constructor(x?: number, y?: number, width?: number, height?: number); + copyFrom(value: Rectangle): void; + clear(): void; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 2D 变换。 + * @version DragonBones 3.0 + */ + class Transform { + /** + * @language zh_CN + * 水平位移。 + * @version DragonBones 3.0 + */ + x: number; + /** + * @language zh_CN + * 垂直位移。 + * @version DragonBones 3.0 + */ + y: number; + /** + * @language zh_CN + * 水平倾斜。 (以弧度为单位) + * @version DragonBones 3.0 + */ + skewX: number; + /** + * @language zh_CN + * 垂直倾斜。 (以弧度为单位) + * @version DragonBones 3.0 + */ + skewY: number; + /** + * @language zh_CN + * 水平缩放。 + * @version DragonBones 3.0 + */ + scaleX: number; + /** + * @language zh_CN + * 垂直缩放。 + * @version DragonBones 3.0 + */ + scaleY: number; + /** + * @private + */ + static normalizeRadian(value: number): number; + /** + * @private + */ + constructor( + /** + * @language zh_CN + * 水平位移。 + * @version DragonBones 3.0 + */ + x?: number, + /** + * @language zh_CN + * 垂直位移。 + * @version DragonBones 3.0 + */ + y?: number, + /** + * @language zh_CN + * 水平倾斜。 (以弧度为单位) + * @version DragonBones 3.0 + */ + skewX?: number, + /** + * @language zh_CN + * 垂直倾斜。 (以弧度为单位) + * @version DragonBones 3.0 + */ + skewY?: number, + /** + * @language zh_CN + * 水平缩放。 + * @version DragonBones 3.0 + */ + scaleX?: number, + /** + * @language zh_CN + * 垂直缩放。 + * @version DragonBones 3.0 + */ + scaleY?: number); + /** + * @private + */ + toString(): string; + /** + * @private + */ + copyFrom(value: Transform): Transform; + /** + * @private + */ + identity(): Transform; + /** + * @private + */ + add(value: Transform): Transform; + /** + * @private + */ + minus(value: Transform): Transform; + /** + * @private + */ + fromMatrix(matrix: Matrix): Transform; + /** + * @language zh_CN + * 转换为矩阵。 + * @param 矩阵。 + * @version DragonBones 3.0 + */ + toMatrix(matrix: Matrix): Transform; + /** + * @language zh_CN + * 旋转。 (以弧度为单位) + * @version DragonBones 3.0 + */ + rotation: number; + } +} +declare namespace dragonBones { + /** + * @private + */ + abstract class TimelineData> extends BaseObject { + /** + * @private + */ + static toString(): string; + scale: number; + /** + * @private + */ + offset: number; + /** + * @private + */ + frames: Array; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @private + */ + class ZOrderTimelineData extends TimelineData { + static toString(): string; + } + /** + * @private + */ + class BoneTimelineData extends TimelineData { + static cacheFrame(cacheFrames: Array, cacheFrameIndex: number, globalTransformMatrix: Matrix): Matrix; + static toString(): string; + bone: BoneData; + originalTransform: Transform; + cachedFrames: Array; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + cacheFrames(cacheFrameCount: number): void; + } + /** + * @private + */ + class SlotTimelineData extends TimelineData { + static cacheFrame(cacheFrames: Array, cacheFrameIndex: number, globalTransformMatrix: Matrix): Matrix; + static toString(): string; + slot: SlotData; + cachedFrames: Array; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + cacheFrames(cacheFrameCount: number): void; + } + /** + * @private + */ + class FFDTimelineData extends TimelineData { + static toString(): string; + displayIndex: number; + skin: SkinData; + slot: SlotDisplayDataSet; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 动画数据。 + * @version DragonBones 3.0 + */ + class AnimationData extends TimelineData { + /** + * @private + */ + static toString(): string; + /** + * @private + */ + hasAsynchronyTimeline: boolean; + /** + * @language zh_CN + * 持续的帧数。 + * @version DragonBones 3.0 + */ + frameCount: number; + /** + * @language zh_CN + * 循环播放的次数。 [0: 无限循环播放, [1~N]: 循环播放 N 次] + * @version DragonBones 3.0 + */ + playTimes: number; + /** + * @language zh_CN + * 开始的时间。 (以秒为单位) + * @version DragonBones 3.0 + */ + position: number; + /** + * @language zh_CN + * 持续的时间。 (以秒为单位) + * @version DragonBones 3.0 + */ + duration: number; + /** + * @language zh_CN + * 淡入混合的时间。 (以秒为单位) + * @version DragonBones 3.0 + */ + fadeInTime: number; + /** + * @private + */ + cacheTimeToFrameScale: number; + /** + * @language zh_CN + * 数据名称。 + * @version DragonBones 3.0 + */ + name: string; + /** + * @private + */ + animation: AnimationData; + /** + * @private + */ + zOrderTimeline: TimelineData; + /** + * @private + */ + boneTimelines: Map; + /** + * @private + */ + slotTimelines: Map; + /** + * @private + */ + ffdTimelines: Map>>; + /** + * @private + */ + cachedFrames: Array; + /** + * @private + */ + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + /** + * @private + */ + cacheFrames(value: number): void; + /** + * @private + */ + addBoneTimeline(value: BoneTimelineData): void; + /** + * @private + */ + addSlotTimeline(value: SlotTimelineData): void; + /** + * @private + */ + addFFDTimeline(value: FFDTimelineData): void; + /** + * @private + */ + getBoneTimeline(name: string): BoneTimelineData; + /** + * @private + */ + getSlotTimeline(name: string): SlotTimelineData; + /** + * @private + */ + getFFDTimeline(skinName: string, slotName: string, displayIndex: number): FFDTimelineData; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 骨架数据。 + * @see dragonBones.Armature + * @version DragonBones 3.0 + */ + class ArmatureData extends BaseObject { + private static _onSortSlots(a, b); + /** + * @private + */ + static toString(): string; + /** + * @language zh_CN + * 动画帧率。 + * @version DragonBones 3.0 + */ + frameRate: number; + /** + * @language zh_CN + * 骨架类型。 + * @see dragonBones.ArmatureType + * @version DragonBones 3.0 + */ + type: ArmatureType; + /** + * @language zh_CN + * 数据名称。 + * @version DragonBones 3.0 + */ + name: string; + /** + * @private + */ + parent: DragonBonesData; + /** + * @private + */ + userData: any; + /** + * @private + */ + aabb: Rectangle; + /** + * @language zh_CN + * 所有的骨骼数据。 + * @see dragonBones.BoneData + * @version DragonBones 3.0 + */ + bones: Map; + /** + * @language zh_CN + * 所有的插槽数据。 + * @see dragonBones.SlotData + * @version DragonBones 3.0 + */ + slots: Map; + /** + * @language zh_CN + * 所有的皮肤数据。 + * @see dragonBones.SkinData + * @version DragonBones 3.0 + */ + skins: Map; + /** + * @language zh_CN + * 所有的动画数据。 + * @see dragonBones.AnimationData + * @version DragonBones 3.0 + */ + animations: Map; + /** + * @private + */ + actions: Array; + /** + * @private + */ + cacheFrameRate: number; + /** + * @private + */ + scale: number; + private _boneDirty; + private _slotDirty; + private _defaultSkin; + private _defaultAnimation; + private _sortedBones; + private _sortedSlots; + private _bonesChildren; + /** + * @private + */ + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + private _sortBones(); + private _sortSlots(); + /** + * @private + */ + cacheFrames(value: number): void; + /** + * @private + */ + addBone(value: BoneData, parentName: string): void; + /** + * @private + */ + addSlot(value: SlotData): void; + /** + * @private + */ + addSkin(value: SkinData): void; + /** + * @private + */ + addAnimation(value: AnimationData): void; + /** + * @language zh_CN + * 获取指定名称的骨骼数据。 + * @param name 骨骼数据名称。 + * @see dragonBones.BoneData + * @version DragonBones 3.0 + */ + getBone(name: string): BoneData; + /** + * @language zh_CN + * 获取指定名称的插槽数据。 + * @param name 插槽数据名称。 + * @see dragonBones.SlotData + * @version DragonBones 3.0 + */ + getSlot(name: string): SlotData; + /** + * @language zh_CN + * 获取指定名称的皮肤数据。 + * @param name 皮肤数据名称。 + * @see dragonBones.SkinData + * @version DragonBones 3.0 + */ + getSkin(name: string): SkinData; + /** + * @language zh_CN + * 获取指定名称的动画数据。 + * @param name 动画数据名称。 + * @see dragonBones.AnimationData + * @version DragonBones 3.0 + */ + getAnimation(name: string): AnimationData; + /** + * @private + */ + sortedBones: Array; + /** + * @private + */ + sortedSlots: Array; + /** + * @language zh_CN + * 获取默认的皮肤数据。 + * @see dragonBones.SkinData + * @version DragonBones 4.5 + */ + defaultSkin: SkinData; + /** + * @language zh_CN + * 获取默认的动画数据。 + * @see dragonBones.AnimationData + * @version DragonBones 4.5 + */ + defaultAnimation: AnimationData; + } + /** + * @language zh_CN + * 骨骼数据。 + * @see dragonBones.Bone + * @version DragonBones 3.0 + */ + class BoneData extends BaseObject { + /** + * @private + */ + static toString(): string; + /** + * @private + */ + inheritTranslation: boolean; + /** + * @private + */ + inheritRotation: boolean; + /** + * @private + */ + inheritScale: boolean; + /** + * @private + */ + bendPositive: boolean; + /** + * @private + */ + chain: number; + /** + * @private + */ + chainIndex: number; + /** + * @private + */ + weight: number; + /** + * @private + */ + length: number; + /** + * @language zh_CN + * 数据名称。 + * @version DragonBones 3.0 + */ + name: string; + /** + * @language zh_CN + * 所属的父骨骼数据。 + * @version DragonBones 3.0 + */ + parent: BoneData; + /** + * @private + */ + ik: BoneData; + /** + * @private + */ + transform: Transform; + /** + * @private + */ + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @language zh_CN + * 插槽数据。 + * @see dragonBones.Slot + * @version DragonBones 3.0 + */ + class SlotData extends BaseObject { + /** + * @private + */ + static DEFAULT_COLOR: ColorTransform; + /** + * @private + */ + static generateColor(): ColorTransform; + /** + * @private + */ + static toString(): string; + /** + * @private + */ + displayIndex: number; + /** + * @private + */ + zOrder: number; + /** + * @private + */ + blendMode: BlendMode; + /** + * @language zh_CN + * 数据名称。 + * @version DragonBones 3.0 + */ + name: string; + /** + * @language zh_CN + * 所属的父骨骼数据。 + * @see dragonBones.BoneData + * @version DragonBones 3.0 + */ + parent: BoneData; + /** + * @private + */ + color: ColorTransform; + /** + * @private + */ + actions: Array; + /** + * @private + */ + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @language zh_CN + * 皮肤数据。 + * @version DragonBones 3.0 + */ + class SkinData extends BaseObject { + /** + * @private + */ + static toString(): string; + /** + * @language zh_CN + * 数据名称。 + * @version DragonBones 3.0 + */ + name: string; + /** + * @private + */ + slots: Map; + /** + * @private + */ + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + /** + * @private + */ + addSlot(value: SlotDisplayDataSet): void; + /** + * @private + */ + getSlot(name: string): SlotDisplayDataSet; + } + /** + * @private + */ + class SlotDisplayDataSet extends BaseObject { + static toString(): string; + slot: SlotData; + displays: Array; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @private + */ + class DisplayData extends BaseObject { + static toString(): string; + isRelativePivot: boolean; + type: DisplayType; + name: string; + texture: TextureData; + armature: ArmatureData; + mesh: MeshData; + pivot: Point; + transform: Transform; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @private + */ + class MeshData extends BaseObject { + static toString(): string; + skinned: boolean; + slotPose: Matrix; + uvs: Array; + vertices: Array; + vertexIndices: Array; + boneIndices: Array>; + weights: Array>; + boneVertices: Array>; + bones: Array; + inverseBindPose: Array; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 龙骨数据,包含多个骨架数据。 + * @see dragonBones.ArmatureData + * @version DragonBones 3.0 + */ + class DragonBonesData extends BaseObject { + /** + * @private + */ + static toString(): string; + /** + * @language zh_CN + * 是否开启共享搜索。 [true: 开启, false: 不开启] + * @default false + * @see dragonBones.ArmatureData + * @version DragonBones 4.5 + */ + autoSearch: boolean; + /** + * @language zh_CN + * 动画帧频。 + * @version DragonBones 3.0 + */ + frameRate: number; + /** + * @language zh_CN + * 数据名称。 + * @version DragonBones 3.0 + */ + name: string; + /** + * @language zh_CN + * 所有的骨架数据。 + * @see dragonBones.ArmatureData + * @version DragonBones 3.0 + */ + armatures: Map; + private _armatureNames; + /** + * @inheritDoc + */ + protected _onClear(): void; + /** + * @language zh_CN + * 获取指定名称的骨架。 + * @param name 骨架数据骨架名称。 + * @see dragonBones.ArmatureData + * @version DragonBones 3.0 + */ + getArmature(name: string): ArmatureData; + /** + * @language zh_CN + * 所有的骨架数据名称。 + * @see #armatures + * @version DragonBones 3.0 + */ + armatureNames: Array; + /** + * @deprecated + * @see dragonBones.BaseFactory#removeDragonBonesData() + */ + dispose(): void; + } +} +declare namespace dragonBones { + /** + * @private + */ + class ActionData extends BaseObject { + static toString(): string; + type: ActionType; + bone: BoneData; + slot: SlotData; + data: Array; + constructor(); + protected _onClear(): void; + } + /** + * @private + */ + class EventData extends BaseObject { + static toString(): string; + type: EventType; + name: string; + data: any; + bone: BoneData; + slot: SlotData; + constructor(); + protected _onClear(): void; + } + /** + * @private + */ + abstract class FrameData extends BaseObject { + position: number; + duration: number; + prev: T; + next: T; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @private + */ + abstract class TweenFrameData extends FrameData { + static samplingCurve(curve: Array, frameCount: number): Array; + tweenEasing: number; + curve: Array; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @private + */ + class AnimationFrameData extends FrameData { + static toString(): string; + actions: Array; + events: Array; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @private + */ + class ZOrderFrameData extends FrameData { + zOrder: Array; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @private + */ + class BoneFrameData extends TweenFrameData { + static toString(): string; + tweenScale: boolean; + tweenRotate: number; + guideCurve: Array; + transform: Transform; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @private + */ + class SlotFrameData extends TweenFrameData { + static DEFAULT_COLOR: ColorTransform; + static generateColor(): ColorTransform; + static toString(): string; + displayIndex: number; + color: ColorTransform; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } + /** + * @private + */ + class ExtensionFrameData extends TweenFrameData { + static toString(): string; + type: ExtensionType; + tweens: Array; + keys: Array; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } +} +declare namespace dragonBones { + /** + * @private + */ + abstract class DataParser { + protected static DATA_VERSION_2_3: string; + protected static DATA_VERSION_3_0: string; + protected static DATA_VERSION_4_0: string; + protected static DATA_VERSION: string; + protected static TEXTURE_ATLAS: string; + protected static SUB_TEXTURE: string; + protected static FORMAT: string; + protected static IMAGE_PATH: string; + protected static WIDTH: string; + protected static HEIGHT: string; + protected static ROTATED: string; + protected static FRAME_X: string; + protected static FRAME_Y: string; + protected static FRAME_WIDTH: string; + protected static FRAME_HEIGHT: string; + protected static DRADON_BONES: string; + protected static ARMATURE: string; + protected static BONE: string; + protected static IK: string; + protected static SLOT: string; + protected static SKIN: string; + protected static DISPLAY: string; + protected static ANIMATION: string; + protected static Z_ORDER: string; + protected static FFD: string; + protected static FRAME: string; + protected static PIVOT: string; + protected static TRANSFORM: string; + protected static AABB: string; + protected static COLOR: string; + protected static FILTER: string; + protected static VERSION: string; + protected static IS_GLOBAL: string; + protected static FRAME_RATE: string; + protected static TYPE: string; + protected static NAME: string; + protected static PARENT: string; + protected static LENGTH: string; + protected static DATA: string; + protected static DISPLAY_INDEX: string; + protected static BLEND_MODE: string; + protected static INHERIT_TRANSLATION: string; + protected static INHERIT_ROTATION: string; + protected static INHERIT_SCALE: string; + protected static TARGET: string; + protected static BEND_POSITIVE: string; + protected static CHAIN: string; + protected static WEIGHT: string; + protected static FADE_IN_TIME: string; + protected static PLAY_TIMES: string; + protected static SCALE: string; + protected static OFFSET: string; + protected static POSITION: string; + protected static DURATION: string; + protected static TWEEN_EASING: string; + protected static TWEEN_ROTATE: string; + protected static TWEEN_SCALE: string; + protected static CURVE: string; + protected static GUIDE_CURVE: string; + protected static EVENT: string; + protected static SOUND: string; + protected static ACTION: string; + protected static ACTIONS: string; + protected static DEFAULT_ACTIONS: string; + protected static X: string; + protected static Y: string; + protected static SKEW_X: string; + protected static SKEW_Y: string; + protected static SCALE_X: string; + protected static SCALE_Y: string; + protected static ALPHA_OFFSET: string; + protected static RED_OFFSET: string; + protected static GREEN_OFFSET: string; + protected static BLUE_OFFSET: string; + protected static ALPHA_MULTIPLIER: string; + protected static RED_MULTIPLIER: string; + protected static GREEN_MULTIPLIER: string; + protected static BLUE_MULTIPLIER: string; + protected static UVS: string; + protected static VERTICES: string; + protected static TRIANGLES: string; + protected static WEIGHTS: string; + protected static SLOT_POSE: string; + protected static BONE_POSE: string; + protected static TWEEN: string; + protected static KEY: string; + protected static COLOR_TRANSFORM: string; + protected static TIMELINE: string; + protected static PIVOT_X: string; + protected static PIVOT_Y: string; + protected static Z: string; + protected static LOOP: string; + protected static AUTO_TWEEN: string; + protected static HIDE: string; + protected static _getArmatureType(value: string): ArmatureType; + protected static _getDisplayType(value: string): DisplayType; + protected static _getBlendMode(value: string): BlendMode; + protected static _getActionType(value: string): ActionType; + protected _data: DragonBonesData; + protected _armature: ArmatureData; + protected _skin: SkinData; + protected _slotDisplayDataSet: SlotDisplayDataSet; + protected _mesh: MeshData; + protected _animation: AnimationData; + protected _timeline: any; + protected _isOldData: boolean; + protected _isGlobalTransform: boolean; + protected _isAutoTween: boolean; + protected _animationTweenEasing: number; + protected _timelinePivot: Point; + protected _helpPoint: Point; + protected _helpTransformA: Transform; + protected _helpTransformB: Transform; + protected _helpMatrix: Matrix; + protected _rawBones: Array; + constructor(); + /** + * @private + */ + abstract parseDragonBonesData(rawData: any, scale: number): DragonBonesData; + /** + * @private + */ + abstract parseTextureAtlasData(rawData: any, textureAtlasData: TextureAtlasData, scale: number): void; + private _getTimelineFrameMatrix(animation, timeline, position, transform); + protected _globalToLocal(armature: ArmatureData): void; + protected _mergeFrameToAnimationTimeline(framePostion: number, actions: Array, events: Array): void; + /** + * @deprecated + * @see dragonBones.BaseFactory#parseDragonBonesData() + */ + static parseDragonBonesData(rawData: any): DragonBonesData; + /** + * @deprecated + * @see dragonBones.BaseFactory#parsetTextureAtlasData() + */ + static parseTextureAtlasData(rawData: any, scale?: number): any; + } +} +declare namespace dragonBones { + /** + * @private + */ + class ObjectDataParser extends DataParser { + /** + * @private + */ + protected static _getBoolean(rawData: any, key: string, defaultValue: boolean): boolean; + /** + * @private + */ + protected static _getNumber(rawData: any, key: string, defaultValue: number): number; + /** + * @private + */ + protected static _getString(rawData: any, key: string, defaultValue: string): string; + /** + * @private + */ + protected static _getParameter(rawData: Array, index: number, defaultValue: any): any; + /** + * @private + */ + constructor(); + /** + * @private + */ + protected _parseArmature(rawData: any, scale: number): ArmatureData; + /** + * @private + */ + protected _parseBone(rawData: any): BoneData; + /** + * @private + */ + protected _parseIK(rawData: any): void; + /** + * @private + */ + protected _parseSlot(rawData: any, zOrder: number): SlotData; + /** + * @private + */ + protected _parseSkin(rawData: any): SkinData; + /** + * @private + */ + protected _parseSlotDisplaySet(rawData: any): SlotDisplayDataSet; + /** + * @private + */ + protected _parseDisplay(rawData: any): DisplayData; + /** + * @private + */ + protected _parseMesh(rawData: any): MeshData; + /** + * @private + */ + protected _parseAnimation(rawData: any): AnimationData; + /** + * @private + */ + protected _parseBoneTimeline(rawData: any): BoneTimelineData; + /** + * @private + */ + protected _parseSlotTimeline(rawData: any): SlotTimelineData; + /** + * @private + */ + protected _parseFFDTimeline(rawData: any): FFDTimelineData; + /** + * @private + */ + protected _parseAnimationFrame(rawData: any, frameStart: number, frameCount: number): AnimationFrameData; + /** + * @private + */ + protected _parseZOrderFrame(rawData: any, frameStart: number, frameCount: number): ZOrderFrameData; + /** + * @private + */ + protected _parseBoneFrame(rawData: Object, frameStart: number, frameCount: number): BoneFrameData; + /** + * @private + */ + protected _parseSlotFrame(rawData: any, frameStart: number, frameCount: number): SlotFrameData; + /** + * @private + */ + protected _parseFFDFrame(rawData: any, frameStart: number, frameCount: number): ExtensionFrameData; + /** + * @private + */ + protected _parseTweenFrame>(rawData: any, frame: T, frameStart: number, frameCount: number): void; + /** + * @private + */ + protected _parseFrame>(rawData: any, frame: T, frameStart: number, frameCount: number): void; + /** + * @private + */ + protected _parseTimeline>(rawData: Object, timeline: TimelineData, frameParser: (rawData: any, frameStart: number, frameCount: number) => T): void; + /** + * @private + */ + protected _parseActionData(rawData: any, actions: Array, bone: BoneData, slot: SlotData): void; + /** + * @private + */ + protected _parseEventData(rawData: any, events: Array, bone: BoneData, slot: SlotData): void; + /** + * @private + */ + protected _parseTransform(rawData: Object, transform: Transform): void; + /** + * @private + */ + protected _parseColorTransform(rawData: Object, color: ColorTransform): void; + /** + * @inheritDoc + */ + parseDragonBonesData(rawData: any, scale?: number): DragonBonesData; + /** + * @inheritDoc + */ + parseTextureAtlasData(rawData: any, textureAtlasData: TextureAtlasData, scale?: number): void; + /** + * @private + */ + private static _instance; + /** + * @deprecated + * @see dragonBones.BaseFactory#parseDragonBonesData() + */ + static getInstance(): ObjectDataParser; + } +} +declare namespace dragonBones { + /** + * @language zh_CN + * 贴图集数据。 + * @version DragonBones 3.0 + */ + abstract class TextureAtlasData extends BaseObject { + /** + * @language zh_CN + * 是否开启共享搜索。 [true: 开启, false: 不开启] + * @default false + * @version DragonBones 4.5 + */ + autoSearch: boolean; + /** + * @language zh_CN + * 贴图集缩放系数。 + * @version DragonBones 3.0 + */ + scale: number; + /** + * @language zh_CN + * 贴图集名称。 + * @version DragonBones 3.0 + */ + name: string; + /** + * @language zh_CN + * 贴图集图片路径。 + * @version DragonBones 3.0 + */ + imagePath: string; + /** + * @inheritDoc + */ + protected _onClear(): void; + /** + * @private + */ + getTexture(name: string): TextureData; + } + /** + * @private + */ + abstract class TextureData extends BaseObject { + static generateRectangle(): Rectangle; + rotated: boolean; + name: string; + frame: Rectangle; + parent: TextureAtlasData; + region: Rectangle; + constructor(); + /** + * @inheritDoc + */ + protected _onClear(): void; + } +} +declare namespace dragonBones { + /** + * @private + */ + type BuildArmaturePackage = { + dataName?: string; + textureAtlasName?: string; + data?: DragonBonesData; + armature?: ArmatureData; + skin?: SkinData; + }; + /** + * @language zh_CN + * 创建骨架的基础工厂。 (通常只需要一个全局工厂实例) + * @see dragonBones.DragonBonesData + * @see dragonBones.TextureAtlasData + * @see dragonBones.ArmatureData + * @see dragonBones.Armature + * @version DragonBones 3.0 + */ + abstract class BaseFactory { + protected static _defaultParser: ObjectDataParser; + /** + * @language zh_CN + * 是否开启共享搜索。 [true: 开启, false: 不开启] + * 如果开启,创建一个骨架时,可以从多个龙骨数据中寻找骨架数据,或贴图集数据中寻找贴图数据。 (通常在有共享导出的数据时开启) + * @see dragonBones.DragonBonesData#autoSearch + * @see dragonBones.TextureAtlasData#autoSearch + * @version DragonBones 4.5 + */ + autoSearch: boolean; + /** + * @private + */ + protected _dataParser: DataParser; + /** + * @private + */ + protected _dragonBonesDataMap: Map; + /** + * @private + */ + protected _textureAtlasDataMap: Map>; + /** + * @private + */ + constructor(dataParser?: DataParser); + /** + * @private + */ + protected _getTextureData(textureAtlasName: string, textureName: string): TextureData; + /** + * @private + */ + protected _fillBuildArmaturePackage(dataPackage: BuildArmaturePackage, dragonBonesName: string, armatureName: string, skinName: string, textureAtlasName: string): boolean; + /** + * @private + */ + protected _buildBones(dataPackage: BuildArmaturePackage, armature: Armature): void; + /** + * @private + */ + protected _buildSlots(dataPackage: BuildArmaturePackage, armature: Armature): void; + /** + * @private + */ + protected _replaceSlotDisplay(dataPackage: BuildArmaturePackage, displayData: DisplayData, slot: Slot, displayIndex: number): void; + /** + * @private + */ + protected abstract _generateTextureAtlasData(textureAtlasData: TextureAtlasData, textureAtlas: any): TextureAtlasData; + /** + * @private + */ + protected abstract _generateArmature(dataPackage: BuildArmaturePackage): Armature; + /** + * @private + */ + protected abstract _generateSlot(dataPackage: BuildArmaturePackage, slotDisplayDataSet: SlotDisplayDataSet, armature: Armature): Slot; + /** + * @language zh_CN + * 解析并添加龙骨数据。 + * @param rawData 需要解析的原始数据。 (JSON) + * @param name 为数据提供一个名称,以便可以通过这个名称获取数据,如果未设置,则使用数据中的名称。 + * @returns DragonBonesData + * @see #getDragonBonesData() + * @see #addDragonBonesData() + * @see #removeDragonBonesData() + * @see dragonBones.DragonBonesData + * @version DragonBones 4.5 + */ + parseDragonBonesData(rawData: any, name?: string, scale?: number): DragonBonesData; + /** + * @language zh_CN + * 解析并添加贴图集数据。 + * @param rawData 需要解析的原始数据。 (JSON) + * @param textureAtlas 贴图集数据。 (JSON) + * @param name 为数据指定一个名称,以便可以通过这个名称获取数据,如果未设置,则使用数据中的名称。 + * @param scale 为贴图集设置一个缩放值。 + * @returns 贴图集数据 + * @see #getTextureAtlasData() + * @see #addTextureAtlasData() + * @see #removeTextureAtlasData() + * @see dragonBones.TextureAtlasData + * @version DragonBones 4.5 + */ + parseTextureAtlasData(rawData: any, textureAtlas: Object, name?: string, scale?: number): TextureAtlasData; + /** + * @language zh_CN + * 获取指定名称的龙骨数据。 + * @param name 数据名称。 + * @returns DragonBonesData + * @see #parseDragonBonesData() + * @see #addDragonBonesData() + * @see #removeDragonBonesData() + * @see dragonBones.DragonBonesData + * @version DragonBones 3.0 + */ + getDragonBonesData(name: string): DragonBonesData; + /** + * @language zh_CN + * 添加龙骨数据。 + * @param data 龙骨数据。 + * @param name 为数据指定一个名称,以便可以通过这个名称获取数据,如果未设置,则使用数据中的名称。 + * @see #parseDragonBonesData() + * @see #getDragonBonesData() + * @see #removeDragonBonesData() + * @see dragonBones.DragonBonesData + * @version DragonBones 3.0 + */ + addDragonBonesData(data: DragonBonesData, name?: string): void; + /** + * @language zh_CN + * 移除龙骨数据。 + * @param name 数据名称。 + * @param disposeData 是否释放数据。 [false: 不释放, true: 释放] + * @see #parseDragonBonesData() + * @see #getDragonBonesData() + * @see #addDragonBonesData() + * @see dragonBones.DragonBonesData + * @version DragonBones 3.0 + */ + removeDragonBonesData(name: string, disposeData?: boolean): void; + /** + * @language zh_CN + * 获取指定名称的贴图集数据列表。 + * @param name 数据名称。 + * @returns 贴图集数据列表。 + * @see #parseTextureAtlasData() + * @see #addTextureAtlasData() + * @see #removeTextureAtlasData() + * @see dragonBones.textures.TextureAtlasData + * @version DragonBones 3.0 + */ + getTextureAtlasData(name: string): Array; + /** + * @language zh_CN + * 添加贴图集数据。 + * @param data 贴图集数据。 + * @param name 为数据指定一个名称,以便可以通过这个名称获取数据,如果未设置,则使用数据中的名称。 + * @see #parseTextureAtlasData() + * @see #getTextureAtlasData() + * @see #removeTextureAtlasData() + * @see dragonBones.textures.TextureAtlasData + * @version DragonBones 3.0 + */ + addTextureAtlasData(data: TextureAtlasData, name?: string): void; + /** + * @language zh_CN + * 移除贴图集数据。 + * @param name 数据名称。 + * @param disposeData 是否释放数据。 [false: 不释放, true: 释放] + * @see #parseTextureAtlasData() + * @see #getTextureAtlasData() + * @see #addTextureAtlasData() + * @see dragonBones.textures.TextureAtlasData + * @version DragonBones 3.0 + */ + removeTextureAtlasData(name: string, disposeData?: boolean): void; + /** + * @language zh_CN + * 清除所有的数据。 + * @param disposeData 是否释放数据。 [false: 不释放, true: 释放] + * @version DragonBones 4.5 + */ + clear(disposeData?: boolean): void; + /** + * @language zh_CN + * 创建一个指定名称的骨架。 + * @param armatureName 骨架数据名称。 + * @param dragonBonesName 龙骨数据名称,如果未设置,将检索所有的龙骨数据,当多个龙骨数据中包含同名的骨架数据时,可能无法创建出准确的骨架。 + * @param skinName 皮肤名称,如果未设置,则使用默认皮肤。 + * @param textureAtlasName 贴图集数据名称,如果未设置,则使用龙骨数据。 + * @returns 骨架 + * @see dragonBones.Armature + * @version DragonBones 3.0 + */ + buildArmature(armatureName: string, dragonBonesName?: string, skinName?: string, textureAtlasName?: string): Armature; + /** + * @language zh_CN + * 将指定骨架的动画替换成其他骨架的动画。 (通常这些骨架应该具有相同的骨架结构) + * @param toArmature 指定的骨架。 + * @param fromArmatreName 其他骨架的名称。 + * @param fromSkinName 其他骨架的皮肤名称,如果未设置,则使用默认皮肤。 + * @param fromDragonBonesDataName 其他骨架属于的龙骨数据名称,如果未设置,则检索所有的龙骨数据。 + * @param ifRemoveOriginalAnimationList 是否移除原有的动画。 [true: 移除, false: 不移除] + * @returns 是否替换成功。 [true: 成功, false: 不成功] + * @see dragonBones.Armature + * @version DragonBones 4.5 + */ + copyAnimationsToArmature(toArmature: Armature, fromArmatreName: string, fromSkinName?: string, fromDragonBonesDataName?: string, ifRemoveOriginalAnimationList?: boolean): boolean; + /** + * @language zh_CN + * 将指定插槽的显示对象替换为指定资源创造出的显示对象。 + * @param dragonBonesName 指定的龙骨数据名称。 + * @param armatureName 指定的骨架名称。 + * @param slotName 指定的插槽名称。 + * @param displayName 指定的显示对象名称。 + * @param slot 指定的插槽实例。 + * @param displayIndex 要替换的显示对象的索引,如果未设置,则替换当前正在显示的显示对象。 + * @version DragonBones 4.5 + */ + replaceSlotDisplay(dragonBonesName: string, armatureName: string, slotName: string, displayName: string, slot: Slot, displayIndex?: number): void; + /** + * @language zh_CN + * 将指定插槽的显示对象列表替换为指定资源创造出的显示对象列表。 + * @param dragonBonesName 指定的 DragonBonesData 名称。 + * @param armatureName 指定的骨架名称。 + * @param slotName 指定的插槽名称。 + * @param slot 指定的插槽实例。 + * @version DragonBones 4.5 + */ + replaceSlotDisplayList(dragonBonesName: string, armatureName: string, slotName: string, slot: Slot): void; + /** + * @private + */ + getAllDragonBonesData(): Map; + /** + * @private + */ + getAllTextureAtlasData(): Map>; + } +} + +declare let jsb: any; +/** Running in the editor. */ +declare let CC_EDITOR: boolean; +/** Preview in browser or simulator. */ +declare let CC_PREVIEW: boolean; +/** Running in the editor or preview. */ +declare let CC_DEV: boolean; +/** Running in the editor or preview, or build in debug mode. */ +declare let CC_DEBUG: boolean; +/** Running in published project. */ +declare let CC_BUILD: boolean; +/** Running in native platform (mobile app, desktop app, or simulator). */ +declare let CC_JSB: boolean; +/** Running in the engine's unit test. */ +declare let CC_TEST: boolean; diff --git a/packages/plugin-matchvs/matchvs/matchvsjssdk/matchvs.all.js b/packages/plugin-matchvs/matchvs/matchvsjssdk/matchvs.all.js index 51ef0ae..7876a54 100644 --- a/packages/plugin-matchvs/matchvs/matchvsjssdk/matchvs.all.js +++ b/packages/plugin-matchvs/matchvs/matchvsjssdk/matchvs.all.js @@ -1,5 +1,18 @@ -/* ================ md5.js ================= */ +/************************************************************************************************** + * Matchvs SDK * + * * + * 2018-08-24 * + * https://www.matchvs.com/home * + **************************************************************************************************/ + +/* ================ MVS.js ================= */ +var MVS = (function (_obj) { + var MVS = (function () { + }); + _obj = MVS; + return _obj; +})({})/* ================ md5.js ================= */ /* * A JavaScript implementation of the RSA Data Security, Inc. MD5 Message * Digest Algorithm, as defined in RFC 1321. @@ -257,17 +270,14 @@ function binl2b64(binarray) return str; } /* ================ format.js ================= */ -// -// format - printf-like string formatting for JavaScript -// github.com/samsonjs/format -// @_sjs -// -// Copyright 2010 - 2013 Sami Samhuri -// -// MIT License -// http://sjs.mit-license.org -// - +/************************************************************************************ + * format - printf-like string formatting for JavaScript + * github.com/samsonjs/format + * @_sjs + * Copyright 2010 - 2013 Sami Samhuri + * MIT License + * http://sjs.mit-license.org + ************************************************************************************/ var format = function (fmt){ var argIndex = 1 // skip initial format argument , args = [].slice.call(arguments) @@ -385,9 +395,9 @@ MatchvsLog.openLog = function () { console.log("---- open log ----"); if (typeof (wx) === "undefined") { MatchvsLog.logI = console.log.bind(console - , "[INFO ] " + " "); + , "[INFO][Matchvs] " + " "); MatchvsLog.logE = console.error.bind(console - , "[ERROR] " + " "); + , "[ERROR][Matchvs] " + " "); } else { MatchvsLog.logI = function () { var loc = ""; @@ -397,7 +407,7 @@ MatchvsLog.openLog = function () { var line = e.stack.split(/\n/)[1]; loc= line.slice(line.lastIndexOf("/")+1,line.lastIndexOf(")")); } - console.info("[INFO ] " + getNowFormatDate() + " " + this.toArray(arguments) + " " + loc); + console.log("[INFO][Matchvs] " + getNowFormatDate() + " " + this.toArray(arguments) + " " + loc); }; MatchvsLog.logE = function () { @@ -408,7 +418,7 @@ MatchvsLog.openLog = function () { var line = e.stack.split(/\n/)[1]; loc= line.slice(line.lastIndexOf("/")+1,line.lastIndexOf(")")); } - console.error("[ERROR] " + getNowFormatDate() + " " + this.toArray(arguments) + " " + loc); + console.error("[ERROR][Matchvs] " + getNowFormatDate() + " " + this.toArray(arguments) + " " + loc); }; } }; @@ -451,7 +461,8 @@ var ENMU_MVS_PTF = { var MVSCONFIG ={ - MAXPLAYER_LIMIT : 20, + MAXPLAYER_LIMIT : 100, + MINPLAYER_LIMIT : 2, MVS_PTF_ADATPER : ENMU_MVS_PTF.MVS_COMMON //如果是白鹭适配就需要填 1 }; @@ -615,6 +626,12 @@ function isIE() { //ie? return !!window.ActiveXObject || "ActiveXObject" in window; } +function isNeedUseWSS() { + return typeof wx !== "undefined"; + +} + + /** * 同时在SDK加入房间时mvs在bookInfo中会返回hotel的wssProxy * 建立连接时用 wss://proxyAddress/proxy?hotel=hotelAddress @@ -622,12 +639,21 @@ function isIE() { //ie? * @returns {string} url */ function getHotelUrl(bookInfo) { - return "wss://" + bookInfo.getWssproxy() + "/proxy?hotel=" + bookInfo.getHoteladdr(); + //TODO isNeedUseWSS; + + return isNeedUseWSS()?("wss://" + bookInfo.getWssproxy() + "/proxy?hotel=" + bookInfo.getHoteladdr()):("ws://"+bookInfo.getHoteladdr()); } +/** + * 检测engine状态 + * @param engineState + * @param roomLoock + * @param type + * @returns {number} + */ function commEngineStateCheck(engineState, roomLoock, type) { var resNo = 0; - if ((engineState & ENGE_STATE.HAVE_INIT) !== ENGE_STATE.HAVE_INIT) resNo= -2; //未初始化 + if ((engineState & ENGE_STATE.HAVE_INIT) !== ENGE_STATE.HAVE_INIT) resNo = -2; //未初始化 if ((engineState & ENGE_STATE.INITING) === ENGE_STATE.INITING) resNo = -3; //正在初始化 if ((engineState & ENGE_STATE.HAVE_LOGIN) !== ENGE_STATE.HAVE_LOGIN) resNo = -4; //未登录 if ((engineState & ENGE_STATE.LOGINING) === ENGE_STATE.LOGINING) resNo = -5; //正在登录 @@ -644,12 +670,101 @@ function commEngineStateCheck(engineState, roomLoock, type) { if ((engineState & ENGE_STATE.LEAVE_ROOMING) === ENGE_STATE.LEAVE_ROOMING) resNo = -10;//正在离开房间 } - if(resNo !== 0){ - MatchvsLog.logI("error code:"+resNo+" see the error documentation : http://www.matchvs.com/service?page=js"); + if (resNo !== 0) { + MatchvsLog.logI("error code:" + resNo + " see the error documentation : http://www.matchvs.com/service?page=js"); } return resNo; -}/* ================ mspb.js ================= */ +} + +var MvsTicker = (function (obj) { + var _tickMap = {}; + var _count = 0; + + function MvsTicker() { + } + + if ("undefined" !== typeof (BK)) { + MvsTicker.prototype.setInterval = function (callback, interval) { + var t = new BK.Ticker(); + t.interval = interval * 6 / 100; + t.setTickerCallBack(callback); + var flag = ++_count; + _tickMap[flag] = t; + return flag; + }; + MvsTicker.prototype.clearInterval = function (flag) { + var ti = _tickMap[flag]; + if (ti) { + ti.dispose(); + delete _tickMap[flag]; + } + }; + } else { + MvsTicker.prototype.setInterval = function (callback, interval) { + return setInterval(callback, interval); + }; + MvsTicker.prototype.clearInterval = function (flag) { + clearInterval(flag); + }; + } + return MvsTicker; +})(MvsTicker); + +var MVS = (function (_obj) { + _obj.ticker = new MvsTicker(); + return _obj; +})(MVS || {}); + + + +/* ================ DefaultAppKeyCheck.js ================= */ +/** + * DefaultAppKeyCheck.js + * 默认 appkey 合法性检测 + */ + +var MVS = (function (_super) { + + var AppKeyCheck = (function(_obj){ + var _tags = ["","EG","CC"]; + /** + * 获取 appkey 里的渠道标记 + * @param appkey + * @returns {string} + */ + var getTag = function(appkey){ + var len = appkey.length; + if(len !== 35){ + return ""; + } + var tags = appkey.split('#'); + if(tags.length !== 2){ + return ""; + } + return tags[1]; + }; + + var AppkeyCheck = (function(){ + + }); + + AppkeyCheck.prototype.isInvailed = function(appkey){ + var tag = getTag(appkey) + for(var i = 0; i < _tags.length; i++){ + if(tag === _tags[i]){ + return true; + } + } + return false; + }; + _obj = AppkeyCheck; + return _obj; + })(AppKeyCheck || {}); + + _super.AppKeyCheck = AppKeyCheck; + return _super; +})(MVS ||{});/* ================ mspb.js ================= */ (function e(t, n, r) { function s(o, u) { if (!n[o]) { @@ -1400,7 +1515,8 @@ function commEngineStateCheck(engineState, roomLoock, type) { goog.moduleLoaderState_ = b; } }, goog.loadModuleFromSource_ = function (a) { - eval(a); + //eval(a); + console.log("eval(a) need open"); return {}; }, goog.writeScriptSrcNode_ = function (a) { goog.global.document.write("

p2|VGy!A5F(9sg8Z-liv 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�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 diff --git a/assets/mikado_outline_shadow.png.meta b/assets/mikado_outline_shadow.png.meta deleted file mode 100644 index 1ceffb9..0000000 --- a/assets/mikado_outline_shadow.png.meta +++ /dev/null @@ -1,30 +0,0 @@ -{ - "ver": "1.0.0", - "uuid": "0f0d9bf9-c718-4ab0-bd20-f7a4bfe5909c", - "type": "sprite", - "wrapMode": "clamp", - "filterMode": "bilinear", - "subMetas": { - "mikado_outline_shadow": { - "ver": "1.0.3", - "uuid": "4f350cc3-5c51-4724-8e3c-2b3663fe7512", - "rawTextureUuid": "0f0d9bf9-c718-4ab0-bd20-f7a4bfe5909c", - "trimType": "auto", - "trimThreshold": 1, - "rotated": false, - "offsetX": -4.5, - "offsetY": 9, - "trimX": 3, - "trimY": 3, - "width": 497, - "height": 232, - "rawWidth": 512, - "rawHeight": 256, - "borderTop": 0, - "borderBottom": 0, - "borderLeft": 0, - "borderRight": 0, - "subMetas": {} - } - } -} \ No newline at end of file diff --git a/assets/result.fire b/assets/result.fire deleted file mode 100644 index 352e981..0000000 --- a/assets/result.fire +++ /dev/null @@ -1,440 +0,0 @@ -[ - { - "__type__": "cc.SceneAsset", - "_name": "", - "_objFlags": 0, - "_rawFiles": null, - "scene": { - "__id__": 1 - } - }, - { - "__type__": "cc.Scene", - "_objFlags": 0, - "_parent": null, - "_children": [ - { - "__id__": 2 - } - ], - "_tag": -1, - "_active": true, - "_components": [], - "_prefab": null, - "_id": "7ac84015-4a9d-4f86-9163-90cb7bfa3895", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 0, - "height": 0 - }, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0, - "autoReleaseAssets": false - }, - { - "__type__": "cc.Node", - "_name": "Canvas", - "_objFlags": 0, - "_parent": { - "__id__": 1 - }, - "_children": [ - { - "__id__": 3 - }, - { - "__id__": 5 - } - ], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 10 - }, - { - "__id__": 11 - } - ], - "_prefab": null, - "_id": "7beA9uSw1NqbZgYsKX3iSi", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 960, - "height": 640 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": 480, - "y": 320 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Node", - "_name": "labelResultFirst", - "_objFlags": 0, - "_parent": { - "__id__": 2 - }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 4 - } - ], - "_prefab": null, - "_id": "94E2dKcqtNpb200UFiQS2Y", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 0, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": -80, - "y": 130 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 3 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, - { - "__type__": "cc.Node", - "_name": "backButton", - "_objFlags": 0, - "_parent": { - "__id__": 2 - }, - "_children": [ - { - "__id__": 6 - } - ], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 8 - }, - { - "__id__": 9 - } - ], - "_prefab": null, - "_id": "37MNlr4ldGdo2O8LNVfqvr", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 100, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": 14, - "y": -256 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Node", - "_name": "Label", - "_objFlags": 0, - "_parent": { - "__id__": 5 - }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 7 - } - ], - "_prefab": null, - "_id": "e94cqn4FlFkaWZELkXmDML", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 100, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 6 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "返回", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, - { - "__type__": "cc.Sprite", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 5 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null - }, - { - "__type__": "cc.Button", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 5 - }, - "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" - }, - "_N$target": { - "__id__": 5 - } - }, - { - "__type__": "cc.Canvas", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 2 - }, - "_enabled": true, - "_designResolution": { - "__type__": "cc.Size", - "width": 960, - "height": 640 - }, - "_fitWidth": false, - "_fitHeight": true - }, - { - "__type__": "47afb331JpASbIJuG281Nza", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 2 - }, - "_enabled": true, - "labelFirst": { - "__id__": 4 - }, - "buttonBack": { - "__id__": 5 - } - } -] \ No newline at end of file diff --git a/assets/result.fire.meta b/assets/result.fire.meta deleted file mode 100644 index 54afceb..0000000 --- a/assets/result.fire.meta +++ /dev/null @@ -1,7 +0,0 @@ -{ - "ver": "1.0.0", - "uuid": "7ac84015-4a9d-4f86-9163-90cb7bfa3895", - "asyncLoadAssets": false, - "autoReleaseAssets": false, - "subMetas": {} -} \ No newline at end of file diff --git a/assets/roomList.fire.meta b/assets/roomList.fire.meta deleted file mode 100644 index 7222323..0000000 --- a/assets/roomList.fire.meta +++ /dev/null @@ -1,7 +0,0 @@ -{ - "ver": "1.0.0", - "uuid": "1ac4ccde-509b-44fe-8d87-8ae212d09ce9", - "asyncLoadAssets": false, - "autoReleaseAssets": false, - "subMetas": {} -} \ No newline at end of file diff --git a/assets/scene.meta b/assets/scene.meta new file mode 100644 index 0000000..fe7c387 --- /dev/null +++ b/assets/scene.meta @@ -0,0 +1,5 @@ +{ + "ver": "1.0.1", + "uuid": "c4336551-5506-46cc-afda-ea7fe31a4caf", + "subMetas": {} +} \ No newline at end of file diff --git a/assets/roomList.fire b/assets/scene/CreateRoom.fire similarity index 59% rename from assets/roomList.fire rename to assets/scene/CreateRoom.fire index 2bf1cd2..48c1847 100644 --- a/assets/roomList.fire +++ b/assets/scene/CreateRoom.fire @@ -15,9 +15,6 @@ "_children": [ { "__id__": 2 - }, - { - "__id__": 60 } ], "_active": true, @@ -44,8 +41,8 @@ }, "_scale": { "__type__": "cc.Vec3", - "x": 0.40328824394676904, - "y": 0.40328824394676904, + "x": 0.7333333333333333, + "y": 0.7333333333333333, "z": 1 }, "_quat": { @@ -55,10 +52,10 @@ "z": 0, "w": 1 }, - "_localZOrder": 2, + "_zIndex": 0, "groupIndex": 0, "autoReleaseAssets": false, - "_id": "1ac4ccde-509b-44fe-8d87-8ae212d09ce9" + "_id": "c3e0ce22-ffc8-423d-948a-29d0debd4752" }, { "__type__": "cc.Node", @@ -81,20 +78,74 @@ "__id__": 9 }, { - "__id__": 22 + "__id__": 11 }, { - "__id__": 27 + "__id__": 13 }, { - "__id__": 29 + "__id__": 15 + }, + { + "__id__": 17 + }, + { + "__id__": 24 + }, + { + "__id__": 26 + }, + { + "__id__": 28 + }, + { + "__id__": 35 + }, + { + "__id__": 37 + }, + { + "__id__": 39 + }, + { + "__id__": 46 + }, + { + "__id__": 48 + }, + { + "__id__": 50 + }, + { + "__id__": 52 + }, + { + "__id__": 57 + }, + { + "__id__": 61 + }, + { + "__id__": 66 + }, + { + "__id__": 71 + }, + { + "__id__": 76 + }, + { + "__id__": 78 } ], "_active": true, "_level": 0, "_components": [ { - "__id__": 59 + "__id__": 80 + }, + { + "__id__": 81 } ], "_prefab": null, @@ -108,8 +159,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -118,8 +169,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 480, - "y": 320, + "x": 640, + "y": 360, "z": 0 }, "_scale": { @@ -139,9 +190,9 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 3, - "groupIndex": 0, - "_id": "b92CYPpXdDPb/ibLJvBa3X" + "_zIndex": 0, + "groupIndex": 1, + "_id": "69G+pJV+lGE7Zrq9E20nNF" }, { "__type__": "cc.Node", @@ -200,9 +251,9 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 4, + "_zIndex": 0, "groupIndex": 0, - "_id": "27KdHuc1dA5LDDHG9Yw3d+" + "_id": "48kBVmhV5IdaN5ZoUicc8t" }, { "__type__": "cc.Camera", @@ -224,11 +275,11 @@ "_depth": 0, "_zoomRatio": 1, "_targetTexture": null, - "_id": "aa02UwLM5ApZSynraWdhuZ" + "_id": "80GVfzTRtPhLEV+sOe7Tix" }, { "__type__": "cc.Node", - "_name": "label", + "_name": "backgrout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -252,8 +303,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 160, - "height": 40 + "width": 1280, + "height": 720 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -262,8 +313,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 5, - "y": 284, + "x": 0, + "y": 0, "z": 0 }, "_scale": { @@ -283,38 +334,41 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 5, + "_zIndex": 0, "groupIndex": 0, - "_id": "7eVpDRwkdMc4p+XnPJkVBu" + "_id": "8bMmtO/YpNGIQqTbLBNd/j" }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { "__id__": 5 }, "_enabled": true, - "_srcBlendFactor": 1, + "_srcBlendFactor": 770, "_dstBlendFactor": 771, - "_useOriginalSize": false, - "_string": "房间列表", - "_N$string": "房间列表", - "_fontSize": 40, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0, - "_id": "05noZEUAROT7bbs+FF+lfk" + "_spriteFrame": { + "__uuid__": "0cbd03ff-a827-4248-a85b-6bfd7ebfcabd" + }, + "_type": 2, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "7aSIJc6l9OmJ3qoGj3Pz92" }, { "__type__": "cc.Node", - "_name": "labelInfo", + "_name": "back", "_objFlags": 0, "_parent": { "__id__": 2 @@ -331,15 +385,15 @@ "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 228, - "g": 58, - "b": 92, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 15 + "width": 20, + "height": 36 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -348,8 +402,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": -369, - "y": 301, + "x": -550, + "y": 290, "z": 0 }, "_scale": { @@ -369,83 +423,76 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 6, + "_zIndex": 0, "groupIndex": 0, - "_id": "7aiQj5oTZNhJW4REqpU2uF" + "_id": "5cqsO9pvZPVrqx8MXOcQWD" }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { "__id__": 7 }, "_enabled": true, - "_srcBlendFactor": 1, + "_srcBlendFactor": 770, "_dstBlendFactor": 771, - "_useOriginalSize": false, - "_string": "", - "_N$string": "", - "_fontSize": 15, - "_lineHeight": 15, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0, - "_id": "f8F4TWk0lPaLQaZPZd4CT4" + "_spriteFrame": { + "__uuid__": "3f66add4-81b7-41d8-995e-1553cd3ef92e" + }, + "_type": 0, + "_sizeMode": 1, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "257nKjf9NGNZTJd4mITyEH" }, { "__type__": "cc.Node", - "_name": "scrollview", + "_name": "New Label", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 10 - }, - { - "__id__": 16 - } - ], + "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 21 - }, - { - "__id__": 14 + "__id__": 10 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 800, - "height": 500 + "width": 216, + "height": 40 }, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_position": { "__type__": "cc.Vec3", - "x": 19, - "y": 6, + "x": -505, + "y": 290, "z": 0 }, "_scale": { @@ -465,58 +512,73 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 7, + "_zIndex": 0, "groupIndex": 0, - "_id": "11eZLWn7xOwKjpad+RXMo+" + "_id": "3bGaUGX+1Bx7y9mcnbL6PZ" + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 9 + }, + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "等待玩家加入", + "_N$string": "等待玩家加入", + "_fontSize": 36, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0, + "_id": "29FOBCTmlJcLgbsPm32MiO" }, { "__type__": "cc.Node", - "_name": "scrollBar", + "_name": "Matching Way", "_objFlags": 0, "_parent": { - "__id__": 9 + "__id__": 2 }, - "_children": [ - { - "__id__": 11 - } - ], + "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 13 - }, - { - "__id__": 19 - }, - { - "__id__": 20 + "__id__": 12 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 8, - "g": 202, - "b": 243, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 15, - "height": 500 + "width": 0, + "height": 40 }, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 1, + "x": 0, "y": 0.5 }, "_position": { "__type__": "cc.Vec3", - "x": 400, - "y": 0, + "x": -260, + "y": 290, "z": 0 }, "_scale": { @@ -536,48 +598,73 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 8, + "_zIndex": 0, "groupIndex": 0, - "_id": "80+uoOPINLTJQFPLXNV+eo" + "_id": "35SexLlfdL45Ou/Yr7jtTR" + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 11 + }, + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "", + "_N$string": "", + "_fontSize": 24, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0, + "_id": "4ccn1EjMNF8LN8dDdwrL0Y" }, { "__type__": "cc.Node", - "_name": "bar", + "_name": "nickName", "_objFlags": 0, "_parent": { - "__id__": 10 + "__id__": 2 }, "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 12 + "__id__": 14 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 236, - "g": 241, - "b": 245, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 10, - "height": 30 + "width": 73.32, + "height": 33 }, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 1, - "y": 0 + "x": 0, + "y": 0.5 }, "_position": { "__type__": "cc.Vec3", - "x": -1, - "y": 0, + "x": 400, + "y": 290, "z": 0 }, "_scale": { @@ -597,95 +684,143 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 9, + "_zIndex": 0, "groupIndex": 0, - "_id": "bd842Xod9JTLINGtCDsxjc" + "_id": "39RUlKe5NI0bMP60DbFN5D" }, { - "__type__": "cc.Sprite", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 11 + "__id__": 13 }, "_enabled": true, - "_srcBlendFactor": 770, + "_srcBlendFactor": 1, "_dstBlendFactor": 771, - "_spriteFrame": { - "__uuid__": "5c3bb932-6c3c-468f-88a9-c8c61d458641" - }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_state": 0, - "_atlas": null, - "_id": "69ZK63napG2IPPNWJdJ2xk" + "_useOriginalSize": false, + "_string": "用户ID", + "_N$string": "用户ID", + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0, + "_id": "8euhfN75JN262VRLYeeekw" }, { - "__type__": "cc.Scrollbar", - "_name": "", + "__type__": "cc.Node", + "_name": "Room Number", "_objFlags": 0, - "node": { - "__id__": 10 - }, - "_enabled": true, - "_scrollView": { - "__id__": 14 + "_parent": { + "__id__": 2 }, - "_touching": false, + "_children": [], + "_active": true, + "_level": 0, + "_components": [ + { + "__id__": 16 + } + ], + "_prefab": null, "_opacity": 255, - "enableAutoHide": true, - "autoHideTime": 1, - "_N$handle": { - "__id__": 12 + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 96, + "height": 33 + }, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0.5 + }, + "_position": { + "__type__": "cc.Vec3", + "x": -505, + "y": 211, + "z": 0 + }, + "_scale": { + "__type__": "cc.Vec3", + "x": 1, + "y": 1, + "z": 1 + }, + "_rotationX": 0, + "_rotationY": 0, + "_quat": { + "__type__": "cc.Quat", + "x": 0, + "y": 0, + "z": 0, + "w": 1 }, - "_N$direction": 1, - "_id": "345LX0J89EGIhu5rGLVlCx" + "_skewX": 0, + "_skewY": 0, + "_zIndex": 0, + "groupIndex": 0, + "_id": "1cxUOdyJFPXIIkW2ekJGE/" }, { - "__type__": "cc.ScrollView", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 9 - }, - "_enabled": true, - "content": { "__id__": 15 }, - "horizontal": false, - "vertical": true, - "inertia": true, - "brake": 0.9, - "elastic": true, - "bounceDuration": 0.23, - "scrollEvents": [], - "cancelInnerEvents": true, - "_N$horizontalScrollBar": null, - "_N$verticalScrollBar": { - "__id__": 13 - }, - "_id": "ebM1gcFGBA2qQyjbjzonL2" + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "房间号:", + "_N$string": "房间号:", + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "Arial", + "_N$overflow": 0, + "_id": "11qJx0xR9HG5eh6LXz2iwZ" }, { "__type__": "cc.Node", - "_name": "content", + "_name": "Player One", "_objFlags": 0, "_parent": { - "__id__": 16 + "__id__": 2 }, - "_children": [], + "_children": [ + { + "__id__": 18 + }, + { + "__id__": 21 + } + ], "_active": true, "_level": 0, - "_components": [], + "_components": [ + { + "__id__": 23 + } + ], "_prefab": null, "_opacity": 255, "_color": { @@ -697,18 +832,18 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 220, - "height": 400 + "width": 200, + "height": 200 }, "_anchorPoint": { "__type__": "cc.Vec2", "x": 0.5, - "y": 1 + "y": 0.5 }, "_position": { "__type__": "cc.Vec3", - "x": -6, - "y": 222, + "x": -300, + "y": 30, "z": 0 }, "_scale": { @@ -728,45 +863,41 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 11, + "_zIndex": 0, "groupIndex": 0, - "_id": "b9WynyBHZJy6LPjozJq9X+" + "_id": "8dbwyKcelC/aF3mBtDgwv3" }, { "__type__": "cc.Node", - "_name": "view", + "_name": "New Layout", "_objFlags": 0, "_parent": { - "__id__": 9 + "__id__": 17 }, - "_children": [ - { - "__id__": 15 - } - ], + "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 17 + "__id__": 19 }, { - "__id__": 18 + "__id__": 20 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 139, + "g": 215, + "b": 224, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 800, - "height": 490 + "width": 200, + "height": 200 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -796,93 +927,22 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 10, + "_zIndex": 0, "groupIndex": 0, - "_id": "cfv6EX36VMHKk11pSnn8r3" - }, - { - "__type__": "cc.Mask", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 16 - }, - "_enabled": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_spriteFrame": null, - "_type": 0, - "_segments": 64, - "_N$alphaThreshold": 1, - "_N$inverted": false, - "_id": "a3XkwVFyVJBYb8dIefwHvz" - }, - { - "__type__": "cc.Widget", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 16 - }, - "_enabled": true, - "alignMode": 0, - "_target": null, - "_alignFlags": 45, - "_left": 0, - "_right": 0, - "_top": 5, - "_bottom": 5, - "_verticalCenter": 0, - "_horizontalCenter": 0, - "_isAbsLeft": true, - "_isAbsRight": true, - "_isAbsTop": true, - "_isAbsBottom": true, - "_isAbsHorizontalCenter": true, - "_isAbsVerticalCenter": true, - "_originalWidth": 800, - "_originalHeight": 500, - "_id": "2f7o5ahQJD5LCLIfIyk60g" - }, - { - "__type__": "cc.Widget", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 10 - }, - "_enabled": true, - "alignMode": 0, - "_target": null, - "_alignFlags": 37, - "_left": 350.07654921020657, - "_right": 0, - "_top": 0, - "_bottom": 0, - "_verticalCenter": 0, - "_horizontalCenter": 0, - "_isAbsLeft": true, - "_isAbsRight": true, - "_isAbsTop": true, - "_isAbsBottom": true, - "_isAbsHorizontalCenter": true, - "_isAbsVerticalCenter": true, - "_originalWidth": 0, - "_originalHeight": 237, - "_id": "54Ezp+jyNMy78GfH8IKQlx" + "_id": "791a5cZMVC7pWnhPsyFty1" }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 10 + "__id__": 18 }, "_enabled": true, "_srcBlendFactor": 770, "_dstBlendFactor": 771, "_spriteFrame": { - "__uuid__": "5fe5dcaa-b513-4dc5-a166-573627b3a159" + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" }, "_type": 1, "_sizeMode": 0, @@ -897,56 +957,53 @@ "_isTrimmedMode": true, "_state": 0, "_atlas": null, - "_id": "27JeyJbztCdYUcGab2IC/h" + "_id": "69gVddNihMxr/qfTilSBrC" }, { - "__type__": "cc.Sprite", + "__type__": "cc.Layout", "_name": "", "_objFlags": 0, "node": { - "__id__": 9 + "__id__": 18 }, "_enabled": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_spriteFrame": { - "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" + "_layoutSize": { + "__type__": "cc.Size", + "width": 200, + "height": 200 }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_state": 0, - "_atlas": null, - "_id": "b1lcMiUqBPEICmhU3RLpEn" + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0, + "_id": "38x49fSYtAS4pHSHHiWqU0" }, { "__type__": "cc.Node", - "_name": "back", + "_name": "New Label", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 17 }, - "_children": [ - { - "__id__": 23 - } - ], + "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 25 - }, - { - "__id__": 26 + "__id__": 22 } ], "_prefab": null, @@ -960,8 +1017,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 80, + "height": 112 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -970,8 +1027,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": -14, - "y": -281, + "x": 0, + "y": 0, "z": 0 }, "_scale": { @@ -991,38 +1048,80 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 12, + "_zIndex": 0, "groupIndex": 0, - "_id": "77AWwc3mxFRaGjizITd1yK" + "_id": "59aZwyj5pIJaVF8pUrn78L" + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 21 + }, + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "我", + "_N$string": "我", + "_fontSize": 80, + "_lineHeight": 112, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0, + "_id": "08bDs/cn1EBow7LgK8bsqW" + }, + { + "__type__": "cc.Mask", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 17 + }, + "_enabled": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_spriteFrame": null, + "_type": 1, + "_segments": 64, + "_N$alphaThreshold": 1, + "_N$inverted": false, + "_id": "f6j1fibctPvbTpvVOs+MFJ" }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "owner Logo", "_objFlags": 0, "_parent": { - "__id__": 22 + "__id__": 2 }, "_children": [], - "_active": true, + "_active": false, "_level": 0, "_components": [ { - "__id__": 24 + "__id__": 25 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 90, + "height": 32 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1031,8 +1130,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": -1, - "y": 1, + "x": -300, + "y": -60, "z": 0 }, "_scale": { @@ -1052,49 +1151,24 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 13, + "_zIndex": 0, "groupIndex": 0, - "_id": "9awVLiiwBHCpyRKqzKhQ56" - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 23 - }, - "_enabled": true, - "_srcBlendFactor": 1, - "_dstBlendFactor": 771, - "_useOriginalSize": false, - "_string": "返回", - "_N$string": "返回", - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1, - "_id": "9cQNyfijFNPqm/UxJ/wAPm" + "_id": "7bryDySYZDOZh4Au31Nuvk" }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 22 + "__id__": 24 }, "_enabled": true, "_srcBlendFactor": 770, "_dstBlendFactor": 771, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "af729f48-62ab-470c-9bd9-77f219dde1c6" }, - "_type": 1, + "_type": 0, "_sizeMode": 0, "_fillType": 0, "_fillCenter": { @@ -1107,86 +1181,21 @@ "_isTrimmedMode": true, "_state": 0, "_atlas": null, - "_id": "c5UNr9qB1A07HcnL7/1T+H" + "_id": "cceo7z0cNMs5xqz/csUBPC" }, { - "__type__": "cc.Button", - "_name": "", + "__type__": "cc.Node", + "_name": "Player Name One", "_objFlags": 0, - "node": { - "__id__": 22 - }, - "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" - }, - "_N$target": { - "__id__": 22 - }, - "_id": "cbs+rkVe1BT7PkXy7A56kY" - }, - { - "__type__": "cc.Node", - "_name": "refreshNumText", - "_objFlags": 0, - "_parent": { - "__id__": 2 + "_parent": { + "__id__": 2 }, "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 28 + "__id__": 27 } ], "_prefab": null, @@ -1201,7 +1210,7 @@ "_contentSize": { "__type__": "cc.Size", "width": 0, - "height": 20 + "height": 40 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1210,8 +1219,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": -294, - "y": 287, + "x": -300, + "y": -100, "z": 0 }, "_scale": { @@ -1231,16 +1240,16 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 14, + "_zIndex": 0, "groupIndex": 0, - "_id": "08VJWcQH9KMokns7WzkImF" + "_id": "83ansYOd9ALaiiIVIsQ+PL" }, { "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 27 + "__id__": 26 }, "_enabled": true, "_srcBlendFactor": 1, @@ -1248,35 +1257,38 @@ "_useOriginalSize": false, "_string": "", "_N$string": "", - "_fontSize": 20, - "_lineHeight": 20, + "_fontSize": 28, + "_lineHeight": 40, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$horizontalAlign": 0, + "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0, - "_id": "6ev3J7XYFJ/LRnhFrskbG8" + "_id": "f5TWzX8LxP+Y/EgmCetsAk" }, { "__type__": "cc.Node", - "_name": "item", + "_name": "Player Two", "_objFlags": 0, "_parent": { "__id__": 2 }, "_children": [ { - "__id__": 30 + "__id__": 29 + }, + { + "__id__": 32 } ], "_active": true, "_level": 0, "_components": [ { - "__id__": 58 + "__id__": 34 } ], "_prefab": null, @@ -1290,8 +1302,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 600, - "height": 140 + "width": 200, + "height": 200 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1300,8 +1312,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 237, - "y": -381, + "x": 0, + "y": 30, "z": 0 }, "_scale": { @@ -1321,57 +1333,41 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 15, + "_zIndex": 0, "groupIndex": 0, - "_id": "c3Y2Il5OxEqa73Aeu2jBeb" + "_id": "9fCtyk1OlFK6CW+iBfNaGq" }, { "__type__": "cc.Node", - "_name": "backgroud", + "_name": "New Layout", "_objFlags": 0, "_parent": { - "__id__": 29 + "__id__": 28 }, - "_children": [ - { - "__id__": 31 - }, - { - "__id__": 36 - }, - { - "__id__": 41 - }, - { - "__id__": 46 - }, - { - "__id__": 51 - } - ], + "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 56 + "__id__": 30 }, { - "__id__": 57 + "__id__": 31 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 85, + "g": 85, + "b": 85, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 600, - "height": 100 + "width": 200, + "height": 200 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1401,80 +1397,76 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 16, + "_zIndex": 0, "groupIndex": 0, - "_id": "2eeXkvuO9NNouq4ieeESoR" + "_id": "17Rb6sDaNEWJ1iag7CuwQ/" }, { - "__type__": "cc.Node", - "_name": "roomName", + "__type__": "cc.Sprite", + "_name": "", "_objFlags": 0, - "_parent": { - "__id__": 30 - }, - "_children": [ - { - "__id__": 32 - }, - { - "__id__": 34 - } - ], - "_active": true, - "_level": 0, - "_components": [], - "_prefab": null, - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "node": { + "__id__": 29 }, - "_contentSize": { - "__type__": "cc.Size", - "width": 0, - "height": 0 + "_enabled": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_spriteFrame": { + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" }, - "_anchorPoint": { + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_position": { - "__type__": "cc.Vec3", "x": 0, - "y": 0, - "z": 0 + "y": 0 }, - "_scale": { - "__type__": "cc.Vec3", - "x": 1, - "y": 1, - "z": 1 + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "9dMnBLs5NGMb6ku4gFGAc2" + }, + { + "__type__": "cc.Layout", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 29 }, - "_rotationX": 0, - "_rotationY": 0, - "_quat": { - "__type__": "cc.Quat", - "x": 0, - "y": 0, - "z": 0, - "w": 1 + "_enabled": true, + "_layoutSize": { + "__type__": "cc.Size", + "width": 200, + "height": 200 }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 17, - "groupIndex": 0, - "_id": "deSIgDeWlOm7jAFSoJKbMf" + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 + }, + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0, + "_id": "d66vgIbZdKQ6LKWOiLrrKq" }, { "__type__": "cc.Node", - "_name": "New Label", + "_name": "Player Two Label", "_objFlags": 0, "_parent": { - "__id__": 31 + "__id__": 28 }, "_children": [], "_active": true, @@ -1488,15 +1480,15 @@ "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 117, + "g": 117, + "b": 117, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 65.56, - "height": 20 + "width": 40, + "height": 112 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1505,8 +1497,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": -252, - "y": 22, + "x": 0, + "y": 0, "z": 0 }, "_scale": { @@ -1526,9 +1518,9 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 18, + "_zIndex": 0, "groupIndex": 0, - "_id": "c8P/tBLd9FTp3dN4nv9n9B" + "_id": "f4ef4QmuRJKZwKhot3Slye" }, { "__type__": "cc.Label", @@ -1541,48 +1533,65 @@ "_srcBlendFactor": 1, "_dstBlendFactor": 771, "_useOriginalSize": false, - "_string": "房间ID:", - "_N$string": "房间ID:", - "_fontSize": 20, - "_lineHeight": 20, + "_string": "2", + "_N$string": "2", + "_fontSize": 80, + "_lineHeight": 112, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0, - "_id": "9dBUAQo9RNEb4OFSiQw+E8" + "_id": "d2cowarQ1PmbpActSACJEv" + }, + { + "__type__": "cc.Mask", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 28 + }, + "_enabled": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_spriteFrame": null, + "_type": 1, + "_segments": 64, + "_N$alphaThreshold": 1, + "_N$inverted": false, + "_id": "cfUKKFMbJEX4Nxm4a8vsHd" }, { "__type__": "cc.Node", - "_name": "roomID", + "_name": "Player Name Two", "_objFlags": 0, "_parent": { - "__id__": 31 + "__id__": 2 }, "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 35 + "__id__": 36 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 253, - "b": 30, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 20 + "width": 84, + "height": 40 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1591,8 +1600,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": -111, - "y": 22, + "x": 0, + "y": -100, "z": 0 }, "_scale": { @@ -1612,53 +1621,50 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 19, + "_zIndex": 0, "groupIndex": 0, - "_id": "ceQuRoZU1FIboG5eM0xivg" + "_id": "bdMCFgAqJLeqtmdL7PIJV1" }, { "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 34 + "__id__": 35 }, "_enabled": true, "_srcBlendFactor": 1, "_dstBlendFactor": 771, "_useOriginalSize": false, - "_string": "", - "_N$string": "", - "_fontSize": 20, - "_lineHeight": 20, + "_string": "待加入", + "_N$string": "待加入", + "_fontSize": 28, + "_lineHeight": 40, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$horizontalAlign": 0, - "_N$verticalAlign": 0, - "_N$fontFamily": "Arial", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", "_N$overflow": 0, - "_id": "1aRg6X3VBM9ocHSBOkM4PG" + "_id": "75UdicMfxHfoxDbaoZn10W" }, { "__type__": "cc.Node", - "_name": "roomState", + "_name": "ownewLogo2", "_objFlags": 0, "_parent": { - "__id__": 30 + "__id__": 2 }, - "_children": [ - { - "__id__": 37 - }, + "_children": [], + "_active": false, + "_level": 0, + "_components": [ { - "__id__": 39 + "__id__": 38 } ], - "_active": true, - "_level": 0, - "_components": [], "_prefab": null, "_opacity": 255, "_color": { @@ -1670,8 +1676,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 0 + "width": 90, + "height": 32 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1680,8 +1686,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 64, - "y": 22, + "x": 0, + "y": -60, "z": 0 }, "_scale": { @@ -1701,38 +1707,73 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 20, + "_zIndex": 0, "groupIndex": 0, - "_id": "cc6SHlKTNKHbShFulU4USp" + "_id": "820a3LmKBKrbqXgc1PSQHa" }, { - "__type__": "cc.Node", - "_name": "New Label", + "__type__": "cc.Sprite", + "_name": "", "_objFlags": 0, - "_parent": { - "__id__": 36 + "node": { + "__id__": 37 }, - "_children": [], - "_active": true, - "_level": 0, - "_components": [ - { - "__id__": 38 - } - ], - "_prefab": null, - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, + "_enabled": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_spriteFrame": { + "__uuid__": "af729f48-62ab-470c-9bd9-77f219dde1c6" + }, + "_type": 0, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "54SrOiVzNPyqhNlOD1lDbi" + }, + { + "__type__": "cc.Node", + "_name": "Player Three", + "_objFlags": 0, + "_parent": { + "__id__": 2 + }, + "_children": [ + { + "__id__": 40 + }, + { + "__id__": 43 + } + ], + "_active": true, + "_level": 0, + "_components": [ + { + "__id__": 45 + } + ], + "_prefab": null, + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, "b": 255, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 25 + "width": 200, + "height": 200 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1741,8 +1782,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": -4, - "y": 3, + "x": 300, + "y": 30, "z": 0 }, "_scale": { @@ -1762,63 +1803,41 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 21, + "_zIndex": 0, "groupIndex": 0, - "_id": "3e1vQ0fbRP4Juuwc7zDqc0" - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 37 - }, - "_enabled": true, - "_srcBlendFactor": 1, - "_dstBlendFactor": 771, - "_useOriginalSize": false, - "_string": "房间状态:", - "_N$string": "房间状态:", - "_fontSize": 20, - "_lineHeight": 25, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0, - "_id": "0cGXcLFsRNN65XnyAyUbdL" + "_id": "d3DI4xgUdPUaqVf0+zwKIb" }, { "__type__": "cc.Node", - "_name": "state", + "_name": "New Layout", "_objFlags": 0, "_parent": { - "__id__": 36 + "__id__": 39 }, "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 40 + "__id__": 41 + }, + { + "__id__": 42 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 255, - "b": 31, + "r": 85, + "g": 85, + "b": 85, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 20 + "width": 200, + "height": 200 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1827,8 +1846,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 74, - "y": 2, + "x": 0, + "y": 0, "z": 0 }, "_scale": { @@ -1848,66 +1867,98 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 22, + "_zIndex": 0, "groupIndex": 0, - "_id": "f8yS5jSnRP0rwTz7fyrrHT" + "_id": "2essz8j19Mo5Cof8asJiNb" }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 39 + "__id__": 40 }, "_enabled": true, - "_srcBlendFactor": 1, + "_srcBlendFactor": 770, "_dstBlendFactor": 771, - "_useOriginalSize": false, - "_string": "", - "_N$string": "", - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0, - "_id": "c5N7QD9O5CH50KwsTAC49+" + "_spriteFrame": { + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" + }, + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "3fDNBqoddM3othiIQV/G3/" + }, + { + "__type__": "cc.Layout", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 40 + }, + "_enabled": true, + "_layoutSize": { + "__type__": "cc.Size", + "width": 200, + "height": 200 + }, + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 + }, + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0, + "_id": "464NhGSZRJYbOlSRZxO2ae" }, { "__type__": "cc.Node", - "_name": "roomPlayer", + "_name": "Player Three Label", "_objFlags": 0, "_parent": { - "__id__": 30 + "__id__": 39 }, - "_children": [ - { - "__id__": 42 - }, + "_children": [], + "_active": true, + "_level": 0, + "_components": [ { "__id__": 44 } ], - "_active": true, - "_level": 0, - "_components": [], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 117, + "g": 117, + "b": 117, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 0 + "width": 40, + "height": 112 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1916,8 +1967,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": -277, - "y": -37, + "x": 0, + "y": 0, "z": 0 }, "_scale": { @@ -1937,38 +1988,80 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 23, + "_zIndex": 0, "groupIndex": 0, - "_id": "14rPbW0fFO2YFcu7wuBC3u" + "_id": "c6z5pFgztL75GLf1o+T8xN" + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 43 + }, + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "3", + "_N$string": "3", + "_fontSize": 80, + "_lineHeight": 112, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0, + "_id": "10qNbVrJJOQ44ZaiCUhE2T" + }, + { + "__type__": "cc.Mask", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 39 + }, + "_enabled": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_spriteFrame": null, + "_type": 1, + "_segments": 64, + "_N$alphaThreshold": 1, + "_N$inverted": false, + "_id": "64a6arbElFgpoeggPfu+dv" }, { "__type__": "cc.Node", - "_name": "New Label", + "_name": "Player Name Three", "_objFlags": 0, "_parent": { - "__id__": 41 + "__id__": 2 }, "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 43 + "__id__": 47 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 20 + "width": 84, + "height": 40 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -1977,8 +2070,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 43, - "y": 18, + "x": 300, + "y": -100, "z": 0 }, "_scale": { @@ -1998,63 +2091,63 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 24, + "_zIndex": 0, "groupIndex": 0, - "_id": "fb4h9QSOxO6Z/fpW9MMCJt" + "_id": "acHtiyPphM2KlZzPT/GE1t" }, { "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 42 + "__id__": 46 }, "_enabled": true, "_srcBlendFactor": 1, "_dstBlendFactor": 771, "_useOriginalSize": false, - "_string": "房间人数:", - "_N$string": "房间人数:", - "_fontSize": 20, - "_lineHeight": 20, + "_string": "待加入", + "_N$string": "待加入", + "_fontSize": 28, + "_lineHeight": 40, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$horizontalAlign": 0, + "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0, - "_id": "a2G4vj4zxMxYU2Ez2XDWtN" + "_id": "9dT0qX1X1O67zsc2q23H5f" }, { "__type__": "cc.Node", - "_name": "playerNum", + "_name": "ownewLogo3", "_objFlags": 0, "_parent": { - "__id__": 41 + "__id__": 2 }, "_children": [], - "_active": true, + "_active": false, "_level": 0, "_components": [ { - "__id__": 45 + "__id__": 49 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 61, + "r": 255, "g": 255, - "b": 0, + "b": 255, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 20 + "width": 90, + "height": 32 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -2063,8 +2156,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 99, - "y": 17, + "x": 300, + "y": -60, "z": 0 }, "_scale": { @@ -2084,66 +2177,66 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 25, + "_zIndex": 0, "groupIndex": 0, - "_id": "c354a6p8lNyqOYWw7xnoir" + "_id": "e2j3KGtMxJyLhxRUmCI/Nx" }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 44 + "__id__": 48 }, "_enabled": true, - "_srcBlendFactor": 1, + "_srcBlendFactor": 770, "_dstBlendFactor": 771, - "_useOriginalSize": false, - "_string": "", - "_N$string": "", - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0, - "_id": "a5DFtaZ8VNzIKZrfrJVQ3y" + "_spriteFrame": { + "__uuid__": "af729f48-62ab-470c-9bd9-77f219dde1c6" + }, + "_type": 0, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "e5voHO5LZLabuow68HPEbV" }, { "__type__": "cc.Node", - "_name": "roomMap", + "_name": "hint", "_objFlags": 0, "_parent": { - "__id__": 30 + "__id__": 2 }, - "_children": [ - { - "__id__": 47 - }, + "_children": [], + "_active": true, + "_level": 0, + "_components": [ { - "__id__": 49 + "__id__": 51 } ], - "_active": true, - "_level": 0, - "_components": [], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 0 + "width": 310, + "height": 28 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -2153,7 +2246,7 @@ "_position": { "__type__": "cc.Vec3", "x": 0, - "y": 0, + "y": -320, "z": 0 }, "_scale": { @@ -2173,38 +2266,131 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 26, + "_zIndex": 0, "groupIndex": 0, - "_id": "c1lqlM/OpKnZSwvuLUkUl+" + "_id": "48dbWQZXVN+od2+YtUmA/o" }, { - "__type__": "cc.Node", - "_name": "New Label", + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 50 + }, + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "提示:需要满3个玩家才能开始游戏", + "_N$string": "提示:需要满3个玩家才能开始游戏", + "_fontSize": 20, + "_lineHeight": 28, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0, + "_id": "ab5JMPp2JEgIaBpgx3b+iG" + }, + { + "__type__": "cc.Node", + "_name": "btnStartGame", "_objFlags": 0, "_parent": { - "__id__": 46 + "__id__": 2 + }, + "_children": [ + { + "__id__": 53 + } + ], + "_active": true, + "_level": 0, + "_components": [ + { + "__id__": 55 + }, + { + "__id__": 56 + } + ], + "_prefab": null, + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 85, + "g": 85, + "b": 85, + "a": 255 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 240, + "height": 70 + }, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_position": { + "__type__": "cc.Vec3", + "x": -170, + "y": -240, + "z": 0 + }, + "_scale": { + "__type__": "cc.Vec3", + "x": 1, + "y": 1, + "z": 1 + }, + "_rotationX": 0, + "_rotationY": 0, + "_quat": { + "__type__": "cc.Quat", + "x": 0, + "y": 0, + "z": 0, + "w": 1 + }, + "_skewX": 0, + "_skewY": 0, + "_zIndex": 0, + "groupIndex": 0, + "_id": "99xnyQrrdBC4E9KO370SjY" + }, + { + "__type__": "cc.Node", + "_name": "Label", + "_objFlags": 0, + "_parent": { + "__id__": 52 }, "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 48 + "__id__": 54 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 117, + "g": 117, + "b": 117, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 60, - "height": 20 + "width": 240, + "height": 33 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -2213,8 +2399,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 46, - "y": -15, + "x": 0, + "y": 0, "z": 0 }, "_scale": { @@ -2234,150 +2420,827 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 27, + "_zIndex": 0, "groupIndex": 0, - "_id": "e6Cg3cBn9IcYHPojTEKaPW" + "_id": "37f0QNN2NKur2aGicBJlPZ" }, { "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 47 + "__id__": 53 }, "_enabled": true, "_srcBlendFactor": 1, "_dstBlendFactor": 771, "_useOriginalSize": false, - "_string": "地图:", - "_N$string": "地图:", - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, + "_string": "开始游戏", + "_N$string": "开始游戏", + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": false, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$horizontalAlign": 0, + "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0, - "_id": "cfDVkLl0RE/5lzjDy9xu/i" + "_N$fontFamily": "PingFangSC", + "_N$overflow": 1, + "_id": "36InLAbgRNlKDF07SNQiBS" + }, + { + "__type__": "cc.Sprite", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 52 + }, + "_enabled": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_spriteFrame": { + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + }, + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "5bVg+1gXhLe4TETAdwaXB7" + }, + { + "__type__": "cc.Button", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 52 + }, + "_enabled": true, + "transition": 2, + "pressedColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "hoverColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "duration": 0.1, + "zoomScale": 1.2, + "clickEvents": [], + "_N$interactable": true, + "_N$enableAutoGrayEffect": false, + "_N$normalColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_N$disabledColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_N$normalSprite": { + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + }, + "_N$pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "_N$hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "_N$disabledSprite": { + "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + }, + "_N$target": { + "__id__": 52 + }, + "_id": "47Z9dRnSFHjaKTlSz1Qor5" }, { "__type__": "cc.Node", - "_name": "map", + "_name": "mapType", "_objFlags": 0, "_parent": { - "__id__": 46 + "__id__": 2 }, - "_children": [], + "_children": [ + { + "__id__": 58 + } + ], "_active": true, "_level": 0, "_components": [ { - "__id__": 50 + "__id__": 60 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 255, - "b": 61, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_contentSize": { "__type__": "cc.Size", "width": 0, - "height": 20 + "height": 33 + }, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0.5 + }, + "_position": { + "__type__": "cc.Vec3", + "x": 470, + "y": 230, + "z": 0 + }, + "_scale": { + "__type__": "cc.Vec3", + "x": 1, + "y": 1, + "z": 1 + }, + "_rotationX": 0, + "_rotationY": 0, + "_quat": { + "__type__": "cc.Quat", + "x": 0, + "y": 0, + "z": 0, + "w": 1 + }, + "_skewX": 0, + "_skewY": 0, + "_zIndex": 0, + "groupIndex": 0, + "_id": "31zmHG9JBIRoz6FEQDJP8z" + }, + { + "__type__": "cc.Node", + "_name": "New Label", + "_objFlags": 0, + "_parent": { + "__id__": 57 + }, + "_children": [], + "_active": true, + "_level": 0, + "_components": [ + { + "__id__": 59 + } + ], + "_prefab": null, + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 153, + "g": 153, + "b": 153, + "a": 255 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 72, + "height": 33 + }, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0.5 + }, + "_position": { + "__type__": "cc.Vec3", + "x": -70, + "y": 0, + "z": 0 + }, + "_scale": { + "__type__": "cc.Vec3", + "x": 1, + "y": 1, + "z": 1 + }, + "_rotationX": 0, + "_rotationY": 0, + "_quat": { + "__type__": "cc.Quat", + "x": 0, + "y": 0, + "z": 0, + "w": 1 + }, + "_skewX": 0, + "_skewY": 0, + "_zIndex": 0, + "groupIndex": 0, + "_id": "11K2V80aFLgaLSiFMGoNOi" + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 58 + }, + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "地图:", + "_N$string": "地图:", + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0, + "_id": "4bVBr2UdVA+7gpaqAqaY0g" + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 57 + }, + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "", + "_N$string": "", + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "Arial", + "_N$overflow": 0, + "_id": "d3lpOvfK9OOqFTsRtTQY4C" + }, + { + "__type__": "cc.Node", + "_name": "seleButton", + "_objFlags": 0, + "_parent": { + "__id__": 2 + }, + "_children": [ + { + "__id__": 62 + } + ], + "_active": true, + "_level": 0, + "_components": [ + { + "__id__": 64 + }, + { + "__id__": 65 + } + ], + "_prefab": null, + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 166, + "g": 166, + "b": 166, + "a": 255 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 240, + "height": 70 + }, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_position": { + "__type__": "cc.Vec3", + "x": 170, + "y": -240, + "z": 0 + }, + "_scale": { + "__type__": "cc.Vec3", + "x": 1, + "y": 1, + "z": 1 + }, + "_rotationX": 0, + "_rotationY": 0, + "_quat": { + "__type__": "cc.Quat", + "x": 0, + "y": 0, + "z": 0, + "w": 1 + }, + "_skewX": 0, + "_skewY": 0, + "_zIndex": 0, + "groupIndex": 0, + "_id": "1cS0yGafFGR7ztrokDKQ4X" + }, + { + "__type__": "cc.Node", + "_name": "Label", + "_objFlags": 0, + "_parent": { + "__id__": 61 + }, + "_children": [], + "_active": true, + "_level": 0, + "_components": [ + { + "__id__": 63 + } + ], + "_prefab": null, + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 240, + "height": 33 + }, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_position": { + "__type__": "cc.Vec3", + "x": 0, + "y": 0, + "z": 0 + }, + "_scale": { + "__type__": "cc.Vec3", + "x": 1, + "y": 1, + "z": 1 + }, + "_rotationX": 0, + "_rotationY": 0, + "_quat": { + "__type__": "cc.Quat", + "x": 0, + "y": 0, + "z": 0, + "w": 1 + }, + "_skewX": 0, + "_skewY": 0, + "_zIndex": 0, + "groupIndex": 0, + "_id": "00nAXn9ktMmL4CylFWAa/X" + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 62 + }, + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "修改房间属性", + "_N$string": "修改房间属性", + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": false, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 1, + "_id": "55J5eQurBDT7fp++JLJwFx" + }, + { + "__type__": "cc.Sprite", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 61 + }, + "_enabled": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_spriteFrame": { + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + }, + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "6fsZJWZTtPOr9J360nUtJU" + }, + { + "__type__": "cc.Button", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 61 + }, + "_enabled": true, + "transition": 2, + "pressedColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "hoverColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "duration": 0.1, + "zoomScale": 1.2, + "clickEvents": [], + "_N$interactable": true, + "_N$enableAutoGrayEffect": false, + "_N$normalColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_N$disabledColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_N$normalSprite": { + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + }, + "_N$pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "_N$hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "_N$disabledSprite": { + "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + }, + "_N$target": { + "__id__": 61 + }, + "_id": "95Xbv5AvBMWaoXsy8AC48l" + }, + { + "__type__": "cc.Node", + "_name": "buttonClick2", + "_objFlags": 0, + "_parent": { + "__id__": 2 + }, + "_children": [ + { + "__id__": 67 + } + ], + "_active": true, + "_level": 0, + "_components": [ + { + "__id__": 69 + }, + { + "__id__": 70 + } + ], + "_prefab": null, + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 0, + "g": 193, + "b": 224, + "a": 255 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 100, + "height": 40 + }, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_position": { + "__type__": "cc.Vec3", + "x": 0, + "y": -150, + "z": 0 + }, + "_scale": { + "__type__": "cc.Vec3", + "x": 1, + "y": 1, + "z": 1 + }, + "_rotationX": 0, + "_rotationY": 0, + "_quat": { + "__type__": "cc.Quat", + "x": 0, + "y": 0, + "z": 0, + "w": 1 + }, + "_skewX": 0, + "_skewY": 0, + "_zIndex": 0, + "groupIndex": 0, + "_id": "1fdUrtPP5DS7uqimHLbJcC" + }, + { + "__type__": "cc.Node", + "_name": "Label", + "_objFlags": 0, + "_parent": { + "__id__": 66 + }, + "_children": [], + "_active": true, + "_level": 0, + "_components": [ + { + "__id__": 68 + } + ], + "_prefab": null, + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 100, + "height": 40 + }, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_position": { + "__type__": "cc.Vec3", + "x": 0, + "y": 0, + "z": 0 + }, + "_scale": { + "__type__": "cc.Vec3", + "x": 1, + "y": 1, + "z": 1 + }, + "_rotationX": 0, + "_rotationY": 0, + "_quat": { + "__type__": "cc.Quat", + "x": 0, + "y": 0, + "z": 0, + "w": 1 + }, + "_skewX": 0, + "_skewY": 0, + "_zIndex": 0, + "groupIndex": 0, + "_id": "8dR5hX9CxCBJN/eXTDmFay" + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 67 + }, + "_enabled": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_useOriginalSize": false, + "_string": "踢人", + "_N$string": "踢人", + "_fontSize": 20, + "_lineHeight": 40, + "_enableWrapText": false, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 1, + "_id": "7bK7DQkHNHBLVSYHleru0R" + }, + { + "__type__": "cc.Sprite", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 66 + }, + "_enabled": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_spriteFrame": { + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + }, + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "e6pFZI+GpBD7CuJmeoTCxS" + }, + { + "__type__": "cc.Button", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 66 + }, + "_enabled": true, + "transition": 2, + "pressedColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "hoverColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "duration": 0.1, + "zoomScale": 1.2, + "clickEvents": [], + "_N$interactable": true, + "_N$enableAutoGrayEffect": false, + "_N$normalColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_N$disabledColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_N$normalSprite": { + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + }, + "_N$pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" }, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 + "pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" }, - "_position": { - "__type__": "cc.Vec3", - "x": 116, - "y": -14, - "z": 0 + "_N$hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" }, - "_scale": { - "__type__": "cc.Vec3", - "x": 1, - "y": 1, - "z": 1 + "hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" }, - "_rotationX": 0, - "_rotationY": 0, - "_quat": { - "__type__": "cc.Quat", - "x": 0, - "y": 0, - "z": 0, - "w": 1 + "_N$disabledSprite": { + "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" }, - "_skewX": 1, - "_skewY": 1, - "_localZOrder": 28, - "groupIndex": 0, - "_id": "3dqEwYmUZAB4WJ+/vZYMxv" - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 49 + "_N$target": { + "__id__": 66 }, - "_enabled": true, - "_srcBlendFactor": 1, - "_dstBlendFactor": 771, - "_useOriginalSize": false, - "_string": "", - "_N$string": "", - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0, - "_id": "1aNL51ThZHopoY1zYU5ut1" + "_id": "11jFLlctJLAbPsoCHPrut9" }, { "__type__": "cc.Node", - "_name": "startRoom", + "_name": "buttonClick3", "_objFlags": 0, "_parent": { - "__id__": 30 + "__id__": 2 }, "_children": [ { - "__id__": 52 + "__id__": 72 } ], "_active": true, "_level": 0, "_components": [ { - "__id__": 54 + "__id__": 74 }, { - "__id__": 55 + "__id__": 75 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_contentSize": { @@ -2392,8 +3255,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 239, - "y": 2, + "x": 300, + "y": -150, "z": 0 }, "_scale": { @@ -2413,32 +3276,32 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 29, + "_zIndex": 0, "groupIndex": 0, - "_id": "6123gi0xtBD6+OZ2tadIPX" + "_id": "bdajoGM/xJJq/tZrUJdslr" }, { "__type__": "cc.Node", "_name": "Label", "_objFlags": 0, "_parent": { - "__id__": 51 + "__id__": 71 }, "_children": [], "_active": true, "_level": 0, "_components": [ { - "__id__": 53 + "__id__": 73 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_contentSize": { @@ -2474,23 +3337,23 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 30, + "_zIndex": 0, "groupIndex": 0, - "_id": "14FAi2cB9Azb3JUPGQu2MY" + "_id": "8c+xlVjlNJqqtpSovIj7eE" }, { "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 52 + "__id__": 72 }, "_enabled": true, "_srcBlendFactor": 1, "_dstBlendFactor": 771, "_useOriginalSize": false, - "_string": "加入房间", - "_N$string": "加入房间", + "_string": "踢人", + "_N$string": "踢人", "_fontSize": 20, "_lineHeight": 40, "_enableWrapText": false, @@ -2499,16 +3362,16 @@ "_spacingX": 0, "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 1, - "_id": "2a7Di8fV1NSJAqkC7gC7V2" + "_id": "b5yIq7SLFADog80Y8LU8IW" }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 51 + "__id__": 71 }, "_enabled": true, "_srcBlendFactor": 770, @@ -2529,14 +3392,14 @@ "_isTrimmedMode": true, "_state": 0, "_atlas": null, - "_id": "0clqFewjVFMpgEDaXm2jMQ" + "_id": "dbGF+D7sVKj7KkKrtheCQe" }, { "__type__": "cc.Button", "_name": "", "_objFlags": 0, "node": { - "__id__": 51 + "__id__": 71 }, "_enabled": true, "transition": 2, @@ -2592,24 +3455,85 @@ "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" }, "_N$target": { - "__id__": 51 + "__id__": 71 + }, + "_id": "46Pj6k46hAcbGRRHS7H6gI" + }, + { + "__type__": "cc.Node", + "_name": "owner Logo", + "_objFlags": 0, + "_parent": { + "__id__": 2 + }, + "_children": [], + "_active": false, + "_level": 0, + "_components": [ + { + "__id__": 77 + } + ], + "_prefab": null, + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 90, + "height": 32 + }, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_position": { + "__type__": "cc.Vec3", + "x": -300, + "y": -60, + "z": 0 + }, + "_scale": { + "__type__": "cc.Vec3", + "x": 1, + "y": 1, + "z": 1 + }, + "_rotationX": 0, + "_rotationY": 0, + "_quat": { + "__type__": "cc.Quat", + "x": 0, + "y": 0, + "z": 0, + "w": 1 }, - "_id": "729W1tmaBFfaMrPkVwn3Xk" + "_skewX": 0, + "_skewY": 0, + "_zIndex": 0, + "groupIndex": 0, + "_id": "04imoLkURADqEc7Y2v23qt" }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 30 + "__id__": 76 }, "_enabled": true, "_srcBlendFactor": 770, "_dstBlendFactor": 771, "_spriteFrame": { - "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" + "__uuid__": "af729f48-62ab-470c-9bd9-77f219dde1c6" }, - "_type": 1, + "_type": 0, "_sizeMode": 0, "_fillType": 0, "_fillCenter": { @@ -2622,132 +3546,36 @@ "_isTrimmedMode": true, "_state": 0, "_atlas": null, - "_id": "4cJUHLMnpKf6lT2qzrELqB" - }, - { - "__type__": "cc.Button", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 30 - }, - "_enabled": true, - "transition": 0, - "pressedColor": { - "__type__": "cc.Color", - "r": 211, - "g": 211, - "b": 211, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 214, - "g": 214, - "b": 214, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 124, - "g": 124, - "b": 124, - "a": 255 - }, - "_N$normalSprite": null, - "_N$pressedSprite": null, - "pressedSprite": null, - "_N$hoverSprite": null, - "hoverSprite": null, - "_N$disabledSprite": null, - "_N$target": { - "__id__": 30 - }, - "_id": "9bkkJlvNhBF4C902y+V0du" - }, - { - "__type__": "5ef25w8ddVIeKi0B0zGVSIS", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 29 - }, - "_enabled": true, - "roomName": { - "__id__": 35 - }, - "roomState": { - "__id__": 40 - }, - "roomPlayer": { - "__id__": 45 - }, - "roomMap": { - "__id__": 50 - }, - "startGame": { - "__id__": 51 - }, - "itemID": 0, - "_id": "a5msYJIoxPdoR+XcHMNNb0" - }, - { - "__type__": "cc.Canvas", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 2 - }, - "_enabled": true, - "_designResolution": { - "__type__": "cc.Size", - "width": 960, - "height": 640 - }, - "_fitWidth": false, - "_fitHeight": true, - "_id": "56oz8IZsRESYX/CYtOmGXP" + "_id": "083Mz3P+pHJ6J/tkfIKjRW" }, { "__type__": "cc.Node", - "_name": "roomList", + "_name": "owner Logo", "_objFlags": 0, "_parent": { - "__id__": 1 + "__id__": 2 }, "_children": [], - "_active": true, + "_active": false, "_level": 0, "_components": [ { - "__id__": 61 + "__id__": 79 } ], "_prefab": null, "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 19, - "g": 2, - "b": 2, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 0 + "width": 90, + "height": 32 }, "_anchorPoint": { "__type__": "cc.Vec2", @@ -2756,8 +3584,8 @@ }, "_position": { "__type__": "cc.Vec3", - "x": 46, - "y": 40, + "x": -300, + "y": -60, "z": 0 }, "_scale": { @@ -2777,35 +3605,113 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 31, + "_zIndex": 0, "groupIndex": 0, - "_id": "19h5CFJntKGbTfffevOf4F" + "_id": "43Ta4jNNFPa7hNDG3HMMBO" }, { - "__type__": "4cf8aAo3zhGCpy3KJJBdkOW", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 60 + "__id__": 78 }, "_enabled": true, - "back": { - "__id__": 22 + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_spriteFrame": { + "__uuid__": "af729f48-62ab-470c-9bd9-77f219dde1c6" }, - "itemTemplate": { - "__id__": 29 + "_type": 0, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_state": 0, + "_atlas": null, + "_id": "2d9vvXy1hKB6x24Ofbt2m4" + }, + { + "__type__": "cc.Canvas", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 2 + }, + "_enabled": true, + "_designResolution": { + "__type__": "cc.Size", + "width": 1280, + "height": 720 + }, + "_fitWidth": true, + "_fitHeight": false, + "_id": "e4o23njTtARoBHCU7e/goI" + }, + { + "__type__": "d6f9ds2b45G/72niDeS85+A", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 2 + }, + "_enabled": true, + "labelMyRoomID": { + "__id__": 16 + }, + "labelUserName": { + "__id__": 27 + }, + "labelUserName2": { + "__id__": 36 + }, + "labelUserName3": { + "__id__": 47 }, - "scrollView": { + "nickName": { "__id__": 14 }, - "spacing": 0, - "totalCount": 0, - "labelInfo": { - "__id__": 8 + "leaveRoom": { + "__id__": 7 }, - "refreshNumText": { - "__id__": 28 + "btnStartGame": { + "__id__": 52 + }, + "kickPlayer2": { + "__id__": 66 + }, + "kickPlayer3": { + "__id__": 71 + }, + "seleButton": { + "__id__": 61 + }, + "mapString": { + "__id__": 60 + }, + "userList": [], + "labelUserID2": { + "__id__": 33 + }, + "labelUserID3": { + "__id__": 44 + }, + "ownerLogo": { + "__id__": 24 + }, + "ownerLogo2": { + "__id__": 37 + }, + "ownerLogo3": { + "__id__": 48 }, - "_id": "e6AML/R6FJzopPm8J2Yt3X" + "userIDfontSize": 18, + "_id": "b8Uq1J5BJIuokcG0Mz+yCT" } ] \ No newline at end of file diff --git a/assets/independent.fire.meta b/assets/scene/CreateRoom.fire.meta similarity index 65% rename from assets/independent.fire.meta rename to assets/scene/CreateRoom.fire.meta index d2d3b56..c08a138 100644 --- a/assets/independent.fire.meta +++ b/assets/scene/CreateRoom.fire.meta @@ -1,6 +1,6 @@ { "ver": "1.0.0", - "uuid": "558b2dcb-1d21-4303-9fa2-67e94a6b1dab", + "uuid": "c3e0ce22-ffc8-423d-948a-29d0debd4752", "asyncLoadAssets": false, "autoReleaseAssets": false, "subMetas": {} diff --git a/assets/game.fire b/assets/scene/Game.fire similarity index 97% rename from assets/game.fire rename to assets/scene/Game.fire index ba566c1..811b553 100644 --- a/assets/game.fire +++ b/assets/scene/Game.fire @@ -123,16 +123,19 @@ }, { "__id__": 83 + }, + { + "__id__": 97 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 97 + "__id__": 99 }, { - "__id__": 98 + "__id__": 100 } ], "_prefab": null, @@ -188,7 +191,7 @@ } ], "_prefab": null, - "_id": "03a60X7kw5Hc7EHsdAS2sAx", + "_id": "cfky7VcwxJ3YEKDNSIGbEe", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -205,17 +208,17 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 512, - "height": 362 + "width": 1332, + "height": 600 }, "_rotationX": 0, "_rotationY": 0, - "_scaleX": 2.5, - "_scaleY": 2, + "_scaleX": 1, + "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -2, - "y": 13 + "x": 0, + "y": 121 }, "_skewX": 0, "_skewY": 0, @@ -235,8 +238,8 @@ "_spriteFrame": { "__uuid__": "5ae5fc98-59fc-46aa-a111-ea45a3736d35" }, - "_type": 0, - "_sizeMode": 1, + "_type": 2, + "_sizeMode": 0, "_fillType": 0, "_fillCenter": { "__type__": "cc.Vec2", @@ -246,8 +249,8 @@ "_fillStart": 0, "_fillRange": 0, "_isTrimmedMode": true, - "_srcBlendFactor": 0, - "_dstBlendFactor": 0, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, "_atlas": null }, { @@ -311,7 +314,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -385,7 +388,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -459,7 +462,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -533,7 +536,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -607,7 +610,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -818,7 +821,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 40, "_enableWrapText": false, @@ -982,7 +985,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, + "_actualFontSize": 40, "_fontSize": 30, "_lineHeight": 40, "_enableWrapText": true, @@ -1058,7 +1061,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, + "_actualFontSize": 40, "_fontSize": 30, "_lineHeight": 40, "_enableWrapText": true, @@ -1134,7 +1137,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, + "_actualFontSize": 40, "_fontSize": 30, "_lineHeight": 40, "_enableWrapText": true, @@ -1210,7 +1213,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -1284,7 +1287,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -1358,7 +1361,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -1432,7 +1435,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -1506,7 +1509,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -1639,7 +1642,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 40, "_enableWrapText": false, @@ -1862,7 +1865,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 40, "_enableWrapText": false, @@ -2085,7 +2088,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, + "_actualFontSize": 40, "_fontSize": 20, "_lineHeight": 40, "_enableWrapText": false, @@ -2249,7 +2252,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 10, + "_actualFontSize": 40, "_fontSize": 10, "_lineHeight": 10, "_enableWrapText": true, @@ -2389,7 +2392,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 32, + "_actualFontSize": 40, "_fontSize": 32, "_lineHeight": 40, "_enableWrapText": true, @@ -2664,6 +2667,7 @@ "isDebug": true, "userID": 1, "playerLabel": null, + "mouseListener": null, "startPostion": 0 }, { @@ -2804,7 +2808,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 32, + "_actualFontSize": 40, "_fontSize": 32, "_lineHeight": 40, "_enableWrapText": true, @@ -3079,6 +3083,7 @@ "isDebug": false, "userID": 1, "playerLabel": null, + "mouseListener": null, "startPostion": 0 }, { @@ -3219,7 +3224,7 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 32, + "_actualFontSize": 40, "_fontSize": 32, "_lineHeight": 40, "_enableWrapText": true, @@ -3494,6 +3499,7 @@ "isDebug": false, "userID": 0, "playerLabel": null, + "mouseListener": null, "startPostion": 0 }, { @@ -3507,6 +3513,69 @@ "fileId": "50bd28LEuBGvaxyZ+RyEm6C", "sync": false }, + { + "__type__": "cc.Node", + "_name": "Main Camera", + "_objFlags": 0, + "_parent": { + "__id__": 2 + }, + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 98 + } + ], + "_prefab": null, + "_id": "646SqQjFZNn53Cx3U4h7tA", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 0, + "height": 0 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 0, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Camera", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 97 + }, + "_enabled": true, + "_targets": [], + "zoomRatio": 1 + }, { "__type__": "cc.Canvas", "_name": "", diff --git a/assets/joinCertainRoom.fire b/assets/scene/JoinCertainRoom.fire similarity index 82% rename from assets/joinCertainRoom.fire rename to assets/scene/JoinCertainRoom.fire index 4c3ace9..0ae62ed 100644 --- a/assets/joinCertainRoom.fire +++ b/assets/scene/JoinCertainRoom.fire @@ -71,17 +71,23 @@ "__id__": 11 }, { - "__id__": 16 + "__id__": 13 + }, + { + "__id__": 15 + }, + { + "__id__": 20 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 21 + "__id__": 22 }, { - "__id__": 22 + "__id__": 23 } ], "_prefab": null, @@ -102,8 +108,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -111,8 +117,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 480, - "y": 320 + "x": 640, + "y": 360 }, "_skewX": 0, "_skewY": 0, @@ -123,7 +129,7 @@ }, { "__type__": "cc.Node", - "_name": "labelInfo", + "_name": "backgrout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -137,13 +143,169 @@ } ], "_prefab": null, - "_id": "557P06KH1K9K3xvFl4KtrD", + "_id": "46bVcSD3VJep9+UNOtPNGi", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 1280, + "height": 720 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 0, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Sprite", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 3 + }, + "_enabled": true, + "_spriteFrame": { + "__uuid__": "0cbd03ff-a827-4248-a85b-6bfd7ebfcabd" + }, + "_type": 2, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null + }, + { + "__type__": "cc.Node", + "_name": "back", + "_objFlags": 0, + "_parent": { + "__id__": 2 + }, + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 6 + } + ], + "_prefab": null, + "_id": "34o/fil/tMb7jhOHtKv0lr", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 228, - "g": 58, - "b": 92, + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 20, + "height": 36 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": -580, + "y": 290 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 0, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Sprite", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 5 + }, + "_enabled": true, + "_spriteFrame": { + "__uuid__": "3f66add4-81b7-41d8-995e-1553cd3ef92e" + }, + "_type": 0, + "_sizeMode": 1, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null + }, + { + "__type__": "cc.Node", + "_name": "nickName", + "_objFlags": 0, + "_parent": { + "__id__": 2 + }, + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 8 + } + ], + "_prefab": null, + "_id": "a1xEsOD3tLcYFdipFOnKw/", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -163,8 +325,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 269, - "y": 164 + "x": 440, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -178,7 +340,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 3 + "__id__": 7 }, "_enabled": true, "_useOriginalSize": false, @@ -192,7 +354,7 @@ "_N$string": "", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { @@ -207,7 +369,7 @@ "_active": true, "_components": [ { - "__id__": 6 + "__id__": 10 } ], "_prefab": null, @@ -223,13 +385,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 120, - "height": 30 + "width": 144, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -237,8 +399,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -179, - "y": 53 + "x": -400, + "y": 180 }, "_skewX": 0, "_skewY": 0, @@ -252,21 +414,21 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 5 + "__id__": 9 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 30, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "房间号:", + "_N$string": "请输入房间号", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { @@ -281,7 +443,7 @@ "_active": true, "_components": [ { - "__id__": 8 + "__id__": 12 } ], "_prefab": null, @@ -302,8 +464,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 300, - "height": 40 + "width": 800, + "height": 92 }, "_rotationX": 0, "_rotationY": 0, @@ -311,8 +473,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 50, - "y": 54 + "x": 0, + "y": 80 }, "_skewX": 0, "_skewY": 0, @@ -326,7 +488,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 7 + "__id__": 11 }, "_enabled": true, "_useOriginalSize": false, @@ -342,16 +504,16 @@ "_N$returnType": 0, "_N$inputFlag": 5, "_N$inputMode": 6, - "_N$fontSize": 29, - "_N$lineHeight": 40, + "_N$fontSize": 48, + "_N$lineHeight": 67, "_N$fontColor": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 40, + "g": 40, + "b": 40, "a": 255 }, - "_N$placeholder": "Enter text here...", + "_N$placeholder": "", "_N$placeholderFontSize": 20, "_N$placeholderFontColor": { "__type__": "cc.Color", @@ -360,7 +522,7 @@ "b": 127, "a": 255 }, - "_N$maxLength": 20, + "_N$maxLength": 40, "_N$stayOnTop": false }, { @@ -375,7 +537,7 @@ "_active": true, "_components": [ { - "__id__": 10 + "__id__": 14 } ], "_prefab": null, @@ -405,8 +567,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": 243 + "x": -420, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -420,7 +582,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 9 + "__id__": 13 }, "_enabled": true, "_useOriginalSize": false, @@ -439,34 +601,34 @@ }, { "__type__": "cc.Node", - "_name": "back", + "_name": "match", "_objFlags": 0, "_parent": { "__id__": 2 }, "_children": [ { - "__id__": 12 + "__id__": 16 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 14 + "__id__": 18 }, { - "__id__": 15 + "__id__": 19 } ], "_prefab": null, - "_id": "77AGna47JM0pI355/nvMoM", + "_id": "d0EOpZFyZK8ImmzoFkbQkQ", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -477,8 +639,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 240, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -486,8 +648,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 219, - "y": -159 + "x": 0, + "y": -180 }, "_skewX": 0, "_skewY": 0, @@ -501,24 +663,24 @@ "_name": "Label", "_objFlags": 0, "_parent": { - "__id__": 11 + "__id__": 15 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 13 + "__id__": 17 } ], "_prefab": null, - "_id": "b6lzBf83RFMITum8EgKJDt", + "_id": "eaFhd1cERHsr4ZfayQl4gi", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -529,8 +691,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 240, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -553,21 +715,21 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 12 + "__id__": 16 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, "_enableWrapText": false, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "返回", + "_N$string": "进入房间", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 1 }, { @@ -575,7 +737,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 11 + "__id__": 15 }, "_enabled": true, "_spriteFrame": { @@ -601,7 +763,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 11 + "__id__": 15 }, "_enabled": true, "transition": 2, @@ -657,103 +819,44 @@ "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" }, "_N$target": { - "__id__": 11 + "__id__": 15 } }, { "__type__": "cc.Node", - "_name": "match", + "_name": "ErrorHint", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 17 - } - ], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 19 - }, - { - "__id__": 20 - } - ], - "_prefab": null, - "_id": "d0EOpZFyZK8ImmzoFkbQkQ", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 100, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": -214, - "y": -159 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Node", - "_name": "Label", - "_objFlags": 0, - "_parent": { - "__id__": 16 - }, "_children": [], "_tag": -1, - "_active": true, + "_active": false, "_components": [ { - "__id__": 18 + "__id__": 21 } ], "_prefab": null, - "_id": "eaFhd1cERHsr4ZfayQl4gi", + "_id": "9fKL+zEy5DgKdGIlDuJCJn", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 89, + "b": 89, "a": 255 }, "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 336, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -761,8 +864,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": 0 + "x": -400, + "y": -12 }, "_skewX": 0, "_skewY": 0, @@ -776,112 +879,22 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 17 + "__id__": 20 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "匹配", + "_N$string": "没有查找到此房间,请重新输入", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, - { - "__type__": "cc.Sprite", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 16 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null - }, - { - "__type__": "cc.Button", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 16 - }, - "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" - }, - "_N$target": { - "__id__": 16 - } + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Canvas", @@ -893,11 +906,11 @@ "_enabled": true, "_designResolution": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, - "_fitWidth": false, - "_fitHeight": true + "_fitWidth": true, + "_fitHeight": false }, { "__type__": "6b3d28D/GBHU4Zx0HhFsFZg", @@ -908,16 +921,19 @@ }, "_enabled": true, "match": { - "__id__": 16 + "__id__": 15 }, "back": { - "__id__": 11 + "__id__": 5 }, - "roomID": { + "nickName": { "__id__": 8 }, - "labelInfo": { - "__id__": 4 + "roomID": { + "__id__": 12 + }, + "errorHint": { + "__id__": 21 } } ] \ No newline at end of file diff --git a/assets/joinCertainRoom.fire.meta b/assets/scene/JoinCertainRoom.fire.meta similarity index 100% rename from assets/joinCertainRoom.fire.meta rename to assets/scene/JoinCertainRoom.fire.meta diff --git a/assets/independent.fire b/assets/scene/Lobby.fire similarity index 53% rename from assets/independent.fire rename to assets/scene/Lobby.fire index 9372cf3..145e404 100644 --- a/assets/independent.fire +++ b/assets/scene/Lobby.fire @@ -21,7 +21,7 @@ "_active": true, "_components": [], "_prefab": null, - "_id": "558b2dcb-1d21-4303-9fa2-67e94a6b1dab", + "_id": "37270621-16d2-4a76-bb39-08a27417a926", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -59,66 +59,57 @@ "__id__": 3 }, { - "__id__": 6 - }, - { - "__id__": 8 - }, - { - "__id__": 10 - }, - { - "__id__": 12 + "__id__": 5 }, { - "__id__": 14 + "__id__": 7 }, { - "__id__": 16 + "__id__": 9 }, { - "__id__": 18 + "__id__": 11 }, { - "__id__": 20 + "__id__": 13 }, { - "__id__": 22 + "__id__": 15 }, { - "__id__": 24 + "__id__": 17 }, { - "__id__": 26 + "__id__": 19 }, { - "__id__": 28 + "__id__": 21 }, { - "__id__": 33 + "__id__": 23 }, { - "__id__": 35 + "__id__": 25 }, { - "__id__": 37 + "__id__": 27 }, { - "__id__": 42 + "__id__": 29 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 44 + "__id__": 32 }, { - "__id__": 45 + "__id__": 33 } ], "_prefab": null, - "_id": "c6r7uaSI1I/oRj2A1MMqWz", + "_id": "92hS2pffxKu47xvhK0ezMf", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -135,8 +126,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -144,8 +135,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 480, - "y": 320 + "x": 640, + "y": 360 }, "_skewX": 0, "_skewY": 0, @@ -156,7 +147,7 @@ }, { "__type__": "cc.Node", - "_name": "New Layout", + "_name": "backgrout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -167,19 +158,16 @@ "_components": [ { "__id__": 4 - }, - { - "__id__": 5 } ], "_prefab": null, - "_id": "67ZLMdwi5PCIv4oOcVEypr", + "_id": "2cr9v+dBZGq64edb4Nbqk9", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 204, - "g": 204, - "b": 204, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -190,8 +178,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -218,9 +206,9 @@ }, "_enabled": true, "_spriteFrame": { - "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" + "__uuid__": "0cbd03ff-a827-4248-a85b-6bfd7ebfcabd" }, - "_type": 1, + "_type": 2, "_sizeMode": 0, "_fillType": 0, "_fillCenter": { @@ -235,40 +223,9 @@ "_dstBlendFactor": 771, "_atlas": null }, - { - "__type__": "cc.Layout", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 3 - }, - "_enabled": true, - "_layoutSize": { - "__type__": "cc.Size", - "width": 960, - "height": 640 - }, - "_resize": 0, - "_N$layoutType": 0, - "_N$padding": 0, - "_N$cellSize": { - "__type__": "cc.Size", - "width": 40, - "height": 40 - }, - "_N$startAxis": 0, - "_N$paddingLeft": 0, - "_N$paddingRight": 0, - "_N$paddingTop": 0, - "_N$paddingBottom": 0, - "_N$spacingX": 0, - "_N$spacingY": 0, - "_N$verticalDirection": 1, - "_N$horizontalDirection": 0 - }, { "__type__": "cc.Node", - "_name": "label", + "_name": "sprite", "_objFlags": 0, "_parent": { "__id__": 2 @@ -278,17 +235,17 @@ "_active": true, "_components": [ { - "__id__": 7 + "__id__": 6 } ], "_prefab": null, - "_id": "1fQTtQz/lAcp+xLwB6SBNd", + "_id": "54LtT37jhGCL3EKpJDkGjZ", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -299,7 +256,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 160, + "width": 30, "height": 40 }, "_rotationX": 0, @@ -308,8 +265,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": 270 + "x": -390, + "y": 128 }, "_skewX": 0, "_skewY": 0, @@ -319,30 +276,34 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 6 + "__id__": 5 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "独立部署", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "6207aaeb-a5d8-406f-b278-10f6f52ecd1f" + }, + "_type": 0, + "_sizeMode": 1, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "label", + "_name": "nickName", "_objFlags": 0, "_parent": { "__id__": 2 @@ -352,17 +313,17 @@ "_active": true, "_components": [ { - "__id__": 9 + "__id__": 8 } ], "_prefab": null, - "_id": "6bZwLH8ThFWqKfY7daYcEB", + "_id": "5fqpZQ6u1ClJ76ABU/aWZ8", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -373,8 +334,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 118, - "height": 40 + "width": 0, + "height": 20 }, "_rotationX": 0, "_rotationY": 0, @@ -382,8 +343,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -230, - "y": -120 + "x": 440, + "y": 289.99999999999994 }, "_skewX": 0, "_skewY": 0, @@ -397,26 +358,26 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 8 + "__id__": 7 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 40, + "_actualFontSize": 20, + "_fontSize": 20, + "_lineHeight": 20, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "userID:", - "_N$horizontalAlign": 0, + "_N$string": "", + "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "label", + "_name": "avatar", "_objFlags": 0, "_parent": { "__id__": 2 @@ -426,17 +387,17 @@ "_active": true, "_components": [ { - "__id__": 11 + "__id__": 10 } ], "_prefab": null, - "_id": "2dTWyHSy5E8JYLBaTjN2Jd", + "_id": "cd5htbr8NAQIYg/0Id7noS", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -447,8 +408,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 112, - "height": 40 + "width": 56, + "height": 56 }, "_rotationX": 0, "_rotationY": 0, @@ -456,8 +417,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -230, - "y": -40 + "x": 481, + "y": 223 }, "_skewX": 0, "_skewY": 0, @@ -467,30 +428,32 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 10 + "__id__": 9 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "secret:", - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": null, + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 1, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "label", + "_name": "title", "_objFlags": 0, "_parent": { "__id__": 2 @@ -500,17 +463,17 @@ "_active": true, "_components": [ { - "__id__": 13 + "__id__": 12 } ], "_prefab": null, - "_id": "45rnNFj/tL7Kg/L6di68Ij", + "_id": "b2MiY4fjlCBYRQMkjE+5ut", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -521,7 +484,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 77, + "width": 144, "height": 40 }, "_rotationX": 0, @@ -530,8 +493,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -230, - "y": 40 + "x": -440, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -545,26 +508,26 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 12 + "__id__": 11 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, + "_actualFontSize": 36, + "_fontSize": 36, "_lineHeight": 40, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "key:", - "_N$horizontalAlign": 0, + "_N$string": "游戏大厅", + "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "label", + "_name": "logout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -574,17 +537,17 @@ "_active": true, "_components": [ { - "__id__": 15 + "__id__": 14 } ], "_prefab": null, - "_id": "3aMaYzsQlOj51g0T1PXhNV", + "_id": "2dHYHikwZJS76nQHI8vjLS", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -595,8 +558,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 142, - "height": 40 + "width": 20, + "height": 36 }, "_rotationX": 0, "_rotationY": 0, @@ -604,8 +567,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -230, - "y": 120 + "x": -550, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -615,30 +578,34 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 14 + "__id__": 13 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "GameID:", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "3f66add4-81b7-41d8-995e-1553cd3ef92e" + }, + "_type": 0, + "_sizeMode": 1, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "label", + "_name": "randomMatch", "_objFlags": 0, "_parent": { "__id__": 2 @@ -648,29 +615,29 @@ "_active": true, "_components": [ { - "__id__": 17 + "__id__": 16 } ], "_prefab": null, - "_id": "500sYl5ppIbLA//JTGa8dg", + "_id": "9cg74ga5VFbony5dzje2t+", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 152, - "height": 40 + "width": 192, + "height": 67 }, "_rotationX": 0, "_rotationY": 0, @@ -678,8 +645,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -230, - "y": 200 + "x": -340, + "y": 128 }, "_skewX": 0, "_skewY": 0, @@ -693,26 +660,26 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 16 + "__id__": 15 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 40, + "_actualFontSize": 48, + "_fontSize": 48, + "_lineHeight": 67, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "EndPoint:", + "_N$string": "随机匹配", "_N$horizontalAlign": 0, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "endPointEditBox", + "_name": "selfDefMatch", "_objFlags": 0, "_parent": { "__id__": 2 @@ -722,11 +689,11 @@ "_active": true, "_components": [ { - "__id__": 19 + "__id__": 18 } ], "_prefab": null, - "_id": "a4UbhBJU5JGKZYmSObeVde", + "_id": "f5t3AmHuFKF4FblB7YnL9k", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -738,12 +705,12 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 360, + "width": 196, "height": 40 }, "_rotationX": 0, @@ -752,8 +719,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": 200 + "x": -340, + "y": -8 }, "_skewX": 0, "_skewY": 0, @@ -763,50 +730,30 @@ "groupIndex": 0 }, { - "__type__": "cc.EditBox", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 18 + "__id__": 17 }, "_enabled": true, "_useOriginalSize": false, - "_string": "mt21gateway.matchvs.com", - "_tabIndex": 0, - "editingDidBegan": [], - "textChanged": [], - "editingDidEnded": [], - "editingReturn": [], - "_N$backgroundImage": { - "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" - }, - "_N$returnType": 0, - "_N$inputFlag": 5, - "_N$inputMode": 6, - "_N$fontSize": 25, - "_N$lineHeight": 40, - "_N$fontColor": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_N$placeholder": "Enter text here...", - "_N$placeholderFontSize": 20, - "_N$placeholderFontColor": { - "__type__": "cc.Color", - "r": 127, - "g": 127, - "b": 127, - "a": 255 - }, - "_N$maxLength": 99, - "_N$stayOnTop": false + "_actualFontSize": 28, + "_fontSize": 28, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "自定义属性匹配", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "gameIDEditBox", + "_name": "syncFrame", "_objFlags": 0, "_parent": { "__id__": 2 @@ -816,11 +763,11 @@ "_active": true, "_components": [ { - "__id__": 21 + "__id__": 20 } ], "_prefab": null, - "_id": "330HG1m/lD2qMaIhR8CreJ", + "_id": "efAuYa3UtOk6WTMC/2nNEF", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -832,12 +779,12 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 360, + "width": 140, "height": 40 }, "_rotationX": 0, @@ -846,8 +793,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": 120 + "x": -340, + "y": -118 }, "_skewX": 0, "_skewY": 0, @@ -857,50 +804,30 @@ "groupIndex": 0 }, { - "__type__": "cc.EditBox", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 20 + "__id__": 19 }, "_enabled": true, "_useOriginalSize": false, - "_string": "1", - "_tabIndex": 0, - "editingDidBegan": [], - "textChanged": [], - "editingDidEnded": [], - "editingReturn": [], - "_N$backgroundImage": { - "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" - }, - "_N$returnType": 0, - "_N$inputFlag": 5, - "_N$inputMode": 6, - "_N$fontSize": 25, - "_N$lineHeight": 40, - "_N$fontColor": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_N$placeholder": "Enter text here...", - "_N$placeholderFontSize": 20, - "_N$placeholderFontColor": { - "__type__": "cc.Color", - "r": 127, - "g": 127, - "b": 127, - "a": 255 - }, - "_N$maxLength": 99, - "_N$stayOnTop": false + "_actualFontSize": 28, + "_fontSize": 28, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "帧同步匹配", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "keyEditBox", + "_name": "joinCertainRoom", "_objFlags": 0, "_parent": { "__id__": 2 @@ -910,11 +837,11 @@ "_active": true, "_components": [ { - "__id__": 23 + "__id__": 22 } ], "_prefab": null, - "_id": "02q+4CarNEZ5E16cnWi6qd", + "_id": "0cTh2fxV5N5oRDwgKGJIbW", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -926,12 +853,12 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 360, + "width": 168, "height": 40 }, "_rotationX": 0, @@ -940,8 +867,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": 40 + "x": 180, + "y": -118 }, "_skewX": 0, "_skewY": 0, @@ -951,50 +878,30 @@ "groupIndex": 0 }, { - "__type__": "cc.EditBox", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 22 + "__id__": 21 }, "_enabled": true, "_useOriginalSize": false, - "_string": "appkey01", - "_tabIndex": 0, - "editingDidBegan": [], - "textChanged": [], - "editingDidEnded": [], - "editingReturn": [], - "_N$backgroundImage": { - "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" - }, - "_N$returnType": 0, - "_N$inputFlag": 5, - "_N$inputMode": 6, - "_N$fontSize": 25, - "_N$lineHeight": 40, - "_N$fontColor": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_N$placeholder": "Enter text here...", - "_N$placeholderFontSize": 20, - "_N$placeholderFontColor": { - "__type__": "cc.Color", - "r": 127, - "g": 127, - "b": 127, - "a": 255 - }, - "_N$maxLength": 99, - "_N$stayOnTop": false + "_actualFontSize": 28, + "_fontSize": 28, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "加入指定房间", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "secretEditBox", + "_name": "roomList", "_objFlags": 0, "_parent": { "__id__": 2 @@ -1004,11 +911,11 @@ "_active": true, "_components": [ { - "__id__": 25 + "__id__": 24 } ], "_prefab": null, - "_id": "b2NfvYQK5LtYAyKW3M/jeC", + "_id": "b037owl3BOY6VxidoN1QYy", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1020,12 +927,12 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 360, + "width": 168, "height": 40 }, "_rotationX": 0, @@ -1034,8 +941,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": -40 + "x": 180, + "y": -8 }, "_skewX": 0, "_skewY": 0, @@ -1045,50 +952,30 @@ "groupIndex": 0 }, { - "__type__": "cc.EditBox", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 24 + "__id__": 23 }, "_enabled": true, "_useOriginalSize": false, - "_string": "appsecret01", - "_tabIndex": 0, - "editingDidBegan": [], - "textChanged": [], - "editingDidEnded": [], - "editingReturn": [], - "_N$backgroundImage": { - "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" - }, - "_N$returnType": 0, - "_N$inputFlag": 5, - "_N$inputMode": 6, - "_N$fontSize": 25, - "_N$lineHeight": 40, - "_N$fontColor": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_N$placeholder": "Enter text here...", - "_N$placeholderFontSize": 20, - "_N$placeholderFontColor": { - "__type__": "cc.Color", - "r": 127, - "g": 127, - "b": 127, - "a": 255 - }, - "_N$maxLength": 99, - "_N$stayOnTop": false + "_actualFontSize": 28, + "_fontSize": 28, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "查看房间列表", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "userIDeditBox", + "_name": "creatRoom", "_objFlags": 0, "_parent": { "__id__": 2 @@ -1098,11 +985,11 @@ "_active": true, "_components": [ { - "__id__": 27 + "__id__": 26 } ], "_prefab": null, - "_id": "3f/V70R+xHLobAG7b4TF8j", + "_id": "5acgrBGbBGc7UMoL7qD03C", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1114,13 +1001,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 360, - "height": 40 + "width": 192, + "height": 67 }, "_rotationX": 0, "_rotationY": 0, @@ -1128,8 +1015,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": -120 + "x": 180, + "y": 127.99999999999989 }, "_skewX": 0, "_skewY": 0, @@ -1139,129 +1026,50 @@ "groupIndex": 0 }, { - "__type__": "cc.EditBox", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 26 + "__id__": 25 }, "_enabled": true, "_useOriginalSize": false, - "_string": "123456", - "_tabIndex": 0, - "editingDidBegan": [], - "textChanged": [], - "editingDidEnded": [], - "editingReturn": [], - "_N$backgroundImage": { - "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" - }, - "_N$returnType": 0, - "_N$inputFlag": 5, - "_N$inputMode": 6, - "_N$fontSize": 25, - "_N$lineHeight": 40, - "_N$fontColor": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_N$placeholder": "Enter text here...", - "_N$placeholderFontSize": 20, - "_N$placeholderFontColor": { - "__type__": "cc.Color", - "r": 127, - "g": 127, - "b": 127, - "a": 255 - }, - "_N$maxLength": 8, - "_N$stayOnTop": false + "_actualFontSize": 48, + "_fontSize": 48, + "_lineHeight": 67, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "创建房间", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "confirmButton", + "_name": "sprite", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 29 - } - ], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 31 - }, - { - "__id__": 32 - } - ], - "_prefab": null, - "_id": "5aW6uDK25ApZUa3WBWwi0x", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 22, - "g": 155, - "b": 213, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 200, - "height": 60 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": 0, - "y": -280 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Node", - "_name": "Label", - "_objFlags": 0, - "_parent": { - "__id__": 28 - }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 30 + "__id__": 28 } ], "_prefab": null, - "_id": "64VuPGyI1Fh4nrEZyRM7cE", + "_id": "60RK0Gmb5Aw616itrUxuGX", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1272,7 +1080,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, + "width": 30, "height": 40 }, "_rotationX": 0, @@ -1281,8 +1089,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": 0 + "x": 140, + "y": 128.1 }, "_skewX": 0, "_skewY": 0, @@ -1291,41 +1099,19 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 29 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "确定", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 28 + "__id__": 27 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "6207aaeb-a5d8-406f-b278-10f6f52ecd1f" }, - "_type": 1, - "_sizeMode": 0, + "_type": 0, + "_sizeMode": 1, "_fillType": 0, "_fillCenter": { "__type__": "cc.Vec2", @@ -1339,147 +1125,9 @@ "_dstBlendFactor": 771, "_atlas": null }, - { - "__type__": "cc.Button", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 28 - }, - "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" - }, - "_N$target": { - "__id__": 28 - } - }, - { - "__type__": "cc.Node", - "_name": "New Label", - "_objFlags": 0, - "_parent": { - "__id__": 2 - }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 34 - } - ], - "_prefab": null, - "_id": "2cgiqK4LRCgIDJF0UIC0GY", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 103, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": -230, - "y": -200 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 33 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "token:", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, { "__type__": "cc.Node", - "_name": "tokenEditBox", + "_name": "New Layout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -1489,170 +1137,20 @@ "_active": true, "_components": [ { - "__id__": 36 - } - ], - "_prefab": null, - "_id": "44C2k0BvtI6LU3MdnBud5z", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 360, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": 20, - "y": -200 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.EditBox", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 35 - }, - "_enabled": true, - "_useOriginalSize": false, - "_string": "OEWIURIOJNUOGIUDSF809LJOKETGT89H", - "_tabIndex": 0, - "editingDidBegan": [], - "textChanged": [], - "editingDidEnded": [], - "editingReturn": [], - "_N$backgroundImage": { - "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" - }, - "_N$returnType": 0, - "_N$inputFlag": 5, - "_N$inputMode": 6, - "_N$fontSize": 25, - "_N$lineHeight": 40, - "_N$fontColor": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_N$placeholder": "Enter text here...", - "_N$placeholderFontSize": 20, - "_N$placeholderFontColor": { - "__type__": "cc.Color", - "r": 127, - "g": 127, - "b": 127, - "a": 255 - }, - "_N$maxLength": 99, - "_N$stayOnTop": false - }, - { - "__type__": "cc.Node", - "_name": "back", - "_objFlags": 0, - "_parent": { - "__id__": 2 - }, - "_children": [ - { - "__id__": 38 - } - ], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 40 + "__id__": 30 }, { - "__id__": 41 - } - ], - "_prefab": null, - "_id": "7d8HBlFHxKE6DaAvsqtGJ9", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 22, - "g": 155, - "b": 213, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 100, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": -372, - "y": -280 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Node", - "_name": "Label", - "_objFlags": 0, - "_parent": { - "__id__": 37 - }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 39 + "__id__": 31 } ], "_prefab": null, - "_id": "ffaY/os8hEn5gilJanm1Vq", + "_id": "e7TRyo/QRGQrxudK7FDhmP", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 93, + "g": 93, + "b": 93, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1663,8 +1161,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 2, + "height": 380 }, "_rotationX": 0, "_rotationY": 0, @@ -1682,38 +1180,16 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 38 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "返回", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 37 + "__id__": 29 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" }, "_type": 1, "_sizeMode": 0, @@ -1731,142 +1207,71 @@ "_atlas": null }, { - "__type__": "cc.Button", + "__type__": "cc.Layout", "_name": "", "_objFlags": 0, "node": { - "__id__": 37 + "__id__": 29 }, "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_layoutSize": { + "__type__": "cc.Size", + "width": 2, + "height": 380 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 }, - "_N$target": { - "__id__": 37 - } + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0 }, { - "__type__": "cc.Node", - "_name": "info", + "__type__": "8081eh5Q3RECZVLEwf0+6/C", + "_name": "", "_objFlags": 0, - "_parent": { + "node": { "__id__": 2 }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 43 - } - ], - "_prefab": null, - "_id": "c6DtFPIkRIxYUvkdsr9QwF", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 228, - "g": 58, - "b": 92, - "a": 255 + "_enabled": true, + "randomMatch": { + "__id__": 15 }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 + "selfDefMatch": { + "__id__": 17 }, - "_contentSize": { - "__type__": "cc.Size", - "width": 188, - "height": 20 + "roomList": { + "__id__": 23 }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": 343, - "y": -60 + "joinCertainRoom": { + "__id__": 21 }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 7, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 42 + "createRoom": { + "__id__": 25 }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "[LOG]:Cocos Creator", - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "returnLogin": { + "__id__": 13 + }, + "buttonSyncFrame": { + "__id__": 19 + }, + "nickName": { + "__id__": 8 + }, + "avatar111": { + "__id__": 10 + } }, { "__type__": "cc.Canvas", @@ -1878,46 +1283,10 @@ "_enabled": true, "_designResolution": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, - "_fitWidth": false, - "_fitHeight": true - }, - { - "__type__": "c7727hRiV1NO7e8qD73ATQ0", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 2 - }, - "_enabled": true, - "endPointEditBox": { - "__id__": 19 - }, - "gameIDEditBox": { - "__id__": 21 - }, - "keyEditBox": { - "__id__": 23 - }, - "secretEditBox": { - "__id__": 25 - }, - "userIDEditBox": { - "__id__": 27 - }, - "confirmButton": { - "__id__": 28 - }, - "backButton": { - "__id__": 37 - }, - "tokenEditBox": { - "__id__": 36 - }, - "labelInfo": { - "__id__": 43 - } + "_fitWidth": true, + "_fitHeight": false } ] \ No newline at end of file diff --git a/assets/createRoom.fire.meta b/assets/scene/Lobby.fire.meta similarity index 65% rename from assets/createRoom.fire.meta rename to assets/scene/Lobby.fire.meta index 5484dc9..dd98ad9 100644 --- a/assets/createRoom.fire.meta +++ b/assets/scene/Lobby.fire.meta @@ -1,6 +1,6 @@ { "ver": "1.0.0", - "uuid": "b355cdca-7c4a-4ed0-be81-d9b1e71cb0cc", + "uuid": "37270621-16d2-4a76-bb39-08a27417a926", "asyncLoadAssets": false, "autoReleaseAssets": false, "subMetas": {} diff --git a/assets/login.fire b/assets/scene/Login.fire similarity index 79% rename from assets/login.fire rename to assets/scene/Login.fire index 31e5ca4..dcbee45 100644 --- a/assets/login.fire +++ b/assets/scene/Login.fire @@ -21,7 +21,7 @@ "_active": true, "_components": [], "_prefab": null, - "_id": "458cbdf5-efc9-4be6-87d3-040eaae36764", + "_id": "5333efe9-5cb8-4d80-ac32-fd3c440e6857", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -59,53 +59,53 @@ "__id__": 3 }, { - "__id__": 8 + "__id__": 5 }, { - "__id__": 10 + "__id__": 7 }, { - "__id__": 15 + "__id__": 9 }, { - "__id__": 17 + "__id__": 11 }, { - "__id__": 19 + "__id__": 16 }, { - "__id__": 21 + "__id__": 18 }, { - "__id__": 29 + "__id__": 20 }, { - "__id__": 31 + "__id__": 22 }, { - "__id__": 39 + "__id__": 30 }, { - "__id__": 41 + "__id__": 32 }, { - "__id__": 49 + "__id__": 40 }, { - "__id__": 51 + "__id__": 42 }, { - "__id__": 57 + "__id__": 50 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 62 + "__id__": 55 }, { - "__id__": 63 + "__id__": 56 } ], "_prefab": null, @@ -126,8 +126,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -135,8 +135,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 480, - "y": 320 + "x": 640, + "y": 360 }, "_skewX": 0, "_skewY": 0, @@ -147,28 +147,21 @@ }, { "__type__": "cc.Node", - "_name": "independent", + "_name": "New Node", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 4 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 6 - }, - { - "__id__": 7 + "__id__": 4 } ], "_prefab": null, - "_id": "9c6rIHAhFPLp5CxzcfYoxA", + "_id": "67tZZAQbZIYYdDpc+5yYIw", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -185,8 +178,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -194,39 +187,65 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 384, - "y": -276 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 4, + "_localZOrder": 0, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Sprite", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 3 + }, + "_enabled": true, + "_spriteFrame": { + "__uuid__": "0cbd03ff-a827-4248-a85b-6bfd7ebfcabd" + }, + "_type": 2, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null + }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "New Label", "_objFlags": 0, "_parent": { - "__id__": 3 + "__id__": 2 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 5 + "__id__": 6 } ], "_prefab": null, - "_id": "c6eCzrlVFFn7Wzah9Snouo", + "_id": "d7diWQUhNBh7dcJ8AIdIuW", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -237,7 +256,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, + "width": 763, "height": 40 }, "_rotationX": 0, @@ -247,11 +266,11 @@ "_position": { "__type__": "cc.Vec2", "x": 0, - "y": 0 + "y": -250 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 5, + "_localZOrder": 0, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -261,116 +280,100 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 4 + "__id__": 5 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, + "_actualFontSize": 20, "_fontSize": 20, "_lineHeight": 40, - "_enableWrapText": false, + "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "设置", + "_N$string": "提示:此Demo需要分别在三个不同的浏览器(如Chrome、火狐、360)里打开进行体验", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { - "__type__": "cc.Sprite", - "_name": "", + "__type__": "cc.Node", + "_name": "New Label", "_objFlags": 0, - "node": { - "__id__": 3 + "_parent": { + "__id__": 2 }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 8 + } + ], + "_prefab": null, + "_id": "5eprLzHtJI8aCnrkgIoQ2n", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 153, + "g": 153, + "b": 153, + "a": 255 }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 498, + "height": 40 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { "__type__": "cc.Vec2", "x": 0, - "y": 0 + "y": -300 }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 0, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 }, { - "__type__": "cc.Button", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 3 + "__id__": 7 }, "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" - }, - "_N$target": { - "__id__": 3 - } + "_useOriginalSize": false, + "_actualFontSize": 20, + "_fontSize": 20, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "如需在一个浏览器里完成体验,则每次需要先“清除缓存”", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "Main Camera", + "_name": "independent", "_objFlags": 0, "_parent": { "__id__": 2 @@ -380,17 +383,17 @@ "_active": true, "_components": [ { - "__id__": 9 + "__id__": 10 } ], "_prefab": null, - "_id": "0fXLlMeadEnp1H1IA7ObSc", + "_id": "b06/188hBIQ65zhRK7W+t0", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -401,8 +404,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 0 + "width": 167, + "height": 40 }, "_rotationX": 0, "_rotationY": 0, @@ -410,26 +413,37 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": 0 + "x": 522, + "y": -310 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 6, + "_localZOrder": 0, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { - "__type__": "cc.Camera", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 8 + "__id__": 9 }, "_enabled": true, - "_targets": [], - "zoomRatio": 1 + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "独立部署 Demo", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "Arial", + "_N$overflow": 0 }, { "__type__": "cc.Node", @@ -440,17 +454,17 @@ }, "_children": [ { - "__id__": 11 + "__id__": 12 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 13 + "__id__": 14 }, { - "__id__": 14 + "__id__": 15 } ], "_prefab": null, @@ -471,8 +485,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 200, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -480,8 +494,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 333, - "y": -88 + "x": 170, + "y": -96 }, "_skewX": 0, "_skewY": 0, @@ -495,14 +509,14 @@ "_name": "Label", "_objFlags": 0, "_parent": { - "__id__": 10 + "__id__": 11 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 12 + "__id__": 13 } ], "_prefab": null, @@ -511,8 +525,8 @@ "_color": { "__type__": "cc.Color", "r": 0, - "g": 0, - "b": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -523,8 +537,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 200, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -547,21 +561,21 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 11 + "__id__": 12 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 20, - "_lineHeight": 40, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, "_enableWrapText": false, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "clear", + "_N$string": "清除缓存", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 1 }, { @@ -569,11 +583,11 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 10 + "__id__": 11 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "e5ea3f2b-5210-48ab-8ada-df4dbdd11846" }, "_type": 1, "_sizeMode": 0, @@ -595,7 +609,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 10 + "__id__": 11 }, "_enabled": true, "transition": 2, @@ -633,7 +647,7 @@ "a": 255 }, "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "e5ea3f2b-5210-48ab-8ada-df4dbdd11846" }, "_N$pressedSprite": { "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" @@ -651,7 +665,7 @@ "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" }, "_N$target": { - "__id__": 10 + "__id__": 11 } }, { @@ -666,7 +680,7 @@ "_active": true, "_components": [ { - "__id__": 16 + "__id__": 17 } ], "_prefab": null, @@ -696,8 +710,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 16, - "y": 292 + "x": 456, + "y": 309 }, "_skewX": 0, "_skewY": 0, @@ -711,11 +725,11 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 15 + "__id__": 16 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, + "_actualFontSize": 20, "_fontSize": 20, "_lineHeight": 20, "_enableWrapText": true, @@ -740,7 +754,7 @@ "_active": true, "_components": [ { - "__id__": 18 + "__id__": 19 } ], "_prefab": null, @@ -761,7 +775,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 407, + "width": 374, "height": 40 }, "_rotationX": 0, @@ -771,7 +785,7 @@ "_position": { "__type__": "cc.Vec2", "x": 0, - "y": 180 + "y": 309 }, "_skewX": 0, "_skewY": 0, @@ -785,7 +799,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 17 + "__id__": 18 }, "_enabled": true, "_useOriginalSize": false, @@ -799,7 +813,7 @@ "_N$string": "MatchVS Demo-Cocos", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { @@ -814,7 +828,7 @@ "_active": true, "_components": [ { - "__id__": 20 + "__id__": 21 } ], "_prefab": null, @@ -835,8 +849,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 107, - "height": 30 + "width": 77, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -844,8 +858,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -250, - "y": 80 + "x": -350, + "y": 230 }, "_skewX": 0, "_skewY": 0, @@ -859,21 +873,21 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 19 + "__id__": 20 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 30, - "_lineHeight": 30, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "GameId", + "_N$string": "gameID", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { @@ -885,20 +899,20 @@ }, "_children": [ { - "__id__": 22 + "__id__": 23 }, { - "__id__": 24 + "__id__": 25 }, { - "__id__": 26 + "__id__": 27 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 28 + "__id__": 29 } ], "_prefab": null, @@ -919,8 +933,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 550, - "height": 40 + "width": 540, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -928,8 +942,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 120, - "y": 80 + "x": 0, + "y": 230 }, "_skewX": 0, "_skewY": 0, @@ -943,14 +957,14 @@ "_name": "BACKGROUND_SPRITE", "_objFlags": 0, "_parent": { - "__id__": 21 + "__id__": 22 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 23 + "__id__": 24 } ], "_prefab": null, @@ -971,8 +985,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 550, - "height": 40 + "width": 540, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -995,7 +1009,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 22 + "__id__": 23 }, "_enabled": true, "_spriteFrame": { @@ -1021,14 +1035,14 @@ "_name": "TEXT_LABEL", "_objFlags": 0, "_parent": { - "__id__": 21 + "__id__": 22 }, "_children": [], "_tag": -1, "_active": false, "_components": [ { - "__id__": 25 + "__id__": 26 } ], "_prefab": null, @@ -1073,7 +1087,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 24 + "__id__": 25 }, "_enabled": true, "_useOriginalSize": true, @@ -1095,14 +1109,14 @@ "_name": "PLACEHOLDER_LABEL", "_objFlags": 0, "_parent": { - "__id__": 21 + "__id__": 22 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 27 + "__id__": 28 } ], "_prefab": null, @@ -1118,13 +1132,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0, - "y": 1 + "x": 0.5, + "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 548, - "height": 40 + "width": 540, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -1132,8 +1146,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -273, - "y": 20 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -1147,11 +1161,11 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 26 + "__id__": 27 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, + "_actualFontSize": 20, "_fontSize": 20, "_lineHeight": 40, "_enableWrapText": false, @@ -1169,7 +1183,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 21 + "__id__": 22 }, "_enabled": true, "_useOriginalSize": false, @@ -1218,7 +1232,7 @@ "_active": true, "_components": [ { - "__id__": 30 + "__id__": 31 } ], "_prefab": null, @@ -1239,8 +1253,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 105, - "height": 30 + "width": 81, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -1248,8 +1262,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -250, - "y": 30 + "x": -350, + "y": 126 }, "_skewX": 0, "_skewY": 0, @@ -1263,21 +1277,21 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 29 + "__id__": 30 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 30, - "_lineHeight": 30, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, "_N$string": "AppKey", - "_N$horizontalAlign": 1, + "_N$horizontalAlign": 0, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { @@ -1288,429 +1302,25 @@ "__id__": 2 }, "_children": [ - { - "__id__": 32 - }, - { - "__id__": 34 - }, - { - "__id__": 36 - } - ], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 38 - } - ], - "_prefab": null, - "_id": "24/SR9W6RIRoz37HY62IrB", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 550, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": 120, - "y": 30 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 17, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Node", - "_name": "BACKGROUND_SPRITE", - "_objFlags": 0, - "_parent": { - "__id__": 31 - }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ { "__id__": 33 - } - ], - "_prefab": null, - "_id": "d9irbwOwxHXbMW3QQka31H", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 550, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 18, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Sprite", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 32 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" - }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null - }, - { - "__type__": "cc.Node", - "_name": "TEXT_LABEL", - "_objFlags": 0, - "_parent": { - "__id__": 31 - }, - "_children": [], - "_tag": -1, - "_active": false, - "_components": [ - { - "__id__": 35 - } - ], - "_prefab": null, - "_id": "b6STI0krlBf6jslUR9ke0j", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0, - "y": 1 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 548, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": -273, - "y": 20 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 19, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 34 - }, - "_enabled": true, - "_useOriginalSize": true, - "_actualFontSize": 40, - "_fontSize": 29, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, - { - "__type__": "cc.Node", - "_name": "PLACEHOLDER_LABEL", - "_objFlags": 0, - "_parent": { - "__id__": 31 - }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 37 - } - ], - "_prefab": null, - "_id": "49uHCJT9tN9LYSh+YHk0XG", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 127, - "g": 127, - "b": 127, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0, - "y": 1 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 548, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": -273, - "y": 20 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 20, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 36 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "*********************************", - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, - { - "__type__": "cc.EditBox", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 31 - }, - "_enabled": true, - "_useOriginalSize": false, - "_string": "", - "_tabIndex": 0, - "editingDidBegan": [], - "textChanged": [], - "editingDidEnded": [], - "editingReturn": [], - "_N$backgroundImage": { - "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" - }, - "_N$returnType": 0, - "_N$inputFlag": 5, - "_N$inputMode": 6, - "_N$fontSize": 29, - "_N$lineHeight": 40, - "_N$fontColor": { - "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, - "a": 255 - }, - "_N$placeholder": "*********************************", - "_N$placeholderFontSize": 20, - "_N$placeholderFontColor": { - "__type__": "cc.Color", - "r": 127, - "g": 127, - "b": 127, - "a": 255 - }, - "_N$maxLength": 80, - "_N$stayOnTop": false - }, - { - "__type__": "cc.Node", - "_name": "secretLabel", - "_objFlags": 0, - "_parent": { - "__id__": 2 - }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 40 - } - ], - "_prefab": null, - "_id": "d4q+Ql17ZP6IlXvTpySuUS", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 87, - "height": 30 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": -250, - "y": -20 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 21, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 39 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 30, - "_lineHeight": 30, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "Secret", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, - { - "__type__": "cc.Node", - "_name": "secretInput", - "_objFlags": 0, - "_parent": { - "__id__": 2 - }, - "_children": [ - { - "__id__": 42 }, { - "__id__": 44 + "__id__": 35 }, { - "__id__": 46 + "__id__": 37 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 48 + "__id__": 39 } ], "_prefab": null, - "_id": "862xUGMoxNTbOkWl0Hf1Kc", + "_id": "24/SR9W6RIRoz37HY62IrB", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1727,8 +1337,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 550, - "height": 40 + "width": 540, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -1736,12 +1346,12 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 120, - "y": -20 + "x": 0, + "y": 126 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 22, + "_localZOrder": 17, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -1751,18 +1361,18 @@ "_name": "BACKGROUND_SPRITE", "_objFlags": 0, "_parent": { - "__id__": 41 + "__id__": 32 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 43 + "__id__": 34 } ], "_prefab": null, - "_id": "d3uAynInpCbqNJqstTLbOv", + "_id": "d9irbwOwxHXbMW3QQka31H", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1779,8 +1389,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 550, - "height": 40 + "width": 540, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -1793,7 +1403,7 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 23, + "_localZOrder": 18, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -1803,7 +1413,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 42 + "__id__": 33 }, "_enabled": true, "_spriteFrame": { @@ -1829,18 +1439,18 @@ "_name": "TEXT_LABEL", "_objFlags": 0, "_parent": { - "__id__": 41 + "__id__": 32 }, "_children": [], "_tag": -1, "_active": false, "_components": [ { - "__id__": 45 + "__id__": 36 } ], "_prefab": null, - "_id": "27XawNqH5OUb/WBhu15KMZ", + "_id": "b6STI0krlBf6jslUR9ke0j", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1871,7 +1481,7 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 24, + "_localZOrder": 19, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -1881,7 +1491,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 44 + "__id__": 35 }, "_enabled": true, "_useOriginalSize": true, @@ -1903,18 +1513,18 @@ "_name": "PLACEHOLDER_LABEL", "_objFlags": 0, "_parent": { - "__id__": 41 + "__id__": 32 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 47 + "__id__": 38 } ], "_prefab": null, - "_id": "e8at+66J1HfJmCZuSbooFh", + "_id": "49uHCJT9tN9LYSh+YHk0XG", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1926,13 +1536,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0, - "y": 1 + "x": 0.5, + "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 548, - "height": 40 + "width": 540, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -1940,12 +1550,12 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -273, - "y": 20 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 25, + "_localZOrder": 20, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -1955,11 +1565,11 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 46 + "__id__": 37 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, + "_actualFontSize": 20, "_fontSize": 20, "_lineHeight": 40, "_enableWrapText": false, @@ -1977,7 +1587,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 41 + "__id__": 32 }, "_enabled": true, "_useOriginalSize": false, @@ -2016,7 +1626,7 @@ }, { "__type__": "cc.Node", - "_name": "alphaLabel", + "_name": "secretLabel", "_objFlags": 0, "_parent": { "__id__": 2 @@ -2026,11 +1636,11 @@ "_active": true, "_components": [ { - "__id__": 50 + "__id__": 41 } ], "_prefab": null, - "_id": "5aroxVX4dAgaL0DRt5w2j5", + "_id": "d4q+Ql17ZP6IlXvTpySuUS", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -2047,8 +1657,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 120, - "height": 30 + "width": 60, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -2056,12 +1666,12 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 120, - "y": -90 + "x": -350, + "y": 16 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 26, + "_localZOrder": 21, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -2071,47 +1681,50 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 49 + "__id__": 40 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 30, - "_lineHeight": 30, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "开启调试", - "_N$horizontalAlign": 1, + "_N$string": "Secret", + "_N$horizontalAlign": 0, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "alphaRadio", + "_name": "secretInput", "_objFlags": 0, "_parent": { "__id__": 2 }, "_children": [ { - "__id__": 52 + "__id__": 43 }, { - "__id__": 54 + "__id__": 45 + }, + { + "__id__": 47 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 56 + "__id__": 49 } ], "_prefab": null, - "_id": "7fFUQftOpD37dJbIwoF/cb", + "_id": "862xUGMoxNTbOkWl0Hf1Kc", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -2128,8 +1741,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 28, - "height": 28 + "width": 540, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -2137,33 +1750,33 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 220, - "y": -90 + "x": 0, + "y": 16 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 27, + "_localZOrder": 22, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { "__type__": "cc.Node", - "_name": "Background", + "_name": "BACKGROUND_SPRITE", "_objFlags": 0, "_parent": { - "__id__": 51 + "__id__": 42 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 53 + "__id__": 44 } ], "_prefab": null, - "_id": "7e9TkHQ85M5rlrcG8czm5Y", + "_id": "d3uAynInpCbqNJqstTLbOv", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -2180,8 +1793,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 28, - "height": 28 + "width": 540, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -2194,7 +1807,7 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 28, + "_localZOrder": 23, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -2204,14 +1817,14 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 52 + "__id__": 43 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "6827ca32-0107-4552-bab2-dfb31799bb44" + "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" }, - "_type": 0, - "_sizeMode": 1, + "_type": 1, + "_sizeMode": 0, "_fillType": 0, "_fillCenter": { "__type__": "cc.Vec2", @@ -2227,39 +1840,39 @@ }, { "__type__": "cc.Node", - "_name": "checkmark", + "_name": "TEXT_LABEL", "_objFlags": 0, "_parent": { - "__id__": 51 + "__id__": 42 }, "_children": [], "_tag": -1, "_active": false, "_components": [ { - "__id__": 55 + "__id__": 46 } ], "_prefab": null, - "_id": "edo1v8fL1Hp7XnW7WBNqmW", + "_id": "27XawNqH5OUb/WBhu15KMZ", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 0, + "b": 0, "a": 255 }, "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 + "x": 0, + "y": 1 }, "_contentSize": { "__type__": "cc.Size", - "width": 28, - "height": 28 + "width": 548, + "height": 40 }, "_rotationX": 0, "_rotationY": 0, @@ -2267,99 +1880,153 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": 0 + "x": -273, + "y": 20 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 29, + "_localZOrder": 24, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { - "__type__": "cc.Sprite", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 54 + "__id__": 45 }, "_enabled": true, - "_spriteFrame": { - "__uuid__": "90004ad6-2f6d-40e1-93ef-b714375c6f06" + "_useOriginalSize": true, + "_actualFontSize": 40, + "_fontSize": 29, + "_lineHeight": 40, + "_enableWrapText": false, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "Arial", + "_N$overflow": 1 + }, + { + "__type__": "cc.Node", + "_name": "PLACEHOLDER_LABEL", + "_objFlags": 0, + "_parent": { + "__id__": 42 }, - "_type": 0, - "_sizeMode": 2, - "_fillType": 0, - "_fillCenter": { + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 48 + } + ], + "_prefab": null, + "_id": "e8at+66J1HfJmCZuSbooFh", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 127, + "g": 127, + "b": 127, + "a": 255 + }, + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 540, + "height": 70 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { "__type__": "cc.Vec2", "x": 0, "y": 0 }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": false, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 25, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 }, { - "__type__": "cc.Toggle", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 51 + "__id__": 47 }, "_enabled": true, - "transition": 3, - "pressedColor": { - "__type__": "cc.Color", - "r": 211, - "g": 211, - "b": 211, - "a": 255 + "_useOriginalSize": false, + "_actualFontSize": 20, + "_fontSize": 20, + "_lineHeight": 40, + "_enableWrapText": false, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "*********************************", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "Arial", + "_N$overflow": 1 + }, + { + "__type__": "cc.EditBox", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 42 }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "_enabled": true, + "_useOriginalSize": false, + "_string": "", + "_tabIndex": 0, + "editingDidBegan": [], + "textChanged": [], + "editingDidEnded": [], + "editingReturn": [], + "_N$backgroundImage": { + "__uuid__": "67e68bc9-dad5-4ad9-a2d8-7e03d458e32f" }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { + "_N$returnType": 0, + "_N$inputFlag": 5, + "_N$inputMode": 6, + "_N$fontSize": 29, + "_N$lineHeight": 40, + "_N$fontColor": { "__type__": "cc.Color", - "r": 214, - "g": 214, - "b": 214, + "r": 0, + "g": 0, + "b": 0, "a": 255 }, - "_N$disabledColor": { + "_N$placeholder": "*********************************", + "_N$placeholderFontSize": 20, + "_N$placeholderFontColor": { "__type__": "cc.Color", - "r": 124, - "g": 124, - "b": 124, + "r": 127, + "g": 127, + "b": 127, "a": 255 }, - "_N$normalSprite": null, - "_N$pressedSprite": null, - "pressedSprite": null, - "_N$hoverSprite": null, - "hoverSprite": null, - "_N$disabledSprite": null, - "_N$target": { - "__id__": 52 - }, - "toggleGroup": null, - "checkMark": { - "__id__": 55 - }, - "checkEvents": [], - "_N$isChecked": false + "_N$maxLength": 80, + "_N$stayOnTop": false }, { "__type__": "cc.Node", @@ -2370,17 +2037,17 @@ }, "_children": [ { - "__id__": 58 + "__id__": 51 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 60 + "__id__": 53 }, { - "__id__": 61 + "__id__": 54 } ], "_prefab": null, @@ -2388,9 +2055,9 @@ "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -2401,8 +2068,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 120, - "height": 50 + "width": 315, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -2410,8 +2077,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": -170 + "x": -114, + "y": -96 }, "_skewX": 0, "_skewY": 0, @@ -2425,14 +2092,14 @@ "_name": "Label", "_objFlags": 0, "_parent": { - "__id__": 57 + "__id__": 50 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 59 + "__id__": 52 } ], "_prefab": null, @@ -2440,9 +2107,9 @@ "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -2453,8 +2120,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 315, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -2477,18 +2144,18 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 58 + "__id__": 51 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 30, - "_lineHeight": 50, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, "_enableWrapText": false, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "确定", + "_N$string": "进入DEMO", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, "_N$fontFamily": "Arial", @@ -2499,7 +2166,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 57 + "__id__": 50 }, "_enabled": true, "_spriteFrame": { @@ -2525,7 +2192,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 57 + "__id__": 50 }, "_enabled": true, "transition": 2, @@ -2581,7 +2248,7 @@ "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" }, "_N$target": { - "__id__": 57 + "__id__": 50 } }, { @@ -2594,11 +2261,11 @@ "_enabled": true, "_designResolution": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, - "_fitWidth": false, - "_fitHeight": true + "_fitWidth": true, + "_fitHeight": false }, { "__type__": "ba449oU8rFArqKhgBI6yqK1", @@ -2609,28 +2276,25 @@ }, "_enabled": true, "gameIdInput": { - "__id__": 21 + "__id__": 22 }, "appKeyInput": { - "__id__": 31 + "__id__": 32 }, "secret": { - "__id__": 41 - }, - "alphaRadio": { - "__id__": 51 + "__id__": 42 }, "confirm": { - "__id__": 57 + "__id__": 50 }, "clear": { - "__id__": 10 + "__id__": 11 }, "independent": { - "__id__": 3 + "__id__": 9 }, "labelInfo": { - "__id__": 16 + "__id__": 17 } } ] \ No newline at end of file diff --git a/assets/lobby.fire.meta b/assets/scene/Login.fire.meta similarity index 65% rename from assets/lobby.fire.meta rename to assets/scene/Login.fire.meta index 98913ec..ce0327c 100644 --- a/assets/lobby.fire.meta +++ b/assets/scene/Login.fire.meta @@ -1,6 +1,6 @@ { "ver": "1.0.0", - "uuid": "63b83656-9405-499a-b758-3c977e929c6d", + "uuid": "5333efe9-5cb8-4d80-ac32-fd3c440e6857", "asyncLoadAssets": false, "autoReleaseAssets": false, "subMetas": {} diff --git a/assets/createRoom.fire b/assets/scene/Match.fire similarity index 70% rename from assets/createRoom.fire rename to assets/scene/Match.fire index 51adfb7..98eda38 100644 --- a/assets/createRoom.fire +++ b/assets/scene/Match.fire @@ -21,7 +21,7 @@ "_active": true, "_components": [], "_prefab": null, - "_id": "b355cdca-7c4a-4ed0-be81-d9b1e71cb0cc", + "_id": "0e557bb3-8ed9-4799-a71b-9beeb7ac8838", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -77,42 +77,42 @@ "__id__": 15 }, { - "__id__": 17 + "__id__": 22 }, { - "__id__": 19 + "__id__": 24 }, { - "__id__": 21 + "__id__": 31 }, { - "__id__": 25 + "__id__": 33 }, { - "__id__": 30 + "__id__": 40 }, { - "__id__": 35 + "__id__": 42 }, { - "__id__": 40 + "__id__": 44 }, { - "__id__": 45 + "__id__": 46 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 50 + "__id__": 52 }, { - "__id__": 51 + "__id__": 53 } ], "_prefab": null, - "_id": "a44tEyV+hAsqOX60Xpg3sN", + "_id": "69G+pJV+lGE7Zrq9E20nNF", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -129,8 +129,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -138,19 +138,19 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 480, - "y": 320 + "x": 640, + "y": 360 }, "_skewX": 0, "_skewY": 0, "_localZOrder": 0, "_globalZOrder": 0, "_opacityModifyRGB": false, - "groupIndex": 0 + "groupIndex": 1 }, { "__type__": "cc.Node", - "_name": "label", + "_name": "backgrout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -164,7 +164,7 @@ } ], "_prefab": null, - "_id": "33uS0etlZOur7lfP2uWqpN", + "_id": "8bMmtO/YpNGIQqTbLBNd/j", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -181,8 +181,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 131, - "height": 40 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -190,8 +190,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -280, - "y": 120 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -201,30 +201,34 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { "__id__": 3 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "用户ID:", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "0cbd03ff-a827-4248-a85b-6bfd7ebfcabd" + }, + "_type": 2, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "label", + "_name": "back", "_objFlags": 0, "_parent": { "__id__": 2 @@ -238,7 +242,7 @@ } ], "_prefab": null, - "_id": "58EJ8MWTpPIr84YqqFuXbw", + "_id": "5cqsO9pvZPVrqx8MXOcQWD", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -255,8 +259,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 131, - "height": 40 + "width": 20, + "height": 36 }, "_rotationX": 0, "_rotationY": 0, @@ -264,8 +268,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -280, - "y": 30 + "x": -550, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -275,30 +279,34 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { "__id__": 5 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "用户ID:", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "3f66add4-81b7-41d8-995e-1553cd3ef92e" + }, + "_type": 0, + "_sizeMode": 1, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "label", + "_name": "New Label", "_objFlags": 0, "_parent": { "__id__": 2 @@ -312,7 +320,7 @@ } ], "_prefab": null, - "_id": "3dZOjDlodCXJI4waG/syXo", + "_id": "3bGaUGX+1Bx7y9mcnbL6PZ", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -324,12 +332,12 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 131, + "width": 216, "height": 40 }, "_rotationX": 0, @@ -338,8 +346,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -280, - "y": -60 + "x": -505, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -357,22 +365,22 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, + "_actualFontSize": 36, + "_fontSize": 36, "_lineHeight": 40, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "用户ID:", + "_N$string": "等待玩家加入", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "label", + "_name": "Matching Way", "_objFlags": 0, "_parent": { "__id__": 2 @@ -386,7 +394,7 @@ } ], "_prefab": null, - "_id": "cfpFvjgnxKv7y9I1hUuPD+", + "_id": "35SexLlfdL45Ou/Yr7jtTR", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -398,13 +406,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 158, - "height": 30 + "width": 112, + "height": 40 }, "_rotationX": 0, "_rotationY": 0, @@ -412,8 +420,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -380, - "y": 300 + "x": -260, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -431,22 +439,22 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 30, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 40, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "我的房间ID:", - "_N$horizontalAlign": 1, + "_N$string": "(随机匹配)", + "_N$horizontalAlign": 0, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "labelInfo", + "_name": "nickName", "_objFlags": 0, "_parent": { "__id__": 2 @@ -460,13 +468,13 @@ } ], "_prefab": null, - "_id": "43SKLIX79Fr4+rAtsyiZlt", + "_id": "39RUlKe5NI0bMP60DbFN5D", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 228, - "g": 58, - "b": 92, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -478,7 +486,7 @@ "_contentSize": { "__type__": "cc.Size", "width": 0, - "height": 15 + "height": 20 }, "_rotationX": 0, "_rotationY": 0, @@ -486,8 +494,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -79, - "y": 231 + "x": 440, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -505,22 +513,22 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 15, - "_fontSize": 15, - "_lineHeight": 15, + "_actualFontSize": 20, + "_fontSize": 20, + "_lineHeight": 20, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, "_N$string": "", - "_N$horizontalAlign": 0, + "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "labelMyRoomID", + "_name": "Room Number", "_objFlags": 0, "_parent": { "__id__": 2 @@ -534,7 +542,7 @@ } ], "_prefab": null, - "_id": "74jVMZseJLNqhnmSJOhVRi", + "_id": "1cxUOdyJFPXIIkW2ekJGE/", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -546,13 +554,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 30 + "width": 96, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -560,8 +568,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -90, - "y": 297 + "x": -505, + "y": 211 }, "_skewX": 0, "_skewY": 0, @@ -579,14 +587,14 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 30, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "", + "_N$string": "房间号:", "_N$horizontalAlign": 0, "_N$verticalAlign": 1, "_N$fontFamily": "Arial", @@ -594,27 +602,34 @@ }, { "__type__": "cc.Node", - "_name": "labelUserID1", + "_name": "Player One", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [], + "_children": [ + { + "__id__": 16 + }, + { + "__id__": 19 + } + ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 16 + "__id__": 21 } ], "_prefab": null, - "_id": "45bOn0lf9Bd5KLegqMudP/", + "_id": "8dbwyKcelC/aF3mBtDgwv3", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 7, - "g": 248, - "b": 46, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -625,8 +640,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 30 + "width": 200, + "height": 200 }, "_rotationX": 0, "_rotationY": 0, @@ -634,8 +649,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -80, - "y": 120 + "x": -300, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -644,51 +659,32 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 15 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 30, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, { "__type__": "cc.Node", - "_name": "labelUserID2", + "_name": "New Layout", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 15 }, "_children": [], "_tag": -1, "_active": true, "_components": [ + { + "__id__": 17 + }, { "__id__": 18 } ], "_prefab": null, - "_id": "039d1XTU1DurU31MNSCNTW", + "_id": "791a5cZMVC7pWnhPsyFty1", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 7, - "g": 248, - "b": 46, + "r": 139, + "g": 215, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -699,8 +695,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 30 + "width": 200, + "height": 200 }, "_rotationX": 0, "_rotationY": 0, @@ -708,8 +704,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -80, - "y": 30 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -719,33 +715,68 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 17 + "__id__": 16 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 30, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" + }, + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null + }, + { + "__type__": "cc.Layout", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 16 + }, + "_enabled": true, + "_layoutSize": { + "__type__": "cc.Size", + "width": 200, + "height": 200 + }, + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 + }, + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0 }, { "__type__": "cc.Node", - "_name": "labelUserID3", + "_name": "New Label", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 15 }, "_children": [], "_tag": -1, @@ -756,13 +787,13 @@ } ], "_prefab": null, - "_id": "a4VduVVuhKI4d0QlTNxB7d", + "_id": "59aZwyj5pIJaVF8pUrn78L", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 7, - "g": 248, - "b": 46, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -773,8 +804,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 30 + "width": 80, + "height": 112 }, "_rotationX": 0, "_rotationY": 0, @@ -782,8 +813,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -80, - "y": -60 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -801,40 +832,50 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 30, + "_actualFontSize": 80, + "_fontSize": 80, + "_lineHeight": 112, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 0, + "_N$string": "我", + "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, + { + "__type__": "cc.Mask", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 15 + }, + "_enabled": true, + "_type": 1, + "_segements": 10000, + "_N$spriteFrame": null, + "_N$alphaThreshold": 1, + "_N$inverted": false + }, { "__type__": "cc.Node", - "_name": "mapType", + "_name": "Player Name One", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 22 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 24 + "__id__": 23 } ], "_prefab": null, - "_id": "30c7OF26xP/6lgp8Niz0Lc", + "_id": "83ansYOd9ALaiiIVIsQ+PL", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -852,7 +893,7 @@ "_contentSize": { "__type__": "cc.Size", "width": 0, - "height": 20 + "height": 40 }, "_rotationX": 0, "_rotationY": 0, @@ -860,8 +901,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 260, - "y": 294 + "x": -300, + "y": -150 }, "_skewX": 0, "_skewY": 0, @@ -870,23 +911,52 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 22 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 28, + "_fontSize": 28, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, { "__type__": "cc.Node", - "_name": "New Label", + "_name": "Player Two", "_objFlags": 0, "_parent": { - "__id__": 21 + "__id__": 2 }, - "_children": [], + "_children": [ + { + "__id__": 25 + }, + { + "__id__": 28 + } + ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 23 + "__id__": 30 } ], "_prefab": null, - "_id": "05l1hYVhNAmrzC/VYLNvvN", + "_id": "9fCtyk1OlFK6CW+iBfNaGq", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -903,8 +973,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 20 + "width": 200, + "height": 200 }, "_rotationX": 0, "_rotationY": 0, @@ -912,8 +982,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -98, - "y": -3 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -922,80 +992,32 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 22 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "场次类型:", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 21 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, { "__type__": "cc.Node", - "_name": "seleButton", + "_name": "New Layout", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 24 }, - "_children": [ - { - "__id__": 26 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 28 + "__id__": 26 }, { - "__id__": 29 + "__id__": 27 } ], "_prefab": null, - "_id": "612TX/cjxPGYM3EMzxRJyk", + "_id": "17Rb6sDaNEWJ1iag7CuwQ/", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 85, + "g": 85, + "b": 85, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1006,8 +1028,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 150, - "height": 40 + "width": 200, + "height": 200 }, "_rotationX": 0, "_rotationY": 0, @@ -1015,8 +1037,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 390, - "y": 290 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -1025,29 +1047,86 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Sprite", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 25 + }, + "_enabled": true, + "_spriteFrame": { + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" + }, + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null + }, + { + "__type__": "cc.Layout", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 25 + }, + "_enabled": true, + "_layoutSize": { + "__type__": "cc.Size", + "width": 200, + "height": 200 + }, + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 + }, + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0 + }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "Player Two Label", "_objFlags": 0, "_parent": { - "__id__": 25 + "__id__": 24 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 27 + "__id__": 29 } ], "_prefab": null, - "_id": "4dNNqrlbxN7ozoZhv8bt/Y", + "_id": "f4ef4QmuRJKZwKhot3Slye", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 117, + "g": 117, + "b": 117, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1058,8 +1137,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 150, - "height": 40 + "width": 40, + "height": 112 }, "_rotationX": 0, "_rotationY": 0, @@ -1067,8 +1146,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -2.1, - "y": 0.5 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -1082,137 +1161,135 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 26 + "__id__": 28 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 18, - "_fontSize": 18, - "_lineHeight": 20, + "_actualFontSize": 80, + "_fontSize": 80, + "_lineHeight": 112, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "修改为黑夜模式", + "_N$string": "2", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { - "__type__": "cc.Sprite", + "__type__": "cc.Mask", "_name": "", "_objFlags": 0, "node": { - "__id__": 25 + "__id__": 24 }, "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null + "_segements": 10000, + "_N$spriteFrame": null, + "_N$alphaThreshold": 1, + "_N$inverted": false }, { - "__type__": "cc.Button", - "_name": "", + "__type__": "cc.Node", + "_name": "Player Name Two", "_objFlags": 0, - "node": { - "__id__": 25 - }, - "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "_parent": { + "__id__": 2 }, - "_N$disabledColor": { + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 32 + } + ], + "_prefab": null, + "_id": "bdMCFgAqJLeqtmdL7PIJV1", + "_opacity": 255, + "_color": { "__type__": "cc.Color", "r": 255, "g": 255, "b": 255, "a": 255 }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_contentSize": { + "__type__": "cc.Size", + "width": 0, + "height": 40 }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 0, + "y": -150 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 0, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 31 }, - "_N$target": { - "__id__": 25 - } + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 28, + "_fontSize": 28, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "btnStartGame", + "_name": "Player Three", "_objFlags": 0, "_parent": { "__id__": 2 }, "_children": [ { - "__id__": 31 + "__id__": 34 + }, + { + "__id__": 37 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 33 - }, - { - "__id__": 34 + "__id__": 39 } ], "_prefab": null, - "_id": "b4oIvc3clAfKTM+ZteHcgH", + "_id": "d3DI4xgUdPUaqVf0+zwKIb", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1229,8 +1306,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 200, + "height": 200 }, "_rotationX": 0, "_rotationY": 0, @@ -1238,8 +1315,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -175, - "y": -190 + "x": 300, + "y": 3 }, "_skewX": 0, "_skewY": 0, @@ -1250,27 +1327,30 @@ }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "New Layout", "_objFlags": 0, "_parent": { - "__id__": 30 + "__id__": 33 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 32 + "__id__": 35 + }, + { + "__id__": 36 } ], "_prefab": null, - "_id": "d2GQ7kZ9NKlY9gkucs25l1", + "_id": "2essz8j19Mo5Cof8asJiNb", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 85, + "g": 85, + "b": 85, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1281,8 +1361,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 200, + "height": 200 }, "_rotationX": 0, "_rotationY": 0, @@ -1300,38 +1380,16 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 31 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "开始游戏", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 30 + "__id__": 34 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" }, "_type": 1, "_sizeMode": 0, @@ -1349,99 +1407,59 @@ "_atlas": null }, { - "__type__": "cc.Button", + "__type__": "cc.Layout", "_name": "", "_objFlags": 0, "node": { - "__id__": 30 + "__id__": 34 }, "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_layoutSize": { + "__type__": "cc.Size", + "width": 200, + "height": 200 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 }, - "_N$target": { - "__id__": 30 - } + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0 }, { "__type__": "cc.Node", - "_name": "leaveRoom", + "_name": "Player Three Label", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 33 }, - "_children": [ - { - "__id__": 36 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { "__id__": 38 - }, - { - "__id__": 39 } ], "_prefab": null, - "_id": "9bPGerjJdBLKKIKmGOoHlA", + "_id": "c6z5pFgztL75GLf1o+T8xN", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 117, + "g": 117, + "b": 117, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1452,8 +1470,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 40, + "height": 112 }, "_rotationX": 0, "_rotationY": 0, @@ -1461,8 +1479,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 115, - "y": -190 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -1471,29 +1489,65 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 37 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 80, + "_fontSize": 80, + "_lineHeight": 112, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "3", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, + { + "__type__": "cc.Mask", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 33 + }, + "_enabled": true, + "_type": 1, + "_segements": 10000, + "_N$spriteFrame": null, + "_N$alphaThreshold": 1, + "_N$inverted": false + }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "Player Name Three", "_objFlags": 0, "_parent": { - "__id__": 35 + "__id__": 2 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 37 + "__id__": 41 } ], "_prefab": null, - "_id": "b8/ryWLhVFSYJW1jDw/5hV", + "_id": "acHtiyPphM2KlZzPT/GE1t", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1504,7 +1558,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, + "width": 0, "height": 40 }, "_rotationX": 0, @@ -1513,8 +1567,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -2, - "y": 0 + "x": 300, + "y": -150 }, "_skewX": 0, "_skewY": 0, @@ -1528,143 +1582,46 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 36 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "离开房间", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, - { - "__type__": "cc.Sprite", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 35 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null - }, - { - "__type__": "cc.Button", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 35 - }, - "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "__id__": 40 }, - "_N$target": { - "__id__": 35 - } + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 28, + "_fontSize": 28, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "buttonClick3", + "_name": "hint", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 41 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { "__id__": 43 - }, - { - "__id__": 44 } ], "_prefab": null, - "_id": "b0dLZRIxpGaZO6YWk78g4h", + "_id": "48dbWQZXVN+od2+YtUmA/o", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1675,8 +1632,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 310, + "height": 28 }, "_rotationX": 0, "_rotationY": 0, @@ -1684,8 +1641,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 290, - "y": -60 + "x": 0, + "y": -280 }, "_skewX": 0, "_skewY": 0, @@ -1694,29 +1651,51 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 42 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 20, + "_fontSize": 20, + "_lineHeight": 28, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "提示:需要满3个玩家才能开始游戏", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "joinopenTextView", "_objFlags": 0, "_parent": { - "__id__": 40 + "__id__": 2 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 42 + "__id__": 45 } ], "_prefab": null, - "_id": "a3KNjE2VRGkKQA7WkVCtfP", + "_id": "688cNM+HtHmY5s3VRbXsuQ", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1727,7 +1706,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, + "width": 112, "height": 40 }, "_rotationX": 0, @@ -1736,8 +1715,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": 0 + "x": 360, + "y": -280 }, "_skewX": 0, "_skewY": 0, @@ -1751,137 +1730,99 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 41 + "__id__": 44 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, + "_actualFontSize": 28, + "_fontSize": 28, "_lineHeight": 40, - "_enableWrapText": false, + "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "踢人", + "_N$string": "允许加入", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, - { - "__type__": "cc.Sprite", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 40 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null + "_N$overflow": 0 }, { - "__type__": "cc.Button", - "_name": "", + "__type__": "cc.Node", + "_name": "joinopen", "_objFlags": 0, - "node": { - "__id__": 40 - }, - "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "_parent": { + "__id__": 2 }, - "_N$disabledColor": { + "_children": [ + { + "__id__": 47 + }, + { + "__id__": 49 + } + ], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 51 + } + ], + "_prefab": null, + "_id": "6aY0C1smBLJZWE8EzKYK1D", + "_opacity": 255, + "_color": { "__type__": "cc.Color", "r": 255, "g": 255, "b": 255, "a": 255 }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_contentSize": { + "__type__": "cc.Size", + "width": 256, + "height": 28 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 430, + "y": -280 }, - "_N$target": { - "__id__": 40 - } + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 0, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 }, { "__type__": "cc.Node", - "_name": "buttonClick2", + "_name": "Background", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 46 }, - "_children": [ - { - "__id__": 46 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { "__id__": 48 - }, - { - "__id__": 49 } ], "_prefab": null, - "_id": "f3h4N+K6lN4Y1op/TvFTdA", + "_id": "21H6Vv8MJNbIEdHPxyAky4", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1898,8 +1839,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 28, + "height": 28 }, "_rotationX": 0, "_rotationY": 0, @@ -1907,8 +1848,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 290, - "y": 30 + "x": -62, + "y": -2 }, "_skewX": 0, "_skewY": 0, @@ -1917,29 +1858,55 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Sprite", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 47 + }, + "_enabled": true, + "_spriteFrame": { + "__uuid__": "6827ca32-0107-4552-bab2-dfb31799bb44" + }, + "_type": 3, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null + }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "checkmark", "_objFlags": 0, "_parent": { - "__id__": 45 + "__id__": 46 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 47 + "__id__": 50 } ], "_prefab": null, - "_id": "81jY6wbMlPwIIwarPBsdiz", + "_id": "efWOlgt89NQIXsgpwBGh4X", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1950,8 +1917,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 28, + "height": 28 }, "_rotationX": 0, "_rotationY": 0, @@ -1959,7 +1926,7 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, + "x": 9, "y": 0 }, "_skewX": 0, @@ -1969,41 +1936,19 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 46 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "踢人", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 45 + "__id__": 49 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "90004ad6-2f6d-40e1-93ef-b714375c6f06" }, - "_type": 1, - "_sizeMode": 0, + "_type": 0, + "_sizeMode": 2, "_fillType": 0, "_fillCenter": { "__type__": "cc.Vec2", @@ -2012,25 +1957,25 @@ }, "_fillStart": 0, "_fillRange": 0, - "_isTrimmedMode": true, + "_isTrimmedMode": false, "_srcBlendFactor": 770, "_dstBlendFactor": 771, "_atlas": null }, { - "__type__": "cc.Button", + "__type__": "cc.Toggle", "_name": "", "_objFlags": 0, "node": { - "__id__": 45 + "__id__": 46 }, "_enabled": true, - "transition": 2, + "transition": 3, "pressedColor": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 211, + "g": 211, + "b": 211, "a": 255 }, "hoverColor": { @@ -2047,39 +1992,33 @@ "_N$enableAutoGrayEffect": false, "_N$normalColor": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 214, + "g": 214, + "b": 214, "a": 255 }, "_N$disabledColor": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 124, + "g": 124, + "b": 124, "a": 255 }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_N$normalSprite": null, + "_N$pressedSprite": null, + "pressedSprite": null, + "_N$hoverSprite": null, + "hoverSprite": null, + "_N$disabledSprite": null, + "_N$target": { + "__id__": 47 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "toggleGroup": null, + "checkMark": { + "__id__": 50 }, - "_N$target": { - "__id__": 45 - } + "checkEvents": [], + "_N$isChecked": true }, { "__type__": "cc.Canvas", @@ -2091,53 +2030,57 @@ "_enabled": true, "_designResolution": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, - "_fitWidth": false, - "_fitHeight": true + "_fitWidth": true, + "_fitHeight": false }, { - "__type__": "d6f9ds2b45G/72niDeS85+A", + "__type__": "484a99DADxHZr2WX8hCpe4u", "_name": "", "_objFlags": 0, "node": { "__id__": 2 }, "_enabled": true, - "labelMyRoomID": { - "__id__": 14 + "playerNameOne": { + "__id__": 23 }, - "labelUserID1": { - "__id__": 16 + "playerNameTwo": { + "__id__": 32 }, - "labelUserID2": { - "__id__": 18 + "playerTwoLayout": { + "__id__": 27 }, - "labelUserID3": { - "__id__": 20 + "playerTwoLabel": { + "__id__": 29 }, - "labelInfo": { - "__id__": 12 + "playerNameThree": { + "__id__": 41 + }, + "playerThreeLayout": { + "__id__": 36 }, - "leaveRoom": { - "__id__": 35 + "playerThreeLabel": { + "__id__": 38 }, - "btnStartGame": { - "__id__": 30 + "labelRoomID": { + "__id__": 14 }, - "kickPlayer2": { - "__id__": 45 + "matchingWay": { + "__id__": 10 }, - "kickPlayer3": { - "__id__": 40 + "back": { + "__id__": 5 }, - "seleButton": { - "__id__": 25 + "joinopen": { + "__id__": 46 }, - "mapString": { - "__id__": 24 + "nickName": { + "__id__": 12 }, - "userList": [] + "userList": [], + "nameViewList": [] } ] \ No newline at end of file diff --git a/assets/login.fire.meta b/assets/scene/Match.fire.meta similarity index 65% rename from assets/login.fire.meta rename to assets/scene/Match.fire.meta index 78d1df2..a82077a 100644 --- a/assets/login.fire.meta +++ b/assets/scene/Match.fire.meta @@ -1,6 +1,6 @@ { "ver": "1.0.0", - "uuid": "458cbdf5-efc9-4be6-87d3-040eaae36764", + "uuid": "0e557bb3-8ed9-4799-a71b-9beeb7ac8838", "asyncLoadAssets": false, "autoReleaseAssets": false, "subMetas": {} diff --git a/assets/match.fire b/assets/scene/Result.fire similarity index 77% rename from assets/match.fire rename to assets/scene/Result.fire index 3566b5d..069d162 100644 --- a/assets/match.fire +++ b/assets/scene/Result.fire @@ -15,16 +15,13 @@ "_children": [ { "__id__": 2 - }, - { - "__id__": 33 } ], "_tag": -1, "_active": true, "_components": [], "_prefab": null, - "_id": "a6c2b82c-6fa1-4ce4-a281-578aec93a8d7", + "_id": "47d41f16-71c2-4854-a85d-9cff1bdacf65", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -64,6 +61,12 @@ { "__id__": 5 }, + { + "__id__": 7 + }, + { + "__id__": 9 + }, { "__id__": 11 }, @@ -86,27 +89,27 @@ "__id__": 23 }, { - "__id__": 25 + "__id__": 28 }, { - "__id__": 27 + "__id__": 31 }, { - "__id__": 29 + "__id__": 34 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 31 + "__id__": 37 }, { - "__id__": 32 + "__id__": 38 } ], "_prefab": null, - "_id": "6bQdc6KCBIh5tLoRzTAjIJ", + "_id": "4cDEN1WV9OdYUv0oTLasg9", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -123,8 +126,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -132,8 +135,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 480, - "y": 320 + "x": 640, + "y": 360 }, "_skewX": 0, "_skewY": 0, @@ -144,7 +147,7 @@ }, { "__type__": "cc.Node", - "_name": "joinopenTextView", + "_name": "backgrout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -158,7 +161,7 @@ } ], "_prefab": null, - "_id": "5854CIcBFHN6w7o6H6LZrp", + "_id": "8aoNxsg/5ADqCb3mEh6jUA", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -175,8 +178,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 112, - "height": 40 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -184,8 +187,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 280, - "y": -273 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -195,51 +198,48 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { "__id__": 3 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 28, - "_fontSize": 28, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "允许加入", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "0cbd03ff-a827-4248-a85b-6bfd7ebfcabd" + }, + "_type": 2, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "joinopen", + "_name": "New Label", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 6 - }, - { - "__id__": 8 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 10 + "__id__": 6 } ], "_prefab": null, - "_id": "89OctB0WBFVqkBVosTKFsP", + "_id": "53TbI/jJxDlZBfD/HgkA9L", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -256,8 +256,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 256, - "height": 28 + "width": 144, + "height": 50 }, "_rotationX": 0, "_rotationY": 0, @@ -265,8 +265,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 363, - "y": -270 + "x": 0, + "y": 280 }, "_skewX": 0, "_skewY": 0, @@ -275,23 +275,45 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 5 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 36, + "_fontSize": 36, + "_lineHeight": 50, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "游戏结果", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, { "__type__": "cc.Node", - "_name": "Background", + "_name": "Room Num", "_objFlags": 0, "_parent": { - "__id__": 5 + "__id__": 2 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 7 + "__id__": 8 } ], "_prefab": null, - "_id": "d9JN3HTbRJcYBtiTjnskSL", + "_id": "888jr4KClK0avtbMCDgTcA", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -308,8 +330,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 28, - "height": 28 + "width": 0, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -317,8 +339,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -62, - "y": -2 + "x": 0, + "y": 220 }, "_skewX": 0, "_skewY": 0, @@ -328,54 +350,50 @@ "groupIndex": 0 }, { - "__type__": "cc.Sprite", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 6 + "__id__": 7 }, "_enabled": true, - "_spriteFrame": { - "__uuid__": "6827ca32-0107-4552-bab2-dfb31799bb44" - }, - "_type": 3, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "checkmark", + "_name": "Owner ID", "_objFlags": 0, "_parent": { - "__id__": 5 + "__id__": 2 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 9 + "__id__": 10 } ], "_prefab": null, - "_id": "b86NPKZoNDFrHtzoEGMBxn", + "_id": "37/KlF2x5CJ4Z1SK14iKKm", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -386,8 +404,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 28, - "height": 28 + "width": 0, + "height": 50 }, "_rotationX": 0, "_rotationY": 0, @@ -395,8 +413,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 9, - "y": 0 + "x": -180, + "y": 120 }, "_skewX": 0, "_skewY": 0, @@ -406,92 +424,30 @@ "groupIndex": 0 }, { - "__type__": "cc.Sprite", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 8 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "90004ad6-2f6d-40e1-93ef-b714375c6f06" - }, - "_type": 0, - "_sizeMode": 2, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": false, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null - }, - { - "__type__": "cc.Toggle", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 5 - }, - "_enabled": true, - "transition": 3, - "pressedColor": { - "__type__": "cc.Color", - "r": 211, - "g": 211, - "b": 211, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 214, - "g": 214, - "b": 214, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 124, - "g": 124, - "b": 124, - "a": 255 - }, - "_N$normalSprite": null, - "_N$pressedSprite": null, - "pressedSprite": null, - "_N$hoverSprite": null, - "hoverSprite": null, - "_N$disabledSprite": null, - "_N$target": { - "__id__": 6 - }, - "toggleGroup": null, - "checkMark": { "__id__": 9 }, - "checkEvents": [], - "_N$isChecked": true + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 36, + "_fontSize": 36, + "_lineHeight": 50, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "labelInfo", + "_name": "New Sprite", "_objFlags": 0, "_parent": { "__id__": 2 @@ -505,13 +461,13 @@ } ], "_prefab": null, - "_id": "76u5ukerBPNqPPICNwaP1g", + "_id": "eaJkAnh3NI04eHIwYx89bf", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 228, - "g": 58, - "b": 92, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -522,8 +478,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 20 + "width": 90, + "height": 32 }, "_rotationX": 0, "_rotationY": 0, @@ -531,8 +487,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 318, - "y": 273 + "x": -300, + "y": 120 }, "_skewX": 0, "_skewY": 0, @@ -542,30 +498,34 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { "__id__": 11 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 0, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "af729f48-62ab-470c-9bd9-77f219dde1c6" + }, + "_type": 0, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "labelProperty", + "_name": "ID One", "_objFlags": 0, "_parent": { "__id__": 2 @@ -579,7 +539,7 @@ } ], "_prefab": null, - "_id": "77Kqby33ZAGLaYflB64/0/", + "_id": "7bpy5R89RPDYKSb2Q68pHr", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -597,7 +557,7 @@ "_contentSize": { "__type__": "cc.Size", "width": 0, - "height": 20 + "height": 50 }, "_rotationX": 0, "_rotationY": 0, @@ -605,8 +565,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -96, - "y": -271 + "x": -180, + "y": 20 }, "_skewX": 0, "_skewY": 0, @@ -624,9 +584,9 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, + "_actualFontSize": 36, + "_fontSize": 36, + "_lineHeight": 50, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, @@ -634,12 +594,12 @@ "_N$string": "", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "labelCountDown", + "_name": "ID Two", "_objFlags": 0, "_parent": { "__id__": 2 @@ -653,7 +613,7 @@ } ], "_prefab": null, - "_id": "74Uj30dhhCr5o7csxgrpWB", + "_id": "6dZveHURxGcadNrOhiiqTG", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -671,7 +631,7 @@ "_contentSize": { "__type__": "cc.Size", "width": 0, - "height": 40 + "height": 50 }, "_rotationX": 0, "_rotationY": 0, @@ -679,8 +639,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 9, - "y": -209 + "x": -180, + "y": -80 }, "_skewX": 0, "_skewY": 0, @@ -698,9 +658,9 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, - "_lineHeight": 40, + "_actualFontSize": 36, + "_fontSize": 36, + "_lineHeight": 50, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, @@ -708,12 +668,12 @@ "_N$string": "", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "labelRoomID", + "_name": "Owner Score", "_objFlags": 0, "_parent": { "__id__": 2 @@ -727,13 +687,13 @@ } ], "_prefab": null, - "_id": "f56Nwa44tA/6YBR+HjGmTl", + "_id": "3dZiK2FNxMALZ+6zV8wMub", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -745,7 +705,7 @@ "_contentSize": { "__type__": "cc.Size", "width": 0, - "height": 20 + "height": 50 }, "_rotationX": 0, "_rotationY": 0, @@ -753,8 +713,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 57, - "y": 216 + "x": 220, + "y": 115 }, "_skewX": 0, "_skewY": 0, @@ -772,9 +732,9 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, + "_actualFontSize": 36, + "_fontSize": 36, + "_lineHeight": 50, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, @@ -782,12 +742,12 @@ "_N$string": "", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "player1", + "_name": "Score One", "_objFlags": 0, "_parent": { "__id__": 2 @@ -801,7 +761,7 @@ } ], "_prefab": null, - "_id": "d4c+83XeZGX4s1lWgXxzNR", + "_id": "b3aHuMvZlGyLEsiXFi1FeV", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -819,7 +779,7 @@ "_contentSize": { "__type__": "cc.Size", "width": 0, - "height": 20 + "height": 50 }, "_rotationX": 0, "_rotationY": 0, @@ -827,8 +787,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -184, - "y": -16 + "x": 220, + "y": 20 }, "_skewX": 0, "_skewY": 0, @@ -846,9 +806,9 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, + "_actualFontSize": 36, + "_fontSize": 36, + "_lineHeight": 50, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, @@ -856,12 +816,12 @@ "_N$string": "", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "title", + "_name": "Score Two", "_objFlags": 0, "_parent": { "__id__": 2 @@ -875,7 +835,7 @@ } ], "_prefab": null, - "_id": "62aEbwxXxEOLEPM3MlPhZY", + "_id": "e2XQ0U26FOC4uaJm+CxQm7", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -892,8 +852,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 80, - "height": 40 + "width": 0, + "height": 50 }, "_rotationX": 0, "_rotationY": 0, @@ -901,8 +861,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": 285 + "x": 220, + "y": -80 }, "_skewX": 0, "_skewY": 0, @@ -920,42 +880,49 @@ }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, - "_lineHeight": 40, + "_actualFontSize": 36, + "_fontSize": 36, + "_lineHeight": 50, "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "匹配", + "_N$string": "", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "join", + "_name": "back", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [], + "_children": [ + { + "__id__": 24 + } + ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 24 + "__id__": 26 + }, + { + "__id__": 27 } ], "_prefab": null, - "_id": "bdDXKuT9BPy64VIwrCTBlo", + "_id": "28tPUAgJtMfYWppCcSivPT", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -966,8 +933,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 120, - "height": 30 + "width": 240, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -975,8 +942,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -132, - "y": 215 + "x": 0, + "y": -250 }, "_skewX": 0, "_skewY": 0, @@ -985,45 +952,23 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 23 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 30, - "_fontSize": 30, - "_lineHeight": 30, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "房间号:", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, { "__type__": "cc.Node", - "_name": "match", + "_name": "Label", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 23 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 26 + "__id__": 25 } ], "_prefab": null, - "_id": "478n3kfDBOT7PvOOeE+VVn", + "_id": "5bvzUhNWpH27pmewFtUS1J", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1040,8 +985,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 561, - "height": 339 + "width": 100, + "height": 40 }, "_rotationX": 0, "_rotationY": 0, @@ -1049,8 +994,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 2, - "y": 16 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -1059,19 +1004,41 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 24 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": false, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "离开游戏", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 1 + }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 25 + "__id__": 23 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "cb8f76e8-80f5-4ba5-8d22-7d4c6746a488" + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" }, - "_type": 0, - "_sizeMode": 1, + "_type": 1, + "_sizeMode": 0, "_fillType": 0, "_fillCenter": { "__type__": "cc.Vec2", @@ -1086,82 +1053,72 @@ "_atlas": null }, { - "__type__": "cc.Node", - "_name": "player2", + "__type__": "cc.Button", + "_name": "", "_objFlags": 0, - "_parent": { - "__id__": 2 + "node": { + "__id__": 23 }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 28 - } - ], - "_prefab": null, - "_id": "e1OdfroqVNjKsD4b7pJ8JF", - "_opacity": 255, - "_color": { + "_enabled": true, + "transition": 2, + "pressedColor": { "__type__": "cc.Color", "r": 255, "g": 255, "b": 255, "a": 255 }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 + "hoverColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 }, - "_contentSize": { - "__type__": "cc.Size", - "width": 0, - "height": 20 + "duration": 0.1, + "zoomScale": 1.2, + "clickEvents": [], + "_N$interactable": true, + "_N$enableAutoGrayEffect": false, + "_N$normalColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": 2, - "y": -20 + "_N$disabledColor": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 27 + "_N$normalSprite": { + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_N$pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "_N$hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "_N$disabledSprite": { + "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + }, + "_N$target": { + "__id__": 23 + } }, { "__type__": "cc.Node", - "_name": "player3", + "_name": "New Layout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -1170,18 +1127,21 @@ "_tag": -1, "_active": true, "_components": [ + { + "__id__": 29 + }, { "__id__": 30 } ], "_prefab": null, - "_id": "fa2IRAVZ9DA6NSuM4sJ0mi", + "_id": "2b59QikP5DVJhrJsNoZ9qf", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 84, + "g": 84, + "b": 84, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1192,8 +1152,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 0, - "height": 20 + "width": 480, + "height": 1 }, "_rotationX": 0, "_rotationY": 0, @@ -1201,8 +1161,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 191, - "y": -26 + "x": 0, + "y": 70 }, "_skewX": 0, "_skewY": 0, @@ -1212,111 +1172,88 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 29 + "__id__": 28 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, - { - "__type__": "cc.Canvas", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 2 + "_spriteFrame": { + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" }, - "_enabled": true, - "_designResolution": { - "__type__": "cc.Size", - "width": 960, - "height": 640 + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 }, - "_fitWidth": false, - "_fitHeight": true + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { - "__type__": "484a99DADxHZr2WX8hCpe4u", + "__type__": "cc.Layout", "_name": "", "_objFlags": 0, "node": { - "__id__": 2 - }, - "_enabled": true, - "player1": { - "__id__": 20 - }, - "player2": { "__id__": 28 }, - "player3": { - "__id__": 30 - }, - "labelRoomID": { - "__id__": 18 - }, - "labelCountdown": { - "__id__": 16 - }, - "labelProperty": { - "__id__": 14 - }, - "labelInfo": { - "__id__": 12 - }, - "leaveRoom": { - "__id__": 33 + "_enabled": true, + "_layoutSize": { + "__type__": "cc.Size", + "width": 480, + "height": 1 }, - "joinopen": { - "__id__": 5 + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 }, - "userList": [], - "nameViewList": [] + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0 }, { "__type__": "cc.Node", - "_name": "buttonLeaveRoom", + "_name": "New Layout", "_objFlags": 0, "_parent": { - "__id__": 1 + "__id__": 2 }, - "_children": [ - { - "__id__": 34 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 36 + "__id__": 32 }, { - "__id__": 37 + "__id__": 33 } ], "_prefab": null, - "_id": "3dzxTO0EtDQ5lNKUotHrVr", + "_id": "34loy80NNJd6NeOi3lFy+G", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 84, + "g": 84, + "b": 84, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1327,8 +1264,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 480, + "height": 1 }, "_rotationX": 0, "_rotationY": 0, @@ -1336,8 +1273,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 501, - "y": 85 + "x": 0, + "y": -30 }, "_skewX": 0, "_skewY": 0, @@ -1346,12 +1283,69 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Sprite", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 31 + }, + "_enabled": true, + "_spriteFrame": { + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" + }, + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null + }, + { + "__type__": "cc.Layout", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 31 + }, + "_enabled": true, + "_layoutSize": { + "__type__": "cc.Size", + "width": 480, + "height": 1 + }, + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 + }, + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0 + }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "New Layout", "_objFlags": 0, "_parent": { - "__id__": 33 + "__id__": 2 }, "_children": [], "_tag": -1, @@ -1359,16 +1353,19 @@ "_components": [ { "__id__": 35 + }, + { + "__id__": 36 } ], "_prefab": null, - "_id": "a6XUu7MPpPnrcogul0eCJn", + "_id": "13+MF6JrdC1bvbD6OidS6e", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 84, + "g": 84, + "b": 84, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1379,8 +1376,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 480, + "height": 1 }, "_rotationX": 0, "_rotationY": 0, @@ -1388,8 +1385,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 1, - "y": 1 + "x": 0, + "y": -130 }, "_skewX": 0, "_skewY": 0, @@ -1398,38 +1395,16 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 34 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "离开房间", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 33 + "__id__": 34 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" }, "_type": 1, "_sizeMode": 0, @@ -1447,67 +1422,83 @@ "_atlas": null }, { - "__type__": "cc.Button", + "__type__": "cc.Layout", "_name": "", "_objFlags": 0, "node": { - "__id__": 33 + "__id__": 34 }, "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "_layoutSize": { + "__type__": "cc.Size", + "width": 480, + "height": 1 }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "_resize": 0, + "_N$layoutType": 0, + "_N$padding": 0, + "_N$cellSize": { + "__type__": "cc.Size", + "width": 40, + "height": 40 }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "_N$startAxis": 0, + "_N$paddingLeft": 0, + "_N$paddingRight": 0, + "_N$paddingTop": 0, + "_N$paddingBottom": 0, + "_N$spacingX": 0, + "_N$spacingY": 0, + "_N$verticalDirection": 1, + "_N$horizontalDirection": 0 + }, + { + "__type__": "cc.Canvas", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 2 }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "_enabled": true, + "_designResolution": { + "__type__": "cc.Size", + "width": 1280, + "height": 720 }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "_fitWidth": true, + "_fitHeight": false + }, + { + "__type__": "47afb331JpASbIJuG281Nza", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 2 }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_enabled": true, + "roomNum": { + "__id__": 8 }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "ownerID": { + "__id__": 10 }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "ownerScore": { + "__id__": 18 }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "oneID": { + "__id__": 14 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "oneScore": { + "__id__": 20 }, - "_N$target": { - "__id__": 33 + "twoID": { + "__id__": 16 + }, + "twoScore": { + "__id__": 22 + }, + "buttonBack": { + "__id__": 23 } } ] \ No newline at end of file diff --git a/assets/scene/Result.fire.meta b/assets/scene/Result.fire.meta new file mode 100644 index 0000000..cbfe091 --- /dev/null +++ b/assets/scene/Result.fire.meta @@ -0,0 +1,7 @@ +{ + "ver": "1.0.0", + "uuid": "47d41f16-71c2-4854-a85d-9cff1bdacf65", + "asyncLoadAssets": false, + "autoReleaseAssets": false, + "subMetas": {} +} \ No newline at end of file diff --git a/assets/lobby.fire b/assets/scene/RoomList.fire similarity index 65% rename from assets/lobby.fire rename to assets/scene/RoomList.fire index b0ceaef..aceec0b 100644 --- a/assets/lobby.fire +++ b/assets/scene/RoomList.fire @@ -15,13 +15,16 @@ "_children": [ { "__id__": 2 + }, + { + "__id__": 57 } ], "_tag": -1, "_active": true, "_components": [], "_prefab": null, - "_id": "63b83656-9405-499a-b758-3c977e929c6d", + "_id": "81eebde1-52ed-412f-a229-ca7011bf4960", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -41,7 +44,7 @@ "width": 0, "height": 0 }, - "_localZOrder": 0, + "_localZOrder": 2, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0, @@ -65,45 +68,27 @@ "__id__": 7 }, { - "__id__": 12 - }, - { - "__id__": 14 + "__id__": 9 }, { - "__id__": 16 + "__id__": 11 }, { - "__id__": 21 + "__id__": 24 }, { "__id__": 26 - }, - { - "__id__": 31 - }, - { - "__id__": 36 - }, - { - "__id__": 41 - }, - { - "__id__": 46 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 48 - }, - { - "__id__": 49 + "__id__": 56 } ], "_prefab": null, - "_id": "92hS2pffxKu47xvhK0ezMf", + "_id": "b92CYPpXdDPb/ibLJvBa3X", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -120,8 +105,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -129,19 +114,19 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 480, - "y": 320 + "x": 640, + "y": 360 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 3, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { "__type__": "cc.Node", - "_name": "nickName", + "_name": "backgrout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -155,13 +140,13 @@ } ], "_prefab": null, - "_id": "5fqpZQ6u1ClJ76ABU/aWZ8", + "_id": "3fSfHElHFKCaJ+dnEU82o6", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 4, - "g": 243, - "b": 23, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -172,8 +157,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 49, - "height": 20 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -181,8 +166,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -399, - "y": 202 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -192,30 +177,34 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { "__id__": 3 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "Label", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "0cbd03ff-a827-4248-a85b-6bfd7ebfcabd" + }, + "_type": 2, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "avatar", + "_name": "back", "_objFlags": 0, "_parent": { "__id__": 2 @@ -229,7 +218,7 @@ } ], "_prefab": null, - "_id": "cd5htbr8NAQIYg/0Id7noS", + "_id": "b2JTpwGfZM3JTMsc7s8XHb", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -246,8 +235,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 80, - "height": 80 + "width": 20, + "height": 36 }, "_rotationX": 0, "_rotationY": 0, @@ -255,8 +244,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -394, - "y": 264 + "x": -550, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -273,9 +262,11 @@ "__id__": 5 }, "_enabled": true, - "_spriteFrame": null, - "_type": 1, - "_sizeMode": 0, + "_spriteFrame": { + "__uuid__": "3f66add4-81b7-41d8-995e-1553cd3ef92e" + }, + "_type": 0, + "_sizeMode": 1, "_fillType": 0, "_fillCenter": { "__type__": "cc.Vec2", @@ -285,34 +276,27 @@ "_fillStart": 0, "_fillRange": 0, "_isTrimmedMode": true, - "_srcBlendFactor": 1, + "_srcBlendFactor": 770, "_dstBlendFactor": 771, "_atlas": null }, { "__type__": "cc.Node", - "_name": "syncFrame", + "_name": "label", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 8 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 10 - }, - { - "__id__": 11 + "__id__": 8 } ], "_prefab": null, - "_id": "c42Klwr25CG7vD35cSDbbm", + "_id": "7eVpDRwkdMc4p+XnPJkVBu", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -324,13 +308,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 144, + "height": 50 }, "_rotationX": 0, "_rotationY": 0, @@ -338,39 +322,61 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": -170 + "x": -505, + "y": 290 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 5, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 7 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 36, + "_fontSize": 36, + "_lineHeight": 50, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "房间列表", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "Arial", + "_N$overflow": 0 + }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "labelInfo", "_objFlags": 0, "_parent": { - "__id__": 7 + "__id__": 2 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 9 + "__id__": 10 } ], "_prefab": null, - "_id": "90ygcVOilNFZTZ5tauI8Ea", + "_id": "7aiQj5oTZNhJW4REqpU2uF", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 228, + "g": 58, + "b": 92, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -381,8 +387,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 0, + "height": 15 }, "_rotationX": 0, "_rotationY": 0, @@ -390,12 +396,12 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, - "y": 0 + "x": -369, + "y": 301 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 6, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -405,136 +411,56 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 8 + "__id__": 9 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, + "_actualFontSize": 15, + "_fontSize": 15, + "_lineHeight": 15, + "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "帧同步模式", + "_N$string": "", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, - { - "__type__": "cc.Sprite", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 7 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null - }, - { - "__type__": "cc.Button", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 7 - }, - "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" - }, - "_N$target": { - "__id__": 7 - } + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "info", + "_name": "scrollview", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [], + "_children": [ + { + "__id__": 12 + }, + { + "__id__": 18 + } + ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 13 + "__id__": 23 + }, + { + "__id__": 16 } ], "_prefab": null, - "_id": "a2yWq/XRRCCYh/zhTmGWXg", + "_id": "11eZLWn7xOwKjpad+RXMo+", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 228, - "g": 58, - "b": 92, + "r": 0, + "g": 0, + "b": 0, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -545,8 +471,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 120, - "height": 20 + "width": 850, + "height": 400 }, "_rotationX": 0, "_rotationY": 0, @@ -554,154 +480,61 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 318, - "y": 218 + "x": 0, + "y": -60 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 7, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { - "__type__": "cc.Label", - "_name": "", + "__type__": "cc.Node", + "_name": "scrollBar", "_objFlags": 0, - "node": { - "__id__": 12 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "进入游戏大厅", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, - { - "__type__": "cc.Node", - "_name": "title", - "_objFlags": 0, - "_parent": { - "__id__": 2 - }, - "_children": [], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 15 - } - ], - "_prefab": null, - "_id": "b2MiY4fjlCBYRQMkjE+5ut", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 160, - "height": 40 - }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { - "__type__": "cc.Vec2", - "x": -3, - "y": 282 - }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 - }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 14 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "游戏大厅", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, - { - "__type__": "cc.Node", - "_name": "logout", - "_objFlags": 0, - "_parent": { - "__id__": 2 + "_parent": { + "__id__": 11 }, "_children": [ { - "__id__": 17 + "__id__": 13 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 19 + "__id__": 15 }, { - "__id__": 20 + "__id__": 21 + }, + { + "__id__": 22 } ], "_prefab": null, - "_id": "2d3VPoDbZB3IQeLZvEX8s3", + "_id": "80+uoOPINLTJQFPLXNV+eo", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 8, + "g": 202, + "b": 243, "a": 255 }, "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 1, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 10, + "height": 300 }, "_rotationX": 0, "_rotationY": 0, @@ -709,51 +542,51 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": -240 + "x": 451, + "y": 0 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 8, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "bar", "_objFlags": 0, "_parent": { - "__id__": 16 + "__id__": 12 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 18 + "__id__": 14 } ], "_prefab": null, - "_id": "b5NQUrK0BJVZvLEVs5FaF2", + "_id": "bd842Xod9JTLINGtCDsxjc", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 236, + "g": 241, + "b": 245, "a": 255 }, "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 + "x": 1, + "y": 0 }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 10, + "height": 30 }, "_rotationX": 0, "_rotationY": 0, @@ -761,48 +594,26 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 0, + "x": -1, "y": 0 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 9, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 17 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "返回登录", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 16 + "__id__": 13 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "5c3bb932-6c3c-468f-88a9-c8c61d458641" }, "_type": 1, "_sizeMode": 0, @@ -820,93 +631,62 @@ "_atlas": null }, { - "__type__": "cc.Button", + "__type__": "cc.Scrollbar", "_name": "", "_objFlags": 0, "node": { - "__id__": 16 + "__id__": 12 }, "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_scrollView": { + "__id__": 16 }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_touching": false, + "_opacity": 255, + "enableAutoHide": true, + "autoHideTime": 1, + "_N$handle": { + "__id__": 14 }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_N$direction": 1 + }, + { + "__type__": "cc.ScrollView", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 11 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "_enabled": true, + "content": { + "__id__": 17 }, - "_N$target": { - "__id__": 16 + "horizontal": false, + "vertical": true, + "inertia": true, + "brake": 0.9, + "elastic": true, + "bounceDuration": 0.23, + "scrollEvents": [], + "cancelInnerEvents": true, + "_N$horizontalScrollBar": null, + "_N$verticalScrollBar": { + "__id__": 15 } }, { "__type__": "cc.Node", - "_name": "randomMatch", + "_name": "content", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 18 }, - "_children": [ - { - "__id__": 22 - } - ], + "_children": [], "_tag": -1, "_active": true, - "_components": [ - { - "__id__": 24 - }, - { - "__id__": 25 - } - ], + "_components": [], "_prefab": null, - "_id": "e3OOacjHRM9ZPaSeHLcBCb", + "_id": "b9WynyBHZJy6LPjozJq9X+", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -919,12 +699,12 @@ "_anchorPoint": { "__type__": "cc.Vec2", "x": 0.5, - "y": 0.5 + "y": 1 }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 220, + "height": 400 }, "_rotationX": 0, "_rotationY": 0, @@ -932,39 +712,46 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": 180 + "x": -6, + "y": 222 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 11, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "view", "_objFlags": 0, "_parent": { - "__id__": 21 + "__id__": 11 }, - "_children": [], + "_children": [ + { + "__id__": 17 + } + ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 23 + "__id__": 19 + }, + { + "__id__": 20 } ], "_prefab": null, - "_id": "b2WxzNPdRCKbrg2xOvTKh0", + "_id": "cfv6EX36VMHKk11pSnn8r3", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -975,8 +762,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 850, + "height": 400 }, "_rotationX": 0, "_rotationY": 0, @@ -989,43 +776,87 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 10, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Mask", "_name": "", "_objFlags": 0, "node": { - "__id__": 22 + "__id__": 18 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "随机匹配", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 + "_type": 0, + "_segements": 64, + "_N$spriteFrame": null, + "_N$alphaThreshold": 1, + "_N$inverted": false + }, + { + "__type__": "cc.Widget", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 18 + }, + "_enabled": true, + "isAlignOnce": true, + "_target": null, + "_alignFlags": 45, + "_left": 0, + "_right": 0, + "_top": 0, + "_bottom": 0, + "_verticalCenter": 0, + "_horizontalCenter": 0, + "_isAbsLeft": true, + "_isAbsRight": true, + "_isAbsTop": true, + "_isAbsBottom": true, + "_isAbsHorizontalCenter": true, + "_isAbsVerticalCenter": true, + "_originalWidth": 800, + "_originalHeight": 500 + }, + { + "__type__": "cc.Widget", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 12 + }, + "_enabled": true, + "isAlignOnce": true, + "_target": null, + "_alignFlags": 37, + "_left": 350.07654921020657, + "_right": -26, + "_top": 50, + "_bottom": 50, + "_verticalCenter": 0, + "_horizontalCenter": 0, + "_isAbsLeft": true, + "_isAbsRight": true, + "_isAbsTop": true, + "_isAbsBottom": true, + "_isAbsHorizontalCenter": true, + "_isAbsVerticalCenter": true, + "_originalWidth": 0, + "_originalHeight": 237 }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 21 + "__id__": 12 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "5fe5dcaa-b513-4dc5-a166-573627b3a159" }, "_type": 1, "_sizeMode": 0, @@ -1043,72 +874,106 @@ "_atlas": null }, { - "__type__": "cc.Button", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 21 + "__id__": 11 }, "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "_spriteFrame": null, + "_type": 1, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null + }, + { + "__type__": "cc.Node", + "_name": "refreshNumText", + "_objFlags": 0, + "_parent": { + "__id__": 2 }, - "_N$disabledColor": { + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 25 + } + ], + "_prefab": null, + "_id": "08VJWcQH9KMokns7WzkImF", + "_opacity": 255, + "_color": { "__type__": "cc.Color", "r": 255, "g": 255, "b": 255, "a": 255 }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0.5 }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_contentSize": { + "__type__": "cc.Size", + "width": 0, + "height": 20 }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": -294, + "y": 290 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 14, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 24 }, - "_N$target": { - "__id__": 21 - } + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 18, + "_fontSize": 18, + "_lineHeight": 20, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "selfDefMatch", + "_name": "item", "_objFlags": 0, "_parent": { "__id__": 2 @@ -1116,20 +981,32 @@ "_children": [ { "__id__": 27 + }, + { + "__id__": 30 + }, + { + "__id__": 35 + }, + { + "__id__": 40 + }, + { + "__id__": 45 + }, + { + "__id__": 50 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 29 - }, - { - "__id__": 30 + "__id__": 55 } ], "_prefab": null, - "_id": "9aM5OqxSxOqavSVtpMAMmS", + "_id": "c3Y2Il5OxEqa73Aeu2jBeb", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1146,8 +1023,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 800, + "height": 100 }, "_rotationX": 0, "_rotationY": 0, @@ -1155,19 +1032,19 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": 110 + "x": -3121, + "y": 3468 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 15, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "backgroud", "_objFlags": 0, "_parent": { "__id__": 26 @@ -1178,16 +1055,19 @@ "_components": [ { "__id__": 28 + }, + { + "__id__": 29 } ], "_prefab": null, - "_id": "46DPNMtqlAw6MPSYtslhoI", + "_id": "2eeXkvuO9NNouq4ieeESoR", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 84, + "g": 84, + "b": 84, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1198,8 +1078,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 800, + "height": 1 }, "_rotationX": 0, "_rotationY": 0, @@ -1208,47 +1088,25 @@ "_position": { "__type__": "cc.Vec2", "x": 0, - "y": 0 + "y": -50 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 16, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 27 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "自定义属性匹配", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 26 + "__id__": 27 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "9bbda31e-ad49-43c9-aaf2-f7d9896bac69" }, "_type": 1, "_sizeMode": 0, @@ -1270,15 +1128,15 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 26 + "__id__": 27 }, "_enabled": true, - "transition": 2, + "transition": 0, "pressedColor": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 211, + "g": 211, + "b": 211, "a": 255 }, "hoverColor": { @@ -1295,64 +1153,48 @@ "_N$enableAutoGrayEffect": false, "_N$normalColor": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 214, + "g": 214, + "b": 214, "a": 255 }, "_N$disabledColor": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 124, + "g": 124, + "b": 124, "a": 255 }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" - }, + "_N$normalSprite": null, + "_N$pressedSprite": null, + "pressedSprite": null, + "_N$hoverSprite": null, + "hoverSprite": null, + "_N$disabledSprite": null, "_N$target": { - "__id__": 26 + "__id__": 27 } }, { "__type__": "cc.Node", - "_name": "roomList", + "_name": "roomName", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 26 }, "_children": [ { - "__id__": 32 - } - ], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 34 + "__id__": 31 }, { - "__id__": 35 + "__id__": 33 } ], + "_tag": -1, + "_active": true, + "_components": [], "_prefab": null, - "_id": "65aBsvr+dCU6Hnqi2UTKQJ", + "_id": "deSIgDeWlOm7jAFSoJKbMf", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1364,13 +1206,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 + "x": 0, + "y": 1 }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 0, + "height": 0 }, "_rotationX": 0, "_rotationY": 0, @@ -1378,51 +1220,51 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": 40 + "x": -400, + "y": 50 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 17, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "New Label", "_objFlags": 0, "_parent": { - "__id__": 31 + "__id__": 30 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 33 + "__id__": 32 } ], "_prefab": null, - "_id": "eamxtBPapLubbYLF7InSlF", + "_id": "c8P/tBLd9FTp3dN4nv9n9B", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 + "x": 0, + "y": 1 }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 80, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -1435,7 +1277,7 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 18, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -1445,137 +1287,523 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 32 + "__id__": 31 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "查看房间列表", - "_N$horizontalAlign": 1, + "_N$string": "房间ID:", + "_N$horizontalAlign": 0, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { - "__type__": "cc.Sprite", - "_name": "", + "__type__": "cc.Node", + "_name": "roomID", "_objFlags": 0, - "node": { - "__id__": 31 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 + "_parent": { + "__id__": 30 }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 34 + } + ], + "_prefab": null, + "_id": "ceQuRoZU1FIboG5eM0xivg", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 1 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 0, + "height": 33 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 85, + "y": 0 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 19, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 }, { - "__type__": "cc.Button", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 31 + "__id__": 33 }, "_enabled": true, - "transition": 2, - "pressedColor": { + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, + { + "__type__": "cc.Node", + "_name": "roomState", + "_objFlags": 0, + "_parent": { + "__id__": 26 + }, + "_children": [ + { + "__id__": 36 + }, + { + "__id__": 38 + } + ], + "_tag": -1, + "_active": true, + "_components": [], + "_prefab": null, + "_id": "cc6SHlKTNKHbShFulU4USp", + "_opacity": 255, + "_color": { "__type__": "cc.Color", "r": 255, "g": 255, "b": 255, "a": 255 }, - "hoverColor": { + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 1 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 0, + "height": 0 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": -200, + "y": 0 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 20, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Node", + "_name": "New Label", + "_objFlags": 0, + "_parent": { + "__id__": 35 + }, + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 37 + } + ], + "_prefab": null, + "_id": "3e1vQ0fbRP4Juuwc7zDqc0", + "_opacity": 255, + "_color": { "__type__": "cc.Color", "r": 255, "g": 255, "b": 255, "a": 255 }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 1 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 120, + "height": 33 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 21, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 36 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "房间状态:", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, + { + "__type__": "cc.Node", + "_name": "state", + "_objFlags": 0, + "_parent": { + "__id__": 35 + }, + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 39 + } + ], + "_prefab": null, + "_id": "f8yS5jSnRP0rwTz7fyrrHT", + "_opacity": 255, + "_color": { "__type__": "cc.Color", "r": 255, "g": 255, "b": 255, "a": 255 }, - "_N$disabledColor": { + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 1 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 0, + "height": 33 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 110, + "y": 0 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 22, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 38 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, + { + "__type__": "cc.Node", + "_name": "roomPlayer", + "_objFlags": 0, + "_parent": { + "__id__": 26 + }, + "_children": [ + { + "__id__": 41 + }, + { + "__id__": 43 + } + ], + "_tag": -1, + "_active": true, + "_components": [], + "_prefab": null, + "_id": "14rPbW0fFO2YFcu7wuBC3u", + "_opacity": 255, + "_color": { "__type__": "cc.Color", "r": 255, "g": 255, "b": 255, "a": 255 }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 1 }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_contentSize": { + "__type__": "cc.Size", + "width": 0, + "height": 0 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": -400, + "y": 0 }, - "_N$target": { - "__id__": 31 - } + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 23, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 }, { "__type__": "cc.Node", - "_name": "joinCertainRoom", + "_name": "New Label", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 40 }, - "_children": [ + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ { - "__id__": 37 + "__id__": 42 } ], + "_prefab": null, + "_id": "fb4h9QSOxO6Z/fpW9MMCJt", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 1 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 120, + "height": 33 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 24, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 41 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "房间人数:", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, + { + "__type__": "cc.Node", + "_name": "playerNum", + "_objFlags": 0, + "_parent": { + "__id__": 40 + }, + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 39 + "__id__": 44 + } + ], + "_prefab": null, + "_id": "c354a6p8lNyqOYWw7xnoir", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0, + "y": 1 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 0, + "height": 33 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 110, + "y": 0 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 25, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 43 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 0, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, + { + "__type__": "cc.Node", + "_name": "roomMap", + "_objFlags": 0, + "_parent": { + "__id__": 26 + }, + "_children": [ + { + "__id__": 46 }, { - "__id__": 40 + "__id__": 48 } ], + "_tag": -1, + "_active": true, + "_components": [], "_prefab": null, - "_id": "7963yhupRO5rkNVdJYKVWW", + "_id": "c1lqlM/OpKnZSwvuLUkUl+", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -1587,13 +1815,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 + "x": 0, + "y": 1 }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 0, + "height": 0 }, "_rotationX": 0, "_rotationY": 0, @@ -1601,51 +1829,51 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 20, - "y": -30 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 26, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "New Label", "_objFlags": 0, "_parent": { - "__id__": 36 + "__id__": 45 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 38 + "__id__": 47 } ], "_prefab": null, - "_id": "0e4dVFZhxLHrAQ8o/dYS+8", + "_id": "e6Cg3cBn9IcYHPojTEKaPW", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 + "x": 0, + "y": 1 }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 72, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -1658,7 +1886,7 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 27, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -1668,143 +1896,127 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 37 + "__id__": 46 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "加入指定房间", - "_N$horizontalAlign": 1, + "_N$string": "地图:", + "_N$horizontalAlign": 0, "_N$verticalAlign": 1, "_N$fontFamily": "Arial", - "_N$overflow": 1 + "_N$overflow": 0 }, { - "__type__": "cc.Sprite", - "_name": "", + "__type__": "cc.Node", + "_name": "map", "_objFlags": 0, - "node": { - "__id__": 36 + "_parent": { + "__id__": 45 }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "_children": [], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 49 + } + ], + "_prefab": null, + "_id": "3dqEwYmUZAB4WJ+/vZYMxv", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { + "_cascadeOpacityEnabled": true, + "_anchorPoint": { "__type__": "cc.Vec2", "x": 0, + "y": 1 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 0, + "height": 33 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 70, "y": 0 }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null + "_skewX": 1, + "_skewY": 1, + "_localZOrder": 28, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 }, { - "__type__": "cc.Button", + "__type__": "cc.Label", "_name": "", "_objFlags": 0, "node": { - "__id__": 36 + "__id__": 48 }, "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" - }, - "_N$target": { - "__id__": 36 - } + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Node", - "_name": "createRoom", + "_name": "startRoom", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 26 }, "_children": [ { - "__id__": 42 + "__id__": 51 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 44 + "__id__": 53 }, { - "__id__": 45 + "__id__": 54 } ], "_prefab": null, - "_id": "79fjYU9aFDLZRV8UV+2MQE", + "_id": "6123gi0xtBD6+OZ2tadIPX", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1815,8 +2027,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 200, - "height": 40 + "width": 160, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -1824,12 +2036,12 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 17, - "y": -100 + "x": 317, + "y": 0 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 29, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -1839,24 +2051,24 @@ "_name": "Label", "_objFlags": 0, "_parent": { - "__id__": 41 + "__id__": 50 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 43 + "__id__": 52 } ], "_prefab": null, - "_id": "05hk0BPxJBa7LUt08mlnU4", + "_id": "14FAi2cB9Azb3JUPGQu2MY", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1867,7 +2079,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 200, + "width": 100, "height": 40 }, "_rotationX": 0, @@ -1881,7 +2093,7 @@ }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 30, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 @@ -1891,21 +2103,21 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 42 + "__id__": 51 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, "_enableWrapText": false, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "创建房间", - "_N$horizontalAlign": 1, + "_N$string": "加入房间", + "_N$horizontalAlign": 0, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", + "_N$fontFamily": "PingFangSC", "_N$overflow": 1 }, { @@ -1913,7 +2125,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 41 + "__id__": 50 }, "_enabled": true, "_spriteFrame": { @@ -1939,7 +2151,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 41 + "__id__": 50 }, "_enabled": true, "transition": 2, @@ -1995,32 +2207,73 @@ "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" }, "_N$target": { - "__id__": 41 + "__id__": 50 } }, + { + "__type__": "5ef25w8ddVIeKi0B0zGVSIS", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 26 + }, + "_enabled": true, + "roomName": { + "__id__": 34 + }, + "roomState": { + "__id__": 39 + }, + "roomPlayer": { + "__id__": 44 + }, + "roomMap": { + "__id__": 49 + }, + "startGame": { + "__id__": 50 + }, + "itemID": 0 + }, + { + "__type__": "cc.Canvas", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 2 + }, + "_enabled": true, + "_designResolution": { + "__type__": "cc.Size", + "width": 1280, + "height": 720 + }, + "_fitWidth": true, + "_fitHeight": false + }, { "__type__": "cc.Node", - "_name": "errorMsg", + "_name": "roomList", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 1 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 47 + "__id__": 58 } ], "_prefab": null, - "_id": "8bynT57qlKDI/SeLGkwelg", + "_id": "19h5CFJntKGbTfffevOf4F", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 19, + "g": 2, + "b": 2, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -2032,7 +2285,7 @@ "_contentSize": { "__type__": "cc.Size", "width": 0, - "height": 40 + "height": 0 }, "_rotationX": 0, "_rotationY": 0, @@ -2040,94 +2293,40 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 23, - "y": 71 + "x": 46, + "y": 40 }, "_skewX": 0, "_skewY": 0, - "_localZOrder": 0, + "_localZOrder": 31, "_globalZOrder": 0, "_opacityModifyRGB": false, "groupIndex": 0 }, { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 46 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, - { - "__type__": "8081eh5Q3RECZVLEwf0+6/C", + "__type__": "4cf8aAo3zhGCpy3KJJBdkOW", "_name": "", "_objFlags": 0, "node": { - "__id__": 2 + "__id__": 57 }, "_enabled": true, - "randomMatch": { - "__id__": 21 + "back": { + "__id__": 5 }, - "selfDefMatch": { + "itemTemplate": { "__id__": 26 }, - "roomList": { - "__id__": 31 - }, - "joinCertainRoom": { - "__id__": 36 - }, - "createRoom": { - "__id__": 41 - }, - "returnLogin": { + "scrollView": { "__id__": 16 }, - "buttonSyncFrame": { - "__id__": 7 - }, + "spacing": 0, + "totalCount": 0, "labelInfo": { - "__id__": 13 - }, - "errorMsg": { - "__id__": 47 - }, - "nickName": { - "__id__": 4 + "__id__": 10 }, - "avatar111": { - "__id__": 6 + "refreshNumText": { + "__id__": 25 } - }, - { - "__type__": "cc.Canvas", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 2 - }, - "_enabled": true, - "_designResolution": { - "__type__": "cc.Size", - "width": 960, - "height": 640 - }, - "_fitWidth": false, - "_fitHeight": true } ] \ No newline at end of file diff --git a/assets/scene/RoomList.fire.meta b/assets/scene/RoomList.fire.meta new file mode 100644 index 0000000..1b69f5f --- /dev/null +++ b/assets/scene/RoomList.fire.meta @@ -0,0 +1,7 @@ +{ + "ver": "1.0.0", + "uuid": "81eebde1-52ed-412f-a229-ca7011bf4960", + "asyncLoadAssets": false, + "autoReleaseAssets": false, + "subMetas": {} +} \ No newline at end of file diff --git a/assets/selfDefMatch.fire b/assets/scene/SelfDefMatch.fire similarity index 82% rename from assets/selfDefMatch.fire rename to assets/scene/SelfDefMatch.fire index 2224bd1..ecee9b9 100644 --- a/assets/selfDefMatch.fire +++ b/assets/scene/SelfDefMatch.fire @@ -21,7 +21,7 @@ "_active": true, "_components": [], "_prefab": null, - "_id": "8b693ca5-7df4-4f8d-b1a0-71e5c43b2e69", + "_id": "345fc359-0b83-4e07-88d8-b053c7121479", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -65,30 +65,33 @@ "__id__": 7 }, { - "__id__": 21 + "__id__": 9 }, { - "__id__": 23 + "__id__": 11 }, { - "__id__": 25 + "__id__": 16 }, { "__id__": 30 + }, + { + "__id__": 32 } ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 35 + "__id__": 34 }, { - "__id__": 36 + "__id__": 35 } ], "_prefab": null, - "_id": "72mF1POnRHjbfVztoIqTPn", + "_id": "46jxYhouxJs5tKV3Fuphmx", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -105,8 +108,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -114,8 +117,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 480, - "y": 320 + "x": 640, + "y": 360 }, "_skewX": 0, "_skewY": 0, @@ -126,7 +129,7 @@ }, { "__type__": "cc.Node", - "_name": "title", + "_name": "backgrout", "_objFlags": 0, "_parent": { "__id__": 2 @@ -140,7 +143,7 @@ } ], "_prefab": null, - "_id": "3btCgqjsRBGY4SJ5bAgGUj", + "_id": "37kCyU/RZCoavTKodgnHRs", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -157,8 +160,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 280, - "height": 40 + "width": 1280, + "height": 720 }, "_rotationX": 0, "_rotationY": 0, @@ -167,7 +170,7 @@ "_position": { "__type__": "cc.Vec2", "x": 0, - "y": 180 + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -177,30 +180,34 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { "__id__": 3 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 40, - "_fontSize": 40, - "_lineHeight": 40, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "自定义属性匹配", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "0cbd03ff-a827-4248-a85b-6bfd7ebfcabd" + }, + "_type": 2, + "_sizeMode": 0, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "infoSelfDefMatch", + "_name": "back", "_objFlags": 0, "_parent": { "__id__": 2 @@ -214,7 +221,7 @@ } ], "_prefab": null, - "_id": "18ni66gj9EELh31tzlOXRy", + "_id": "f1q2rUJQFHqYkFAbpVdYSs", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -231,8 +238,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 80, - "height": 20 + "width": 20, + "height": 36 }, "_rotationX": 0, "_rotationY": 0, @@ -240,8 +247,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 241, - "y": 215 + "x": -550, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -251,51 +258,48 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { "__id__": 5 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 20, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "匹配信息", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 + "_spriteFrame": { + "__uuid__": "3f66add4-81b7-41d8-995e-1553cd3ef92e" + }, + "_type": 0, + "_sizeMode": 1, + "_fillType": 0, + "_fillCenter": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "select", + "_name": "New Label", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 8 - }, - { - "__id__": 15 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 14 + "__id__": 8 } ], "_prefab": null, - "_id": "691oxyyHxLoqgYjvhpI7og", + "_id": "0aElY4jZNBGpn6Z91bKwQM", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -307,13 +311,13 @@ "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 221, - "height": 200 + "width": 252, + "height": 40 }, "_rotationX": 0, "_rotationY": 0, @@ -321,8 +325,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -4, - "y": 31 + "x": -505, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -331,48 +335,63 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 7 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 36, + "_fontSize": 36, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "自定义属性匹配", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, { "__type__": "cc.Node", - "_name": "odd", + "_name": "nickName", "_objFlags": 0, "_parent": { - "__id__": 7 + "__id__": 2 }, - "_children": [ - { - "__id__": 9 - }, - { - "__id__": 11 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 13 + "__id__": 10 } ], "_prefab": null, - "_id": "42H2lj6AxOko9w1p5iXO5P", + "_id": "39MPQcA1dEbIwq1watEfx2", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 153, + "g": 153, + "b": 153, "a": 255 }, "_cascadeOpacityEnabled": true, "_anchorPoint": { "__type__": "cc.Vec2", - "x": 0.5, + "x": 0, "y": 0.5 }, "_contentSize": { "__type__": "cc.Size", - "width": 41, - "height": 28 + "width": 73, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -380,8 +399,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -60, - "y": 50 + "x": 400, + "y": 290 }, "_skewX": 0, "_skewY": 0, @@ -390,29 +409,58 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 9 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "用户ID", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, { "__type__": "cc.Node", - "_name": "Background", + "_name": "btnStartGame", "_objFlags": 0, "_parent": { - "__id__": 8 + "__id__": 2 }, - "_children": [], + "_children": [ + { + "__id__": 12 + } + ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 10 + "__id__": 14 + }, + { + "__id__": 15 } ], "_prefab": null, - "_id": "0dC9F1flJPZaNdPCm8Wqm7", + "_id": "53u7kWwblJmIT/CCeDqFRY", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -423,8 +471,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 28, - "height": 30 + "width": 240, + "height": 70 }, "_rotationX": 0, "_rotationY": 0, @@ -433,7 +481,7 @@ "_position": { "__type__": "cc.Vec2", "x": 0, - "y": 0 + "y": -200 }, "_skewX": 0, "_skewY": 0, @@ -442,49 +490,23 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Sprite", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 9 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "e7aba14b-f956-4480-b254-8d57832e273f" - }, - "_type": 0, - "_sizeMode": 1, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null - }, { "__type__": "cc.Node", - "_name": "checkmark", + "_name": "Label", "_objFlags": 0, "_parent": { - "__id__": 8 + "__id__": 11 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 12 + "__id__": 13 } ], "_prefab": null, - "_id": "bdet/vK1JEZ4Ud9sGUKNcj", + "_id": "0f7AY8yvhG2qXubDXkWgcJ", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -501,8 +523,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 32, - "height": 32 + "width": 240, + "height": 33 }, "_rotationX": 0, "_rotationY": 0, @@ -520,6 +542,28 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 12 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 24, + "_fontSize": 24, + "_lineHeight": 33, + "_enableWrapText": false, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "开始游戏", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 1 + }, { "__type__": "cc.Sprite", "_name": "", @@ -529,10 +573,10 @@ }, "_enabled": true, "_spriteFrame": { - "__uuid__": "1a32fc76-f0bd-4f66-980f-56929c0ca0b3" + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" }, - "_type": 0, - "_sizeMode": 2, + "_type": 1, + "_sizeMode": 0, "_fillType": 0, "_fillCenter": { "__type__": "cc.Vec2", @@ -541,25 +585,25 @@ }, "_fillStart": 0, "_fillRange": 0, - "_isTrimmedMode": false, + "_isTrimmedMode": true, "_srcBlendFactor": 770, "_dstBlendFactor": 771, "_atlas": null }, { - "__type__": "cc.Toggle", + "__type__": "cc.Button", "_name": "", "_objFlags": 0, "node": { - "__id__": 8 + "__id__": 11 }, "_enabled": true, - "transition": 3, + "transition": 2, "pressedColor": { "__type__": "cc.Color", - "r": 211, - "g": 211, - "b": 211, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "hoverColor": { @@ -576,70 +620,123 @@ "_N$enableAutoGrayEffect": false, "_N$normalColor": { "__type__": "cc.Color", - "r": 214, - "g": 214, - "b": 214, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_N$disabledColor": { "__type__": "cc.Color", - "r": 124, - "g": 124, - "b": 124, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, - "_N$normalSprite": null, - "_N$pressedSprite": null, - "pressedSprite": null, - "_N$hoverSprite": null, - "hoverSprite": null, - "_N$disabledSprite": null, - "_N$target": { - "__id__": 9 + "_N$normalSprite": { + "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" }, - "toggleGroup": { - "__id__": 14 + "_N$pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" }, - "checkMark": { - "__id__": 12 + "pressedSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" }, - "checkEvents": [], - "_N$isChecked": true - }, - { - "__type__": "cc.ToggleGroup", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 7 + "_N$hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" }, - "_enabled": true, - "allowSwitchOff": false + "hoverSprite": { + "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + }, + "_N$disabledSprite": { + "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + }, + "_N$target": { + "__id__": 11 + } }, { "__type__": "cc.Node", - "_name": "even", + "_name": "select", "_objFlags": 0, "_parent": { - "__id__": 7 + "__id__": 2 }, "_children": [ { - "__id__": 16 + "__id__": 17 }, { - "__id__": 18 + "__id__": 23 } ], "_tag": -1, "_active": true, "_components": [ + { + "__id__": 29 + } + ], + "_prefab": null, + "_id": "73sg1SjrNCZ7vi1Dluy3OE", + "_opacity": 255, + "_color": { + "__type__": "cc.Color", + "r": 255, + "g": 255, + "b": 255, + "a": 255 + }, + "_cascadeOpacityEnabled": true, + "_anchorPoint": { + "__type__": "cc.Vec2", + "x": 0.5, + "y": 0.5 + }, + "_contentSize": { + "__type__": "cc.Size", + "width": 640, + "height": 300 + }, + "_rotationX": 0, + "_rotationY": 0, + "_scaleX": 1, + "_scaleY": 1, + "_position": { + "__type__": "cc.Vec2", + "x": 0, + "y": 0 + }, + "_skewX": 0, + "_skewY": 0, + "_localZOrder": 0, + "_globalZOrder": 0, + "_opacityModifyRGB": false, + "groupIndex": 0 + }, + { + "__type__": "cc.Node", + "_name": "odd", + "_objFlags": 0, + "_parent": { + "__id__": 16 + }, + "_children": [ + { + "__id__": 18 + }, { "__id__": 20 } ], + "_tag": -1, + "_active": true, + "_components": [ + { + "__id__": 22 + } + ], "_prefab": null, - "_id": "2esMn4OXBN7oFRaFv2eKaV", + "_id": "d8G6iZMFlLSIApqA9yuyRY", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -656,8 +753,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 42, - "height": 28 + "width": 640, + "height": 92 }, "_rotationX": 0, "_rotationY": 0, @@ -665,8 +762,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": -60, - "y": -10 + "x": 0, + "y": 80 }, "_skewX": 0, "_skewY": 0, @@ -680,18 +777,18 @@ "_name": "Background", "_objFlags": 0, "_parent": { - "__id__": 15 + "__id__": 17 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 17 + "__id__": 19 } ], "_prefab": null, - "_id": "c0V6FtysNP7J3LlIJeTccM", + "_id": "cdfyKE1vpDpp/5kptrZF+G", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -708,8 +805,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 28, - "height": 30 + "width": 640, + "height": 92 }, "_rotationX": 0, "_rotationY": 0, @@ -732,11 +829,11 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 16 + "__id__": 18 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "e7aba14b-f956-4480-b254-8d57832e273f" + "__uuid__": "d40c133d-8f74-4167-bc0f-5759db62656c" }, "_type": 0, "_sizeMode": 1, @@ -758,18 +855,18 @@ "_name": "checkmark", "_objFlags": 0, "_parent": { - "__id__": 15 + "__id__": 17 }, "_children": [], "_tag": -1, - "_active": false, + "_active": true, "_components": [ { - "__id__": 19 + "__id__": 21 } ], "_prefab": null, - "_id": "6fYU3EpVdKZrjPcqE8Teqb", + "_id": "79pgLbIntLu76qHIrn9Dgk", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -786,8 +883,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 32, - "height": 32 + "width": 640, + "height": 92 }, "_rotationX": 0, "_rotationY": 0, @@ -810,11 +907,11 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 18 + "__id__": 20 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "1a32fc76-f0bd-4f66-980f-56929c0ca0b3" + "__uuid__": "84faf979-6331-42a5-b2f0-b880f65cfa78" }, "_type": 0, "_sizeMode": 2, @@ -836,7 +933,7 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 15 + "__id__": 17 }, "_enabled": true, "transition": 3, @@ -880,34 +977,39 @@ "hoverSprite": null, "_N$disabledSprite": null, "_N$target": { - "__id__": 16 - }, - "toggleGroup": { - "__id__": 14 + "__id__": 17 }, + "toggleGroup": null, "checkMark": { - "__id__": 19 + "__id__": 21 }, "checkEvents": [], - "_N$isChecked": false + "_N$isChecked": true }, { "__type__": "cc.Node", - "_name": "oddLabel", + "_name": "event", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 16 }, - "_children": [], + "_children": [ + { + "__id__": 24 + }, + { + "__id__": 26 + } + ], "_tag": -1, "_active": true, "_components": [ { - "__id__": 22 + "__id__": 28 } ], "_prefab": null, - "_id": "b7aWX8o5FCSaDNSiLH3OB5", + "_id": "10EX/QP8ZDKLGRWaHcX2KN", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -924,8 +1026,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 67, - "height": 25 + "width": 640, + "height": 92 }, "_rotationX": 0, "_rotationY": 0, @@ -933,8 +1035,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 25, - "y": 82 + "x": 0, + "y": -80 }, "_skewX": 0, "_skewY": 0, @@ -943,45 +1045,23 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 21 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 25, - "_fontSize": 25, - "_lineHeight": 25, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "属性A", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, { "__type__": "cc.Node", - "_name": "evenLabel", + "_name": "Background", "_objFlags": 0, "_parent": { - "__id__": 2 + "__id__": 23 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 24 + "__id__": 25 } ], "_prefab": null, - "_id": "7df9siKZ5GRY9PdThPeDM6", + "_id": "7e3y9RpGpKp4hpjNkCtSHH", "_opacity": 255, "_color": { "__type__": "cc.Color", @@ -998,8 +1078,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 67, - "height": 25 + "width": 640, + "height": 92 }, "_rotationX": 0, "_rotationY": 0, @@ -1007,8 +1087,8 @@ "_scaleY": 1, "_position": { "__type__": "cc.Vec2", - "x": 25, - "y": 22 + "x": 0, + "y": 0 }, "_skewX": 0, "_skewY": 0, @@ -1018,109 +1098,54 @@ "groupIndex": 0 }, { - "__type__": "cc.Label", + "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 23 + "__id__": 24 }, "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 25, - "_fontSize": 25, - "_lineHeight": 25, - "_enableWrapText": true, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "属性B", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 0 - }, - { - "__type__": "cc.Node", - "_name": "startMatch", - "_objFlags": 0, - "_parent": { - "__id__": 2 - }, - "_children": [ - { - "__id__": 26 - } - ], - "_tag": -1, - "_active": true, - "_components": [ - { - "__id__": 28 - }, - { - "__id__": 29 - } - ], - "_prefab": null, - "_id": "55K83DMFpLMq5RxAQEhV/7", - "_opacity": 255, - "_color": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_cascadeOpacityEnabled": true, - "_anchorPoint": { - "__type__": "cc.Vec2", - "x": 0.5, - "y": 0.5 - }, - "_contentSize": { - "__type__": "cc.Size", - "width": 100, - "height": 40 + "_spriteFrame": { + "__uuid__": "d40c133d-8f74-4167-bc0f-5759db62656c" }, - "_rotationX": 0, - "_rotationY": 0, - "_scaleX": 1, - "_scaleY": 1, - "_position": { + "_type": 0, + "_sizeMode": 1, + "_fillType": 0, + "_fillCenter": { "__type__": "cc.Vec2", "x": 0, - "y": -110 + "y": 0 }, - "_skewX": 0, - "_skewY": 0, - "_localZOrder": 0, - "_globalZOrder": 0, - "_opacityModifyRGB": false, - "groupIndex": 0 + "_fillStart": 0, + "_fillRange": 0, + "_isTrimmedMode": true, + "_srcBlendFactor": 770, + "_dstBlendFactor": 771, + "_atlas": null }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "checkmark", "_objFlags": 0, "_parent": { - "__id__": 25 + "__id__": 23 }, "_children": [], "_tag": -1, - "_active": true, + "_active": false, "_components": [ { "__id__": 27 } ], "_prefab": null, - "_id": "67BizFx3JIfrtfyt0XIcDY", + "_id": "defVnXfjZNtIl4bqC15nIV", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1131,8 +1156,8 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, - "height": 40 + "width": 640, + "height": 92 }, "_rotationX": 0, "_rotationY": 0, @@ -1150,41 +1175,19 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, - { - "__type__": "cc.Label", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 26 - }, - "_enabled": true, - "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, - "_lineHeight": 40, - "_enableWrapText": false, - "_N$file": null, - "_isSystemFontUsed": true, - "_spacingX": 0, - "_N$string": "开始匹配", - "_N$horizontalAlign": 1, - "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, { "__type__": "cc.Sprite", "_name": "", "_objFlags": 0, "node": { - "__id__": 25 + "__id__": 26 }, "_enabled": true, "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" + "__uuid__": "84faf979-6331-42a5-b2f0-b880f65cfa78" }, - "_type": 1, - "_sizeMode": 0, + "_type": 0, + "_sizeMode": 2, "_fillType": 0, "_fillCenter": { "__type__": "cc.Vec2", @@ -1193,25 +1196,25 @@ }, "_fillStart": 0, "_fillRange": 0, - "_isTrimmedMode": true, + "_isTrimmedMode": false, "_srcBlendFactor": 770, "_dstBlendFactor": 771, "_atlas": null }, { - "__type__": "cc.Button", + "__type__": "cc.Toggle", "_name": "", "_objFlags": 0, "node": { - "__id__": 25 + "__id__": 23 }, "_enabled": true, - "transition": 2, + "transition": 3, "pressedColor": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 211, + "g": 211, + "b": 211, "a": 255 }, "hoverColor": { @@ -1228,70 +1231,67 @@ "_N$enableAutoGrayEffect": false, "_N$normalColor": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 214, + "g": 214, + "b": 214, "a": 255 }, "_N$disabledColor": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 124, + "g": 124, + "b": 124, "a": 255 }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "_N$normalSprite": null, + "_N$pressedSprite": null, + "pressedSprite": null, + "_N$hoverSprite": null, + "hoverSprite": null, + "_N$disabledSprite": null, + "_N$target": { + "__id__": 23 }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" + "toggleGroup": null, + "checkMark": { + "__id__": 27 }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" + "checkEvents": [], + "_N$isChecked": false + }, + { + "__type__": "cc.ToggleContainer", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 16 }, - "_N$target": { - "__id__": 25 - } + "_enabled": true, + "allowSwitchOff": false }, { "__type__": "cc.Node", - "_name": "returnLobby", + "_name": "New Label", "_objFlags": 0, "_parent": { "__id__": 2 }, - "_children": [ - { - "__id__": 31 - } - ], + "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 33 - }, - { - "__id__": 34 + "__id__": 31 } ], "_prefab": null, - "_id": "0fy+DjWVxBo5V13g1uQnVM", + "_id": "5aDlx5i6xGnIjRQzhOq7ap", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, + "r": 0, + "g": 193, + "b": 224, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1302,7 +1302,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, + "width": 76, "height": 40 }, "_rotationX": 0, @@ -1312,7 +1312,7 @@ "_position": { "__type__": "cc.Vec2", "x": 0, - "y": -170 + "y": 80 }, "_skewX": 0, "_skewY": 0, @@ -1321,29 +1321,51 @@ "_opacityModifyRGB": false, "groupIndex": 0 }, + { + "__type__": "cc.Label", + "_name": "", + "_objFlags": 0, + "node": { + "__id__": 30 + }, + "_enabled": true, + "_useOriginalSize": false, + "_actualFontSize": 28, + "_fontSize": 28, + "_lineHeight": 40, + "_enableWrapText": true, + "_N$file": null, + "_isSystemFontUsed": true, + "_spacingX": 0, + "_N$string": "属性A", + "_N$horizontalAlign": 1, + "_N$verticalAlign": 1, + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 + }, { "__type__": "cc.Node", - "_name": "Label", + "_name": "New Label", "_objFlags": 0, "_parent": { - "__id__": 30 + "__id__": 2 }, "_children": [], "_tag": -1, "_active": true, "_components": [ { - "__id__": 32 + "__id__": 33 } ], "_prefab": null, - "_id": "0bG2/HKndOrZZb1QT4cf2u", + "_id": "213Pk/099DbZjPDBiVtc7T", "_opacity": 255, "_color": { "__type__": "cc.Color", - "r": 0, - "g": 0, - "b": 0, + "r": 255, + "g": 255, + "b": 255, "a": 255 }, "_cascadeOpacityEnabled": true, @@ -1354,7 +1376,7 @@ }, "_contentSize": { "__type__": "cc.Size", - "width": 100, + "width": 75, "height": 40 }, "_rotationX": 0, @@ -1364,7 +1386,7 @@ "_position": { "__type__": "cc.Vec2", "x": 0, - "y": 0 + "y": -80 }, "_skewX": 0, "_skewY": 0, @@ -1378,112 +1400,22 @@ "_name": "", "_objFlags": 0, "node": { - "__id__": 31 + "__id__": 32 }, "_enabled": true, "_useOriginalSize": false, - "_actualFontSize": 20, - "_fontSize": 20, + "_actualFontSize": 28, + "_fontSize": 28, "_lineHeight": 40, - "_enableWrapText": false, + "_enableWrapText": true, "_N$file": null, "_isSystemFontUsed": true, "_spacingX": 0, - "_N$string": "返回", + "_N$string": "属性B", "_N$horizontalAlign": 1, "_N$verticalAlign": 1, - "_N$fontFamily": "Arial", - "_N$overflow": 1 - }, - { - "__type__": "cc.Sprite", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 30 - }, - "_enabled": true, - "_spriteFrame": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_type": 1, - "_sizeMode": 0, - "_fillType": 0, - "_fillCenter": { - "__type__": "cc.Vec2", - "x": 0, - "y": 0 - }, - "_fillStart": 0, - "_fillRange": 0, - "_isTrimmedMode": true, - "_srcBlendFactor": 770, - "_dstBlendFactor": 771, - "_atlas": null - }, - { - "__type__": "cc.Button", - "_name": "", - "_objFlags": 0, - "node": { - "__id__": 30 - }, - "_enabled": true, - "transition": 2, - "pressedColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "hoverColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "duration": 0.1, - "zoomScale": 1.2, - "clickEvents": [], - "_N$interactable": true, - "_N$enableAutoGrayEffect": false, - "_N$normalColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$disabledColor": { - "__type__": "cc.Color", - "r": 255, - "g": 255, - "b": 255, - "a": 255 - }, - "_N$normalSprite": { - "__uuid__": "f0048c10-f03e-4c97-b9d3-3506e1d58952" - }, - "_N$pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "pressedSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "hoverSprite": { - "__uuid__": "e9ec654c-97a2-4787-9325-e6a10375219a" - }, - "_N$disabledSprite": { - "__uuid__": "29158224-f8dd-4661-a796-1ffab537140e" - }, - "_N$target": { - "__id__": 30 - } + "_N$fontFamily": "PingFangSC", + "_N$overflow": 0 }, { "__type__": "cc.Canvas", @@ -1495,11 +1427,11 @@ "_enabled": true, "_designResolution": { "__type__": "cc.Size", - "width": 960, - "height": 640 + "width": 1280, + "height": 720 }, - "_fitWidth": false, - "_fitHeight": true + "_fitWidth": true, + "_fitHeight": false }, { "__type__": "5c130uVIWlHa64+tAq2vxDd", @@ -1510,19 +1442,20 @@ }, "_enabled": true, "odd": { - "__id__": 13 + "__id__": 22 }, "even": { - "__id__": 20 + "__id__": 28 }, "startMatch": { - "__id__": 25 + "__id__": 11 }, "returnLobby": { - "__id__": 30 + "__id__": 5 }, - "labelInfoSelfDefineMatch": { - "__id__": 6 + "labelInfoSelfDefineMatch": null, + "nickName": { + "__id__": 10 } } ] \ No newline at end of file diff --git a/assets/scene/SelfDefMatch.fire.meta b/assets/scene/SelfDefMatch.fire.meta new file mode 100644 index 0000000..518fdab --- /dev/null +++ b/assets/scene/SelfDefMatch.fire.meta @@ -0,0 +1,7 @@ +{ + "ver": "1.0.0", + "uuid": "345fc359-0b83-4e07-88d8-b053c7121479", + "asyncLoadAssets": false, + "autoReleaseAssets": false, + "subMetas": {} +} \ No newline at end of file diff --git a/assets/game.fire.meta b/assets/scene/game.fire.meta similarity index 100% rename from assets/game.fire.meta rename to assets/scene/game.fire.meta diff --git a/assets/scripts/CreateRoom.js b/assets/scripts/CreateRoom.js index 48a5c2a..22ecf67 100644 --- a/assets/scripts/CreateRoom.js +++ b/assets/scripts/CreateRoom.js @@ -10,19 +10,19 @@ cc.Class({ default: null, type: cc.Label }, - labelUserID1: { + labelUserName: { default: null, type: cc.Label }, - labelUserID2: { + labelUserName2: { default: null, type: cc.Label }, - labelUserID3: { + labelUserName3: { default: null, type: cc.Label }, - labelInfo: { + nickName: { default: null, type: cc.Label }, @@ -36,32 +36,47 @@ cc.Class({ type: cc.Label }, userList :[], + labelUserID2:cc.Label, + labelUserID3:cc.Label, + ownerLogo:cc.Node, + ownerLogo2:cc.Node, + ownerLogo3:cc.Node, + userIDfontSize:26, }, onLoad () { - this.nameViewList = [this.labelUserID2,this.labelUserID3]; + this.nameViewList = [this.labelUserName2,this.labelUserName3]; + this.userIDViewList = [this.labelUserID2,this.labelUserID3]; + this.userOwnewLogoList = [this.ownerLogo2,this.ownerLogo3]; GLB.number1 = ""; GLB.number2 = ""; GLB.number3 = ""; var self = this; + self.nickName.string = '用户ID:'+GLB.userID; // roomID的全局赋值要慎重使用,离开房间记得置空 if (GLB.roomID != "") { engine.prototype.getRoomDetail(GLB.roomID); } this.initEvent(self); this.kickPlayer2.on(cc.Node.EventType.TOUCH_END, function(event){ - var userID = self.kickPlayerName(self.labelUserID2.string); - if (userID != undefined) { - engine.prototype.kickPlayer(userID,self.labelUserID2.string); - self.labelUserID2.string = ""; + // var userID = self.kickPlayerName(self.labelUserID2.string); + var userID = self.labelUserID2.string; + if (userID != undefined && userID != 2) { + engine.prototype.kickPlayer(userID,self.labelUserName2.string); + self.labelUserID2.string = 2; + self.labelUserID2.fontSize = 80; + self.labelUserName2.string = "待加入"; } }); this.kickPlayer3.on(cc.Node.EventType.TOUCH_END, function(event){ - var userID = self.kickPlayerName(self.labelUserID3.string); - if (userID != undefined) { - engine.prototype.kickPlayer(userID,self.labelUserID3.string); - self.labelUserID3.string = ""; + // var userID = self.kickPlayerName(self.labelUserID3.string); + var userID = self.labelUserID3.string; + if (userID != undefined && userID != 3) { + engine.prototype.kickPlayer(userID,self.labelUserName3.string); + self.labelUserID3.string = 3; + self.labelUserID3.fontSize = 80; + self.labelUserName3.string = "待加入"; } }); this.leaveRoom.on(cc.Node.EventType.TOUCH_END, function(event){ @@ -76,7 +91,7 @@ cc.Class({ engine.prototype.sendEventEx(JSON.stringify(event)); engine.prototype.joinOver(); } else { - self.labelLog('房间人数小于' + GLB.MAX_PLAYER_COUNT); + // self.labelLog('房间人数小于' + GLB.MAX_PLAYER_COUNT); } }); this.seleButton.on(cc.Node.EventType.TOUCH_END, function(event){ @@ -112,44 +127,47 @@ cc.Class({ * @param event */ onEvent :function (event) { + var eventData = event.detail; + if (eventData == undefined) { + eventData = event; + } switch(event.type) { case msg.MATCHVS_JOIN_ROOM_NOTIFY: - this.userList.push(event.detail.roomUserInfo); - this.initUserView(event.detail.roomUserInfo.userProfile); + this.userList.push(eventData.roomUserInfo); + this.initUserView(eventData.roomUserInfo.userProfile,eventData.roomUserInfo.userID,0); break; case msg.MATCHVS_KICK_PLAYER: - this.removeView(event.detail.kickPlayerRsp); + this.removeView(eventData.kickPlayerRsp); break; case msg.MATCHVS_KICK_PLAYER_NOTIFY: - this.removeView(event.detail.kickPlayerNotify); + this.removeView(eventData.kickPlayerNotify); break; case msg.MATCHVS_SET_ROOM_PROPETY: - this.setRoomPropertyResponse(event.detail.rsp); + this.setRoomPropertyResponse(eventData.rsp); break; case msg.MATCHVS_SET_ROOM_PROPETY_NOTIFY: - this.setRoomPropertyResponse(event.detail.rsp); + this.setRoomPropertyResponse(eventData.rsp); break; case msg.MATCHVS_ROOM_DETAIL: - this.joinRoom(event.detail.rsp); - for (var i in event.detail.rsp.userInfos) { - if (GLB.userID != event.detail.rsp.userInfos[i].userId) { - this.initUserView(event.detail.rsp.userInfos[i].userProfile); - this.userList.push(event.detail.rsp.userInfos[i]); + this.joinRoom(eventData.rsp); + for (var i in eventData.rsp.userInfos) { + if (GLB.userID != eventData.rsp.userInfos[i].userID) { + this.initUserView(eventData.rsp.userInfos[i].userProfile,eventData.rsp.userInfos[i].userID,eventData.rsp.owner); + this.userList.push(eventData.rsp.userInfos[i]); } } break; case msg.MATCHVS_LEAVE_ROOM_NOTIFY: - this.removeView(event.detail.leaveRoomInfo) + this.removeView(eventData.leaveRoomInfo) break; case msg.MATCHVS_SEND_EVENT_NOTIFY: - var data = JSON.parse(event.detail.eventInfo.cpProto); + var data = JSON.parse(eventData.eventInfo.cpProto); if (data.action == msg.EVENT_GAME_START) { this.startGame(); } break; case msg.MATCHVS_ERROE_MSG: - this.labelLog("[Err]errCode:"+event.detail.errorCode+" errMsg:"+event.detail.errorMsg); - cc.director.loadScene('login'); + cc.director.loadScene('Login'); break; } }, @@ -166,14 +184,14 @@ cc.Class({ } }, - kickPlayerName :function (name) { - for (var i in this.userList) { - var obj = JSON.parse(this.userList[i].userProfile); - if (obj.name == name) { - return this.userList[i].userId - } - } - }, + // kickPlayerName :function (name) { + // for (var i in this.userList) { + // var obj = JSON.parse(this.userList[i].userProfile); + // if (obj.name == name) { + // return this.userList[i].userId + // } + // } + // }, /** @@ -183,19 +201,19 @@ cc.Class({ joinRoom: function (rsp) { if (rsp.owner === GLB.userID) { GLB.isRoomOwner = true; + this.ownerLogo.active = true; } else { GLB.isRoomOwner = false; + this.ownerLogo.active = false; } this.buttonIsShow(GLB.isRoomOwner); if (GLB.roomID != "") { - this.labelLog('房间号: ' + GLB.roomID); this.labelMyRoomID.string = GLB.roomID; } else { - this.labelLog('房间号: ' + rsp.roomID); this.labelMyRoomID.string = rsp.roomID; GLB.roomID = rsp.roomID; } - this.labelUserID1.string = GLB.name; + this.labelUserName.string = GLB.name; GLB.mapType = rsp.roomProperty; this.setRoomPropertyResponse(rsp); }, @@ -204,11 +222,16 @@ cc.Class({ * 展示玩家信息 * @param userList */ - initUserView :function(userProfile){ + initUserView :function(userProfile,userID,owner){ for(var i = 0; i < this.nameViewList.length; i++) { var info = JSON.parse(userProfile); - if (this.nameViewList[i].string === "") { + if (this.nameViewList[i].string === "待加入") { + this.userIDViewList[i].string = userID; + this.userIDViewList[i].fontSize = this.userIDfontSize; this.nameViewList[i].string = info.name; + if(userID === owner) { + this.userOwnewLogoList[i].active = true; + } return; } } @@ -219,30 +242,39 @@ cc.Class({ * @param userID */ removeView:function (info) { - var userID ; - if (info.userID == undefined) { - userID = info.userId; - } else { - userID = info.userID; - } + var userID = info.userID; + // if (info.userID == undefined) { + // userID = info.userId; + // } else { + // userID = ; + // } for(var i = 0; i < this.userList.length;i++ ) { if(userID == this.userList[i].userId) { this.userList.splice(i,1); + this.nameViewList[i].string = "待加入"; + this.userIDViewList[i].string = i+2; + this.userIDViewList[i].fontSize = 80; + this.userOwnewLogoList[i].active = false; } } - if (info.cpProto != undefined) { - console.log(JSON.parse(info.cpProto)); - var name = JSON.parse(info.cpProto).name; - for(var a = 0; a < this.nameViewList.length; a++) { - if(name == this.nameViewList[a].string) { - this.nameViewList[a].string = ""; - } - } - if(name == GLB.name) { - this.leaveRoom1(); - } + if (userID== GLB.userID) { + this.leaveRoom1(); } + // if (info.cpProto != undefined) { + // console.log(JSON.parse(info.cpProto)); + // var name = JSON.parse(info.cpProto).name; + // for(var a = 0; a < this.nameViewList.length; a++) { + // if(name == this.nameViewList[a].string) { + // if(info) + // + // } + // } + // if(name == GLB.name) { + // this.leaveRoom1(); + // } + // } if (info.owner === GLB.userID) { + this.ownerLogo.active = true; GLB.isRoomOwner = true; this.buttonIsShow(true); } @@ -294,17 +326,17 @@ cc.Class({ leaveRoom1 :function () { GLB.roomID = "" - cc.director.loadScene('lobby'); + cc.director.loadScene('Lobby'); }, startGame: function () { - this.labelLog('游戏即将开始') - cc.director.loadScene('game') + // this.labelLog('游戏即将开始') + cc.director.loadScene('Game') }, - labelLog: function (info) { - this.labelInfo.string += '\n' + info; - }, + // labelLog: function (info) { + // this.labelInfo.string += '\n' + info; + // }, }); diff --git a/assets/scripts/Game.js b/assets/scripts/Game.js index a860867..ec2b114 100644 --- a/assets/scripts/Game.js +++ b/assets/scripts/Game.js @@ -85,6 +85,7 @@ cc.Class({ this.timer = 0; var myScorce = {userID:GLB.userID,Score:this.score}; this.userScores.push(myScorce); + this.scoreDisplays0.string = myScorce.userID + ":"+myScorce.Score ; this.starDuration = this.maxStarDuration - this.minStarDuration; this.gameTime = 9999; this.roomidLabel.string = "房间号:" + GLB.roomID; @@ -129,7 +130,7 @@ cc.Class({ } GLB.isGameOver = true; mvs.engine.leaveRoom(""); - cc.director.loadScene('lobby'); + cc.director.loadScene('Lobby'); }); @@ -162,23 +163,29 @@ cc.Class({ this.node.on(msg.MATCHVS_FRAME_UPDATE,this.onEvent ,this); this.node.on(msg.PLAYER_POSINTON,this.onEvent , this); this.node.on(msg.MATCHVS_LEAVE_ROOM_NOTIFY,this.onEvent, this); + this.node.on(msg.MATCHVS_LEAVE_ROOM,this.onEvent ,this); this.node.on(msg.MATCHVS_NETWORK_STATE_NOTIFY,this.onEvent,this); this.node.on(msg.MATCHVS_SET_FRAME_SYNC_RSP,this.setFrameSyncResponse, this); }, onEvent :function (event) { + var eventData = event.detail; + if (eventData == undefined) { + eventData = event; + } switch(event.type) { case msg.MATCHVS_ROOM_DETAIL: - for (var i = 0; i this.gameTime) - return this.gameOver(); + if(!GLB.isGameOver) { + this.gameOver(); + } this.timer += dt }, @@ -283,7 +294,6 @@ cc.Class({ this.updatePlayerMoveDirection(event); } else if (event.action === GLB.EVENT_GAIN_SCORE) { this.refreshScore(event); - console.log('得分'); } else if (event.action === GLB.GAME_RECONNECT) { this.reconnection(event.cpProto); @@ -340,7 +350,7 @@ cc.Class({ this.newStar = cc.instantiate(this.starPrefab) this.node.addChild(this.newStar) - this.newStar.setPosition(cc.p(position.x, position.y)) + this.newStar.setPosition(cc.v2(position.x, position.y)) this.newStar.getComponent('Star').game = this; this.newStar.active = true; this.timer = 0 @@ -351,7 +361,8 @@ cc.Class({ * 发送创建星星事件 */ spawnNewStar: function () { - if (!GLB.isRoomOwner) return; // 只有房主可创建星星 + if (!GLB.isRoomOwner) + return; // 只有房主可创建星星 var event = { action: GLB.EVENT_NEW_START, @@ -367,9 +378,9 @@ cc.Class({ // 随机返回'新的星星'的位置 getNewStarPosition: function () { - var randX = cc.randomMinus1To1() * this.starMaxX; + var randX = this.randomMinus1To1() * this.starMaxX; var randY = -90; - return cc.p(randX, randY) + return cc.v2(randX, randY) }, @@ -378,7 +389,6 @@ cc.Class({ if (event != undefined) { for (var i = 0; i < this.userScores.length;i++) { if (event.userID == this.userScores[i].userID) { - console.log(event.userID+"得分了"); this.userScores[i].Score ++; this.scoreDisplays[i].string = this.userScores[i].userID + ':' + this.userScores[i].Score; } @@ -393,10 +403,11 @@ cc.Class({ gameOver: function () { GLB.isGameOver = true; for (var i = 0, l = this.players.length; i < l; i++) { - this.players[i].stopAllActions() + this.players[i].stopAllActions(); + this.players[i].destroy(); } mvs.engine.leaveRoom(""); - cc.director.loadScene('result'); + cc.director.loadScene('Result'); }, labelLog: function (info) { @@ -435,6 +446,7 @@ cc.Class({ this.node.off(msg.MATCHVS_FRAME_UPDATE,this.onEvent ,this); this.node.off(msg.PLAYER_POSINTON,this.onEvent , this); this.node.off(msg.MATCHVS_LEAVE_ROOM_NOTIFY,this.onEvent, this); + this.node.off(msg.MATCHVS_LEAVE_ROOM,this.onEvent ,this); this.node.off(msg.MATCHVS_NETWORK_STATE_NOTIFY,this.onEvent,this); this.node.off(msg.MATCHVS_SET_FRAME_SYNC_RSP,this.setFrameSyncResponse, this); }, @@ -446,5 +458,9 @@ cc.Class({ } GLB.syncFrame = false; GLB.isGameOver = true; + }, + + randomMinus1To1 :function() { + return 2 * (Math.random() - .5); } }); diff --git a/assets/scripts/Glb.js b/assets/scripts/Glb.js index c496f85..1e2c285 100644 --- a/assets/scripts/Glb.js +++ b/assets/scripts/Glb.js @@ -9,8 +9,8 @@ var obj = { EVENT_PLAYER_POSINTON_CHANGED: "playerPosition", GAME_RECONNECT:"Reconnect", - channel: 'MatchVS', - platform: 'release', + channel: 'Matchvs', + platform: 'alpha', gameID: 200978, gameVersion: 1, appKey: '4fd4a67c10e84e259a2c3c417b9114f4', @@ -34,21 +34,21 @@ var obj = { syncFrame: false, FRAME_RATE: 20, roomID: 0, - playertime: 180, + playertime: 30, first: null, second: null, third: null, isGameOver: false, NEW_STAR_POSITION : 0, - scoreMap: [{"uid":0,score:0},{"uid":0,score:0},{"uid":0,score:0}], + // scoreMap: [{"uid":0,score:0},{"uid":0,score:0},{"uid":0,score:0}], number1: "", number2: "", number3: "", - + ownew:0, //只为做分数展示时判断使用 mapType: "", - lastErrMsg: "2018-05-17", + // lastErrMsg: "2018-05-17", diff --git a/assets/scripts/Independent.js b/assets/scripts/Independent.js index f8dc123..5b43fc0 100644 --- a/assets/scripts/Independent.js +++ b/assets/scripts/Independent.js @@ -31,7 +31,7 @@ cc.Class({ selt.premiseInit(endPoint,gameID); }); this.backButton.on(cc.Node.EventType.TOUCH_END,function (event) { - cc.director.loadScene('login'); + cc.director.loadScene('Login'); }) }, /** @@ -64,6 +64,13 @@ cc.Class({ }, onEvent(event) { + var eventData; + try{ + eventData = event.detail; + } catch(error){ + console.warn(error.message); + eventData = event; + } switch (event.type){ case msg.MATCHVS_INIT: var token = this.tokenEditBox.getComponent(cc.EditBox).string; @@ -75,7 +82,7 @@ cc.Class({ } break; case msg.MATCHVS_LOGIN: - cc.director.loadScene("lobby"); + cc.director.loadScene("Lobby"); break; } }, diff --git a/assets/scripts/JoinCertainRoom.js b/assets/scripts/JoinCertainRoom.js index a02a09a..8f6357c 100644 --- a/assets/scripts/JoinCertainRoom.js +++ b/assets/scripts/JoinCertainRoom.js @@ -11,34 +11,38 @@ cc.Class({ match: cc.Node, back: cc.Node, + nickName:cc.Label, roomID: { default: null, type: cc.EditBox }, - labelInfo: { + errorHint: { default: null, type: cc.Label - } + } }, - labelLog: function (info) { - this.labelInfo.string += '\n' + info; - }, onLoad () { var self = this; this.initEvent(self); + self.nickName.string = '用户ID:'+GLB.userID; this.back.on(cc.Node.EventType.TOUCH_END, function(event){ - cc.director.loadScene("lobby"); + cc.director.loadScene("Lobby"); }); this.match.on(cc.Node.EventType.TOUCH_END, function(event){ var roomidTmp = self.roomID.string; if (roomidTmp !== null && roomidTmp !== "") { - self.labelLog("开始加入指定房间, roomid:" + roomidTmp); - engine.prototype.joinRoom(roomidTmp, "china"); - // cc.director.loadScene("match"); + var result = engine.prototype.joinRoom(roomidTmp, "Matchvs"); + if (result === 0) { + self.errorHint.node.active = false; + } else { + self.errorHint.node.active = true; + self.errorHint.string = "没有查找到此房间,请重新输入" + } } else { - self.labelLog("房间ID为空,请输入指定房间号"); + self.errorHint.node.active = true; + self.errorHint.string = "房间号不能为空,请输入房间号在进行加入" } }); }, @@ -58,11 +62,10 @@ cc.Class({ */ onEvent:function (event) { if (event.type == msg.MATCHVS_ERROE_MSG) { - this.labelLog("[Err]errCode:"+event.detail.errorCode+" errMsg:"+event.detail.errorMsg); - cc.director.loadScene('login'); + cc.director.loadScene('Login'); } else if (event.type == msg.MATCHVS_JOIN_ROOM_RSP) { GLB.roomID = this.roomID.string; - cc.director.loadScene("createRoom"); + cc.director.loadScene("Matchvs"); } }, @@ -71,6 +74,7 @@ cc.Class({ */ removeEvent:function () { this.node.off(msg.MATCHVS_ERROE_MSG, this.onEvent, this); + this.node.off(msg.MATCHVS_JOIN_ROOM_RSP, this.onEvent, this); }, diff --git a/assets/scripts/Lobby.js b/assets/scripts/Lobby.js index c26f014..ca62d12 100644 --- a/assets/scripts/Lobby.js +++ b/assets/scripts/Lobby.js @@ -17,16 +17,6 @@ cc.Class({ createRoom: cc.Node, returnLogin: cc.Node, buttonSyncFrame: cc.Node, - labelInfo: { - default: null, - type: cc.Label - }, - - errorMsg: { - default: null, - type: cc.Label - }, - nickName: { default:null, @@ -41,7 +31,7 @@ cc.Class({ onLoad:function () { var self = this; this.initEvent(self); - this.nickName.string = GLB.name; + this.nickName.string = "用户ID:"+ GLB.name; console.log('avatar url', GLB.avatar); if (GLB.isWX) { let image = wx.createImage(); @@ -70,29 +60,29 @@ cc.Class({ this.returnLogin.on(cc.Node.EventType.TOUCH_END, function(event){ engine.prototype.logout(); engine.prototype.uninit(); - cc.director.loadScene('login'); + cc.director.loadScene('Login'); }); // 随机匹配 this.randomMatch.on(cc.Node.EventType.TOUCH_END, function(event){ GLB.matchType = GLB.RANDOM_MATCH; // 修改匹配方式为随机匹配 - self.labelLog('开始随机匹配'); - cc.director.loadScene('match'); + // self.labelLog('开始随机匹配'); + cc.director.loadScene('Match'); }); // 自定义属性匹配 this.selfDefMatch.on(cc.Node.EventType.TOUCH_END, function(event){ - cc.director.loadScene("selfDefMatch"); + cc.director.loadScene("SelfDefMatch"); }); // 查看房间列表 this.roomList.on(cc.Node.EventType.TOUCH_END, function(event){ - cc.director.loadScene("roomList"); + cc.director.loadScene("RoomList"); }); // 加入指定房间 this.joinCertainRoom.on(cc.Node.EventType.TOUCH_END, function(event){ - cc.director.loadScene("joinCertainRoom"); + cc.director.loadScene("JoinCertainRoom"); }); // 创建房间 @@ -104,15 +94,13 @@ cc.Class({ create.canWatch = 0; create.visibility = 1; create.roomProperty = '白天模式'; - engine.prototype.createRoom(create,"china"); + engine.prototype.createRoom(create,"Matchvs"); }); this.buttonSyncFrame.on(cc.Node.EventType.TOUCH_END, function(event){ GLB.syncFrame = true; - self.labelLog('准备开启帧同步'); GLB.matchType = GLB.RANDOM_MATCH; // 修改匹配方式为随机匹配 - self.labelLog('开始随机匹配'); - cc.director.loadScene('match'); + cc.director.loadScene('Match'); }); }, @@ -131,12 +119,15 @@ cc.Class({ * @param event */ onEvent:function (event) { + var eventData = event.detail; + if (eventData == undefined) { + eventData = event; + } if (event.type == msg.MATCHVS_ERROE_MSG) { - this.labelLog("[Err]errCode:"+event.detail.errorCode+" errMsg:"+event.detail.errorMsg); - cc.director.loadScene('login'); + cc.director.loadScene('Login'); } else if (event.type == msg.MATCHVS_CREATE_ROOM) { - GLB.roomID = event.detail.rsp.roomID; - cc.director.loadScene("createRoom"); + GLB.roomID = eventData.rsp.roomID; + cc.director.loadScene("CreateRoom"); } }, @@ -149,11 +140,6 @@ cc.Class({ }, - labelLog: function (info) { - this.labelInfo.string += '\n' + info; - }, - - /** * 生命周期,页面销毁 */ diff --git a/assets/scripts/Login.js b/assets/scripts/Login.js index 9ed2832..028f5a5 100644 --- a/assets/scripts/Login.js +++ b/assets/scripts/Login.js @@ -13,7 +13,6 @@ cc.Class({ gameIdInput: cc.Node, appKeyInput: cc.Node, secret: cc.Node, - alphaRadio: cc.Node, confirm: cc.Node, clear: cc.Node, independent: cc.Node, @@ -30,7 +29,6 @@ cc.Class({ onLoad: function () { var self = this; this.initEvent(self); - this.alphaRadio.getComponent(cc.Toggle).isChecked = true; this.confirm.on(cc.Node.EventType.TOUCH_END, function (event) { // 获取用户输入的参数 if (Number(self.gameIdInput.getComponent(cc.EditBox).string) != 0) { @@ -42,22 +40,9 @@ cc.Class({ if (self.secret.getComponent(cc.EditBox).string != "") { GLB.secret = self.secret.getComponent(cc.EditBox).string; } - var alpha = self.alphaRadio.getComponent(cc.Toggle).isChecked; - if (alpha === true) { - GLB.platform = 'alpha'; - } else { - GLB.platform = 'release'; - } - console.log('platform:'+GLB.platform); engine.prototype.init(GLB.channel,GLB.platform,GLB.gameID); }); this.clear.on(cc.Node.EventType.TOUCH_END, function (event) { - self.gameIdInput.getComponent(cc.EditBox).string = ''; - self.gameIdInput.getComponent(cc.EditBox).placeholder = '请输入gameID'; - self.appKeyInput.getComponent(cc.EditBox).string = ''; - self.appKeyInput.getComponent(cc.EditBox).placeholder = '请输入gameKey'; - self.secret.getComponent(cc.EditBox).string = ''; - self.secret.getComponent(cc.EditBox).placeholder = '请输入secret'; if (LocalStore_Clear) { LocalStore_Clear() } @@ -80,7 +65,6 @@ cc.Class({ this.node.on(msg.MATCHVS_REGISTER_USER,this.onEvent,this); this.node.on(msg.MATCHVS_LOGIN,this.onEvent,this); this.node.on(msg.MATCHVS_WX_BINDING,this.onEvent,this); - this.node.on(msg.MATCHVS_ROOM_DETAIL,this.onEvent,this); }, @@ -89,47 +73,45 @@ cc.Class({ * @param event */ onEvent:function (event) { + var eventData = event.detail; + if (eventData == undefined) { + eventData = event; + } switch (event.type){ case msg.MATCHVS_INIT: this.labelLog('初始化成功'); this.getUserFromWeChat(this); break; case msg.MATCHVS_REGISTER_USER: - userInfo = event.detail.msg; - console.log(userInfo); - this.login(userInfo.id,userInfo.token); + this.login(eventData.userInfo.id,eventData.userInfo.token); break; case msg.MATCHVS_LOGIN: - var MsLoginRsp = event.detail.MsLoginRsp; - if (MsLoginRsp.roomID != null && MsLoginRsp.roomID !== '0') { - console.log("开始重连"+ MsLoginRsp.roomID); + if (eventData.MsLoginRsp.roomID != null && eventData.MsLoginRsp.roomID !== '0') { + console.log("开始重连"+ eventData.MsLoginRsp.roomID); engine.prototype.reconnect(); } else { - cc.director.loadScene("lobby"); + cc.director.loadScene("Lobby"); } break; case msg.MATCHVS_RE_CONNECT: - var reConnect = event.detail.roomUserInfoList; - engine.prototype.getRoomDetail(reConnect.roomID); - GLB.roomID = reConnect.roomID; - break; - case msg.MATCHVS_ERROE_MSG: - this.labelLog("[Err]errCode:"+event.detail.errorCode+" errMsg:"+event.detail.errorMsg); - break; - case msg.MATCHVS_WX_BINDING: - engine.prototype.login(event.detail.val.userid,event.detail.val.token); - break; - case msg.MATCHVS_ROOM_DETAIL: - if (event.detail.rsp.state == 1) { - cc.director.loadScene('createRoom'); - } else { - cc.director.loadScene("game"); - } - if (event.detail.rsp.owner == GLB.userID) { + GLB.roomID = eventData.roomUserInfoList.roomID; + if (eventData.roomUserInfoList.owner == GLB.userID) { GLB.isRoomOwner = true; } else { GLB.isRoomOwner = false; } + if (eventData.roomUserInfoList.state == 1) { + cc.director.loadScene('CreateRoom'); + } else { + cc.director.loadScene("Game"); + } + + break; + case msg.MATCHVS_ERROE_MSG: + this.labelLog("[Err]errCode:"+eventData.errorCode+" errMsg:"+eventData.errorMsg); + break; + case msg.MATCHVS_WX_BINDING: + engine.prototype.login(eventData.data.userid,eventData.data.token); break; } }, @@ -224,7 +206,6 @@ cc.Class({ } } }; - //sign=md5(appKey&gameID=value1&openID=value2&session=value3&thirdFlag=value4&appSecret) let params = "gameID="+GLB.gameID+"&openID="+wxUserInfo.openInfos.data.openid+"&session="+wxUserInfo.openInfos.data.session_key+"&thirdFlag=1"; //计算签名 let signstr = this.getSign(params); diff --git a/assets/scripts/Match.js b/assets/scripts/Match.js index 87e5a52..cb9754c 100644 --- a/assets/scripts/Match.js +++ b/assets/scripts/Match.js @@ -7,36 +7,33 @@ cc.Class({ extends: cc.Component, properties: { - player1: { + playerNameOne: { default: null, type: cc.Label }, - player2: { + playerNameTwo: { default: null, type: cc.Label }, - player3: { + playerTwoLayout: cc.Layout, + playerTwoLabel : cc.Label, + playerNameThree: { default: null, type: cc.Label }, + playerThreeLayout:cc.Layout, + playerThreeLabel : cc.Label, labelRoomID: { default: null, type: cc.Label }, - labelCountdown: { + matchingWay: { default: null, type: cc.Label }, - labelProperty: { - default: null, - type: cc.Label - }, - labelInfo: { - default: null, - type: cc.Label - }, - leaveRoom: cc.Node, + back: cc.Node, joinopen: cc.Node, + nickName:cc.Label, userList :[], nameViewList:[] }, @@ -45,20 +42,31 @@ cc.Class({ onLoad: function () { var self = this; this.initEvent(self); - this.nameViewList = [this.player2,this.player3]; + this.nameViewList = [[this.playerNameTwo,this.playerTwoLayout,this.playerTwoLabel], + [this.playerNameThree,this.playerThreeLayout,this.playerThreeLabel]]; + if (GLB.syncFrame) { + self.matchingWay.string = "帧同步模式" ; + } + // this.nameViewList[0][1].node.color = '#ffffff'; + // self.playerTwoLayout.node.color.a = 255; + // self.playerTwoLayout.node.color.r = 139; + // self.playerTwoLayout.node.color.g = 215; + // self.playerTwoLayout.node.color.b = 224; + // console.log(JSON.stringify(self.playerTwoLayout.node.color.a)+'node'); + self.nickName.string = '用户ID:'+ GLB.userID; if (GLB.matchType === GLB.RANDOM_MATCH) { engine.prototype.joinRandomRoom(GLB.MAX_PLAYER_COUNT, "这里是负载信息"); } else if (GLB.matchType === GLB.PROPERTY_MATCH) { var matchinfo = new mvs.MsMatchInfo(); matchinfo.maxPlayer = GLB.MAX_PLAYER_COUNT; matchinfo.mode = 0; - matchinfo.canWatch = 0; + matchinfo.canWatch = 1; matchinfo.tags = GLB.tagsInfo; - this.labelProperty.string = "自定义属性:" + JSON.stringify(GLB.tagsInfo); - engine.prototype.joinRoomWithProperties(matchinfo,"china"); + self.matchingWay.string = "自定义属性匹配" ; + engine.prototype.joinRoomWithProperties(matchinfo,"Matchvs"); } - this.leaveRoom.on(cc.Node.EventType.TOUCH_END, function (event) { + this.back.on(cc.Node.EventType.TOUCH_END, function (event) { GLB.roomID = ""; engine.prototype.leaveRoom(); }); @@ -96,22 +104,24 @@ cc.Class({ * @param event */ onEvent:function (event) { + var eventData = event.detail; + if (eventData == undefined) { + eventData = event; + } var checkBox = this.joinopen.getComponent(cc.Toggle); switch (event.type) { case msg.MATCHVS_JOIN_ROOM_RSP: - var userInfoList = event.detail.userInfoList; - console.log(userInfoList); - this.joinRoom(userInfoList); + this.joinRoom(eventData.userInfoList); break; case msg.MATCHVS_JOIN_ROOM_NOTIFY: - this.userList.push(event.detail.roomUserInfo) + this.userList.push(eventData.roomUserInfo) this.initUserView(this.userList); break; case msg.MATCHVS_LEAVE_ROOM: - cc.director.loadScene('lobby'); + cc.director.loadScene('Lobby'); break; case msg.MATCHVS_LEAVE_ROOM_NOTIFY: - this.removeView(event.detail.leaveRoomInfo); + this.removeView(eventData.leaveRoomInfo); break; case msg.MATCHVS_JOIN_OVER_NOTIFY: checkBox.isChecked = false; @@ -127,8 +137,7 @@ cc.Class({ break; case msg.MATCHVS_ERROE_MSG: GLB.roomID = ""; - this.labelLog("[Err]errCode:"+event.detail.errorCode+" errMsg:"+event.detail.errorMsg); - cc.director.loadScene("login") + cc.director.loadScene("Login") break } @@ -162,11 +171,9 @@ cc.Class({ joinRoom: function (userInfoList) { - this.labelLog('进入房间成功'); - this.labelLog('房间号: ' + userInfoList.roomID); this.labelRoomID.string = userInfoList.roomID; GLB.roomID = userInfoList.roomID; - this.player1.string = GLB.name; + this.playerNameOne.string = GLB.name; this.userList = userInfoList; this.initUserView(this.userList); if (this.userList.length == GLB.MAX_PLAYER_COUNT-1) { @@ -182,8 +189,9 @@ cc.Class({ initUserView :function(userList){ for(var i = 0; i < userList.length; i++) { var info = JSON.parse(userList[i].userProfile); - if (this.nameViewList[i].string === "") { - this.nameViewList[i].string = info.name; + if (this.nameViewList[i][0].string === "") { + this.nameViewList[i][0].string = info.name; + this.nameViewList[i][1].node.color = '#96E8B5'; } } if (this.userList.length == GLB.MAX_PLAYER_COUNT-1) { @@ -205,17 +213,14 @@ cc.Class({ } var name = JSON.parse(info.cpProto).name; for(var i = 0; i < this.nameViewList.length; i++) { - if(name == this.nameViewList[i].string) { - this.nameViewList[i].string = ""; + if(name == this.nameViewList[i][0].string) { + this.nameViewList[i][0].string = ""; } } }, - labelLog: function (info) { - this.labelInfo.string += '\n' + info; - }, + startGame: function () { - this.labelLog('游戏即将开始'); - cc.director.loadScene('game'); + cc.director.loadScene('Game'); }, }); diff --git a/assets/scripts/Matchvs.js b/assets/scripts/Matchvs.js index b854a91..b1557d8 100644 --- a/assets/scripts/Matchvs.js +++ b/assets/scripts/Matchvs.js @@ -5,28 +5,22 @@ var MsCreateRoomInfo; var MsRoomFilterEx; var LocalStore_Clear; try { - engine = Matchvs.MatchvsEngine.getInstance(); - MsMatchInfo = Matchvs.MatchInfo; - MsCreateRoomInfo = Matchvs.CreateRoomInfo; - MsRoomFilterEx = Matchvs.RoomFilterEx ; - console.log("load matchvs JSB"); + // engine = Matchvs.MatchvsEngine.getInstance(); + // MsMatchInfo = Matchvs.MatchInfo; + // MsCreateRoomInfo = Matchvs.CreateRoomInfo; + // MsRoomFilterEx = Matchvs.RoomFilterEx ; + // console.log("load matchvs JSB"); + var jsMatchvs = require("matchvs.all"); + engine = new jsMatchvs.MatchvsEngine(); + response = new jsMatchvs.MatchvsResponse(); + MsMatchInfo = jsMatchvs.MsMatchInfo; + MsCreateRoomInfo = jsMatchvs.MsCreateRoomInfo; + MsRoomFilterEx = jsMatchvs.MsRoomFilterEx ; + LocalStore_Clear = jsMatchvs.LocalStore_Clear; + console.log("load matchvs.all.js"); } catch (e) { console.warn("load matchvs JSB fail,"+e.message); - // try { - var jsMatchvs = require("matchvs.all"); - engine = new jsMatchvs.MatchvsEngine(); - response = new jsMatchvs.MatchvsResponse(); - MsMatchInfo = jsMatchvs.MsMatchInfo; - MsCreateRoomInfo = jsMatchvs.MsCreateRoomInfo; - MsRoomFilterEx = jsMatchvs.MsRoomFilterEx ; - LocalStore_Clear = jsMatchvs.LocalStore_Clear; - console.log("load matchvs.all.js"); - // } catch (e) { - // console.warn("load matchvs.all.js fail,"+e.message); - // var MatchVSEngine = require('MatchvsEngine'); - // console.log("load matchvs test code"); - // engine = new MatchVSEngine(); - // } + } module.exports = { engine: engine, diff --git a/assets/scripts/MatchvsDemoResponse.js b/assets/scripts/MatchvsDemoResponse.js index 5049666..14a1b8e 100644 --- a/assets/scripts/MatchvsDemoResponse.js +++ b/assets/scripts/MatchvsDemoResponse.js @@ -48,9 +48,7 @@ MatchvsDemoResponse.prototype.initResponse =function (status) { if (status == 200) { console.log("初始化成功"); console.log(this.context); - this.context.node.emit(msg.MATCHVS_INIT, { - msg: status, - }); + this.context.node.emit(msg.MATCHVS_INIT,{status:status,type:msg.MATCHVS_INIT}); } else { console.log("初始化失败"+status); } @@ -60,7 +58,7 @@ MatchvsDemoResponse.prototype.initResponse =function (status) { * 注册回调 */ MatchvsDemoResponse.prototype.registerUserResponse = function (userInfo) { - if (userInfo.id != undefined) { + if (userInfo.status == 0) { console.log("注册成功"); if (userInfo.name != "") { GLB.name = userInfo.name; @@ -69,7 +67,7 @@ MatchvsDemoResponse.prototype.registerUserResponse = function (userInfo) { } GLB.avatar = userInfo.avatar; GLB.userID = userInfo.id; - this.context.node.emit(msg.MATCHVS_REGISTER_USER, {msg: userInfo,}); + this.context.node.emit(msg.MATCHVS_REGISTER_USER,{userInfo:userInfo,type:msg.MATCHVS_REGISTER_USER}); } else { console.log("注册失败"+userInfo.status); } @@ -81,7 +79,7 @@ MatchvsDemoResponse.prototype.registerUserResponse = function (userInfo) { MatchvsDemoResponse.prototype.loginResponse = function (MsLoginRsp) { if (MsLoginRsp.status == 200) { console.log("登录成功"); - this.context.node.emit(msg.MATCHVS_LOGIN, {MsLoginRsp}); + this.context.node.emit(msg.MATCHVS_LOGIN, {MsLoginRsp:MsLoginRsp,type:msg.MATCHVS_LOGIN}); } else { console.log("登录失败"+ MsLoginRsp.status); } @@ -100,7 +98,7 @@ MatchvsDemoResponse.prototype.reconnectResponse = function (status,roomUserInfoL roomUserInfoList.roomProperty = roomInfo.roomProperty; roomUserInfoList.state = roomInfo.state; roomUserInfoList.ownerID = roomInfo.ownerID; - this.context.node.emit(msg.MATCHVS_RE_CONNECT, {roomUserInfoList}); + this.context.node.emit(msg.MATCHVS_RE_CONNECT, {roomUserInfoList:roomUserInfoList,type:msg.MATCHVS_RE_CONNECT}); } else { console.log("重连失败"+status); } @@ -112,7 +110,7 @@ MatchvsDemoResponse.prototype.reconnectResponse = function (status,roomUserInfoL */ MatchvsDemoResponse.prototype.errorResponse = function (errorCode,errorMsg) { console.log("发生错误了!!!!!!!!!!!!!"); - this.context.node.emit(msg.MATCHVS_ERROE_MSG, {errorCode,errorMsg}); + this.context.node.emit(msg.MATCHVS_ERROE_MSG, {errorCode,errorMsg,type:msg.MATCHVS_ERROE_MSG}); }; /** @@ -125,7 +123,7 @@ MatchvsDemoResponse.prototype.joinRoomResponse = function (status, userInfoList, if (status == 200) { console.log("进入房间成功"); userInfoList.roomID = roomInfo.roomID; - this.context.node.emit(msg.MATCHVS_JOIN_ROOM_RSP,{userInfoList}); + this.context.node.emit(msg.MATCHVS_JOIN_ROOM_RSP,{userInfoList:userInfoList,type:msg.MATCHVS_JOIN_ROOM_RSP}); } else { console.log("进入房间失败"+status); } @@ -137,7 +135,7 @@ MatchvsDemoResponse.prototype.joinRoomResponse = function (status, userInfoList, */ MatchvsDemoResponse.prototype.joinRoomNotify = function (roomUserInfo) { console.log(roomUserInfo.userId+"加入了房间"); - this.context.node.emit(msg.MATCHVS_JOIN_ROOM_NOTIFY,{roomUserInfo}); + this.context.node.emit(msg.MATCHVS_JOIN_ROOM_NOTIFY,{roomUserInfo:roomUserInfo,type:msg.MATCHVS_JOIN_ROOM_NOTIFY}); }; /** @@ -146,7 +144,7 @@ MatchvsDemoResponse.prototype.joinRoomNotify = function (roomUserInfo) { */ MatchvsDemoResponse.prototype.joinOpenNotify = function (notify) { console.log("房间打开通知"); - this.context.node.emit(msg.MATCHVS_JOIN_OPEN_NOTIFY,{notify}); + this.context.node.emit(msg.MATCHVS_JOIN_OPEN_NOTIFY,{notify,type:msg.MATCHVS_JOIN_OPEN_NOTIFY}); }; /** @@ -156,7 +154,7 @@ MatchvsDemoResponse.prototype.joinOpenNotify = function (notify) { MatchvsDemoResponse.prototype.joinOpenResponse =function (rsp) { if (rsp.status == 200) { console.log("房间打开成功"); - this.context.node.emit(msg.MATCHVS_JOIN_OPEN_RSP,{rsp}); + this.context.node.emit(msg.MATCHVS_JOIN_OPEN_RSP,{rsp,type:msg.MATCHVS_JOIN_OPEN_RSP}); } else { console.log("房间打开失败"+rsp.status); } @@ -170,7 +168,7 @@ MatchvsDemoResponse.prototype.joinOpenResponse =function (rsp) { MatchvsDemoResponse.prototype.joinOverResponse = function (rsp) { if(rsp.status == 200) { console.log("房间关闭成功"); - this.context.node.emit(msg.MATCHVS_JOIN_OVER_RSP,{rsp}); + this.context.node.emit(msg.MATCHVS_JOIN_OVER_RSP,{rsp,type:msg.MATCHVS_JOIN_OPEN_RSP}); } else { console.log("房间关闭失败"+rsp.status); } @@ -181,7 +179,7 @@ MatchvsDemoResponse.prototype.joinOverResponse = function (rsp) { */ MatchvsDemoResponse.prototype.joinOverNotify = function (notify) { console.log("房间关闭通知"); - this.context.node.emit(msg.MATCHVS_JOIN_OVER_NOTIFY,{notify}); + this.context.node.emit(msg.MATCHVS_JOIN_OVER_NOTIFY,{notify,type:msg.MATCHVS_JOIN_OVER_NOTIFY}); }; /** @@ -191,7 +189,9 @@ MatchvsDemoResponse.prototype.joinOverNotify = function (notify) { MatchvsDemoResponse.prototype.leaveRoomResponse = function (leaveRoomRsp) { if (leaveRoomRsp.status == 200) { console.log("离开房间成功"); - this.context.node.emit(msg.MATCHVS_LEAVE_ROOM,{leaveRoomRsp}); + if (this.context != null) { + this.context.node.emit(msg.MATCHVS_LEAVE_ROOM,{leaveRoomRsp,type:msg.MATCHVS_LEAVE_ROOM}); + } } else { console.log("离开房间失败"+leaveRoomRsp.status); } @@ -202,8 +202,9 @@ MatchvsDemoResponse.prototype.leaveRoomResponse = function (leaveRoomRsp) { * @param leaveRoomInfo */ MatchvsDemoResponse.prototype.leaveRoomNotify = function (leaveRoomInfo) { - console.log(JSON.stringify(leaveRoomInfo)); - this.context.node.emit(msg.MATCHVS_LEAVE_ROOM_NOTIFY,{leaveRoomInfo}); + if (this.context != null) { + this.context.node.emit(msg.MATCHVS_LEAVE_ROOM_NOTIFY,{leaveRoomInfo:leaveRoomInfo,type:msg.MATCHVS_LEAVE_ROOM_NOTIFY}); + } }; /** @@ -213,7 +214,7 @@ MatchvsDemoResponse.prototype.leaveRoomNotify = function (leaveRoomInfo) { MatchvsDemoResponse.prototype.getRoomListExResponse = function (rsp) { if (rsp.status == 200) { console.log("获取房间列表扩展接口成功"); - this.context.node.emit(msg.MATCHVS_ROOM_LIST_EX,{rsp}); + this.context.node.emit(msg.MATCHVS_ROOM_LIST_EX,{rsp:rsp,type:msg.MATCHVS_ROOM_LIST_EX}); } else { console.log("获取房间列表扩展接口失败 status" + rsp.status); } @@ -227,7 +228,7 @@ MatchvsDemoResponse.prototype.getRoomListExResponse = function (rsp) { MatchvsDemoResponse.prototype.createRoomResponse = function (rsp) { if (rsp.status == 200) { console.log("创建指定类型房间接口成功"); - this.context.node.emit(msg.MATCHVS_CREATE_ROOM,{rsp}); + this.context.node.emit(msg.MATCHVS_CREATE_ROOM,{rsp:rsp,type:msg.MATCHVS_CREATE_ROOM}); } else { console.log("创建指定类型房间接口失败 status" + rsp.status); } @@ -240,7 +241,7 @@ MatchvsDemoResponse.prototype.createRoomResponse = function (rsp) { MatchvsDemoResponse.prototype.kickPlayerResponse = function (kickPlayerRsp) { if (kickPlayerRsp.status == 200) { console.log("踢出指定玩家成功"); - this.context.node.emit(msg.MATCHVS_KICK_PLAYER, {kickPlayerRsp}) + this.context.node.emit(msg.MATCHVS_KICK_PLAYER,{kickPlayerRsp:kickPlayerRsp,type:msg.MATCHVS_KICK_PLAYER} ); } else { console.log("踢出指定玩家失败 status" + kickPlayerRsp.status); } @@ -252,7 +253,7 @@ MatchvsDemoResponse.prototype.kickPlayerResponse = function (kickPlayerRsp) { */ MatchvsDemoResponse.prototype.kickPlayerNotify = function (kickPlayerNotify) { console.log("踢出指定玩家通知"); - this.context.node.emit(msg.MATCHVS_KICK_PLAYER_NOTIFY, {kickPlayerNotify}) + this.context.node.emit(msg.MATCHVS_KICK_PLAYER_NOTIFY, {kickPlayerNotify:kickPlayerNotify,type:msg.MATCHVS_KICK_PLAYER_NOTIFY}); }; /** @@ -262,7 +263,7 @@ MatchvsDemoResponse.prototype.kickPlayerNotify = function (kickPlayerNotify) { MatchvsDemoResponse.prototype.setRoomPropertyResponse = function (rsp) { if (rsp.status == 200) { console.log("修改房间属性成功"); - this.context.node.emit(msg.MATCHVS_SET_ROOM_PROPETY, {rsp}) + this.context.node.emit(msg.MATCHVS_SET_ROOM_PROPETY, {rsp:rsp,type:msg.MATCHVS_SET_ROOM_PROPETY}); } else { console.log("修改房间属性失败 status" + rsp.status); } @@ -273,7 +274,8 @@ MatchvsDemoResponse.prototype.setRoomPropertyResponse = function (rsp) { */ MatchvsDemoResponse.prototype.setRoomPropertyNotify = function (rsp) { console.log("修改房间属性通知"); - this.context.node.emit(msg.MATCHVS_SET_ROOM_PROPETY_NOTIFY, {rsp}) + console.log(rsp.userID+"修改了房间属性,新的房间属性是"+rsp.roomProperty); +this.context.node.emit(msg.MATCHVS_SET_ROOM_PROPETY_NOTIFY, {rsp:rsp,type:msg.MATCHVS_SET_ROOM_PROPETY_NOTIFY}) }; /** @@ -282,7 +284,7 @@ MatchvsDemoResponse.prototype.setRoomPropertyNotify = function (rsp) { */ MatchvsDemoResponse.prototype.getRoomDetailResponse = function (rsp) { if (rsp.status == 200) { - this.context.node.emit(msg.MATCHVS_ROOM_DETAIL,{rsp}); + this.context.node.emit(msg.MATCHVS_ROOM_DETAIL,{rsp:rsp,type:msg.MATCHVS_ROOM_DETAIL}); console.log("获取房间详情成功"); } else { console.log("获取房间详情失败 status "+ rsp.status); @@ -295,8 +297,7 @@ MatchvsDemoResponse.prototype.getRoomDetailResponse = function (rsp) { */ MatchvsDemoResponse.prototype.sendEventResponse = function (sendEventRsp) { if (sendEventRsp.status == 200) { - this.context.node.emit(msg.MATCHVS_SEND_EVENT_RSP,{sendEventRsp}); - // console.log("发送消息Response"); + this.context.node.emit(msg.MATCHVS_SEND_EVENT_RSP,{sendEventRsp,type:msg.MATCHVS_SEND_EVENT_RSP}); } else { console.log("发送消息失败 status"+sendEventRsp.status); } @@ -307,12 +308,12 @@ MatchvsDemoResponse.prototype.sendEventResponse = function (sendEventRsp) { * @param eventInfo */ MatchvsDemoResponse.prototype.sendEventNotify = function (eventInfo) { - // console.log("收到信息"); - this.context.node.emit(msg.MATCHVS_SEND_EVENT_NOTIFY, {eventInfo}); + //console.log('ID为'+eventInfo.srcUserID+'通知了'+eventInfo.cpProto); + this.context.node.emit(msg.MATCHVS_SEND_EVENT_NOTIFY,{eventInfo:eventInfo,type:msg.MATCHVS_SEND_EVENT_NOTIFY}); }; MatchvsDemoResponse.prototype.setFrameSyncResponse = function (rsp) { - this.context.node.emit(msg.MATCHVS_SET_FRAME_SYNC_RSP,rsp); + this.context.node.emit(msg.MATCHVS_SET_FRAME_SYNC_RSP,{rsp,type:msg.MATCHVS_SET_FRAME_SYNC_RSP}); if (rsp.mStatus == 200) { console.log('帧率设置成功'); } else if (rsp.mStatus ==519 ) { @@ -327,26 +328,25 @@ MatchvsDemoResponse.prototype.setFrameSyncResponse = function (rsp) { * @param data */ MatchvsDemoResponse.prototype.frameUpdate = function (data) { - this.context.node.emit(msg.MATCHVS_FRAME_UPDATE, data); + this.context.node.emit(msg.MATCHVS_FRAME_UPDATE, {data:data,type:msg.MATCHVS_FRAME_UPDATE}); }; MatchvsDemoResponse.prototype.networkStateNotify = function (netNotify) { console.log("netNotify.owner:" + netNotify.owner); - this.context.node.emit(msg.MATCHVS_NETWORK_STATE_NOTIFY,netNotify); + this.context.node.emit(msg.MATCHVS_NETWORK_STATE_NOTIFY,{netNotify:netNotify,type:msg.MATCHVS_NETWORK_STATE_NOTIFY}); }; MatchvsDemoResponse.prototype.onMsg = function (buf) { var data = JSON.parse(buf); if (data.status == 0) { - var val = data.data; - this.context.node.emit(msg.MATCHVS_WX_BINDING,{val}) + this.context.node.emit(msg.MATCHVS_WX_BINDING,{data:data.data,type:msg.MATCHVS_WX_BINDING}) } else { } }; MatchvsDemoResponse.prototype.onErr = function (errCode,errMsg) { - console.log(errCode,errMsg+"11111111111111111111111"); + console.log(errCode,errMsg+"!!!"); }; module.exports = MatchvsDemoResponse; diff --git a/assets/scripts/MatvhvsMessage.js b/assets/scripts/MatvhvsMessage.js index 5a8bf0f..23fb3a6 100644 --- a/assets/scripts/MatvhvsMessage.js +++ b/assets/scripts/MatvhvsMessage.js @@ -31,6 +31,7 @@ var msg = { EVENT_GAME_START :"EVENT_GAME_START", NEW_STAR_POSITION : "NEW_STAR_POSITION", PLAYER_POSINTON : "PLAYER_POSINTON", + DESTROY_NODE : "DESTROY_NODE" }; module.exports = msg; \ No newline at end of file diff --git a/assets/scripts/Player.js b/assets/scripts/Player.js index effc26b..57a21b9 100644 --- a/assets/scripts/Player.js +++ b/assets/scripts/Player.js @@ -36,46 +36,34 @@ cc.Class({ isDebug:false, userID:0, playerLabel:null, - + mouseListener:null, startPostion:0, }, - // playJumpSound: function () { - // // 调用声音引擎播放声音 - // cc.audioEngine.playEffect(this.jumpAudio, false); - // }, - onPostionChanged(x, arrow) { - // var action = cc.moveTo(1,x,0); - // if (x != this.playerSpriteRight.node.x) { - // this.playerSpriteRight.node.runAction(action); - this.playerSpriteRight.node.x = x; - // this.playerSpriteRight.node.stopAction(action); - // } - // if (x != this.playerSpriteLeft.node.x) { - // this.playerSpriteLeft.node.runAction(action); - this.playerSpriteLeft.node.x = x; - // this.playerSpriteLeft.node.stopAction(action); - // } - // this.playJumpSound(); + onPostionChanged(x, arrow) { + this.playerSpriteRight.node.x = x; + this.playerSpriteLeft.node.x = x; this.playAnimation(arrow); this.playerLabel.node.x = x; - // console.log(x,GLB.NEW_STAR_POSITION); - }, + getPostion: function () { return this.playerSpriteRight.node.x; }, onLoad: function () { - this.rightAnimNode = this.node.getChildByName("rightAnimNode"); - this.leftAnimNode = this.node.getChildByName("leftAnimNode"); - this.animRightComp = this.rightAnimNode.getComponent(cc.Animation); - this.animLeftComp = this.leftAnimNode.getComponent(cc.Animation); - this.playerSpriteRight = this.rightAnimNode.getComponent(cc.Sprite); - this.playerSpriteLeft = this.leftAnimNode.getComponent(cc.Sprite); - this.playerLabel = this.node.getChildByName("playerLabel").getComponent(cc.Label); - + // if (this.node != undefined && this.node != null) { + this.rightAnimNode = this.node.getChildByName("rightAnimNode"); + this.leftAnimNode = this.node.getChildByName("leftAnimNode"); + this.animRightComp = this.rightAnimNode.getComponent(cc.Animation); + this.animLeftComp = this.leftAnimNode.getComponent(cc.Animation); + this.playerSpriteRight = this.rightAnimNode.getComponent(cc.Sprite); + + this.playerSpriteLeft = this.leftAnimNode.getComponent(cc.Sprite); + this.playerLabel = this.node.getChildByName("playerLabel").getComponent(cc.Label); + // } + console.log("xxxxxxxx",this.playerSpriteRight.node.x); var self = this; if (this.isAllowInput) { this.postionSampler = setInterval(function () { @@ -91,7 +79,7 @@ cc.Class({ "arrow": self.isUserInputing }); var x = self.getPostion(); - self.node.parent.getComponent("Game").node.emit(msg.PLAYER_POSINTON, {x}); + self.node.parent.getComponent("Game").node.emit(msg.PLAYER_POSINTON, {x:x,type:msg.PLAYER_POSINTON}); // if (self.isDebug){ // self.node.parent.getComponent("Game").onNewWorkGameEvent({"cpProto":frameData}); //remove me, This is for Test only // } else { @@ -104,25 +92,13 @@ cc.Class({ engine.prototype.sendEvent(frameData); } - - - // try { - // if (self.isUserInputing !== 0) { - // GLB.syncFrame === false ? (mvs.engine.sendEventEx(0, frameData, 0, GLB.playerUserIds)) - // : (mvs.engine.sendFrameEvent(frameData)); - // } - // } catch (e) { - // console.log(e); - // } - }, 1000 / GLB.FPS); // 初始化键盘输入监听 - this.setInputControl(); + this.setInputControl(self); } }, - playAnimation: function (arrow) { if (arrow === GLB.ARROW_STOP) { this.animRightComp.stop(); @@ -150,9 +126,8 @@ cc.Class({ }, - setInputControl: function () { - var self = this; - + setInputControl: function (self) { + // var self = this; var onTouch = function (touch) { var touchLoc = touch.getLocation(); if (touchLoc.x >= cc.winSize.width / 3) { @@ -163,11 +138,11 @@ cc.Class({ self.onPostionChanged(self.playerSpriteRight.node.x - self.speed, self.isUserInputing); } }; - cc.eventManager.addListener({ + //2.0 需要手动移除 + this.mouseListener = cc.eventManager.addListener({ event: cc.EventListener.TOUCH_ONE_BY_ONE, fakeMove: Number, onTouchBegan: function (touch, event) { - console.log("begin move "); onTouch(touch); this.fakeMove = setInterval(function () { onTouch(touch); @@ -187,7 +162,6 @@ cc.Class({ }, - // 随机返回'新的星星'的位置 getNewStarPosition: function () { var randX = cc.randomMinus1To1() * this.starMaxX; @@ -197,7 +171,11 @@ cc.Class({ + + onDestroy: function () { + console.log("人物节点销毁"); this.postionSampler && clearInterval(this.postionSampler); + cc.eventManager.removeListener(this.mouseListener); } }); diff --git a/assets/scripts/RoomList.js b/assets/scripts/RoomList.js index c8876e7..8b0b8d7 100644 --- a/assets/scripts/RoomList.js +++ b/assets/scripts/RoomList.js @@ -3,13 +3,7 @@ var response = require("MatchvsDemoResponse"); var mvs = require("Matchvs"); var GLB = require("Glb"); var msg = require("MatvhvsMessage"); -var RoomFilterEx = new mvs.MsRoomFilterEx(); -RoomFilterEx.maxPlayer = GLB.MAX_PLAYER_COUNT; -RoomFilterEx.mode = 0; -RoomFilterEx.canWatch = 0; -RoomFilterEx.roomProperty = ""; -RoomFilterEx.pageNo = 0; -RoomFilterEx.pageSize = 10; + var refreshNum = 0; var time; @@ -43,22 +37,14 @@ cc.Class({ }, - // getPositionInView: function (item) { // get item position in scrollview's node space - // let worldPos = item.parent.convertToWorldSpaceAR(item.position); - // let viewPos = this.scrollView.node.convertToNodeSpaceAR(worldPos); - // return viewPos; - // }, - - onLoad:function () { this.content = this.scrollView.content; this.items = []; - // this.initialize(); var self = this; this.initEvent(self); this.getRooomList(); this.back.on(cc.Node.EventType.TOUCH_END, function(event){ - cc.director.loadScene("lobby"); + cc.director.loadScene("Lobby"); }); time = setInterval(this.getRooomList,10000); @@ -66,6 +52,13 @@ cc.Class({ getRooomList:function () { + var RoomFilterEx = new mvs.MsRoomFilterEx(); + RoomFilterEx.maxPlayer = GLB.MAX_PLAYER_COUNT; + RoomFilterEx.mode = 0; + RoomFilterEx.canWatch = 0; + RoomFilterEx.roomProperty = "白天模式"; + RoomFilterEx.pageNo = 0; + RoomFilterEx.pageSize = 10; engine.prototype.getRoomListEx(RoomFilterEx) }, @@ -85,22 +78,26 @@ cc.Class({ * @param event */ onEvent :function (event) { + var eventData = event.detail; + if (eventData == undefined) { + eventData = event; + } switch (event.type) { case msg.MATCHVS_ROOM_LIST_EX: - this.getRoomListExResponse(event.detail); + this.getRoomListExResponse(eventData.rsp); break; case msg.MATCHVS_ERROE_MSG: if (event.detail.errorCode == 405) { this.labelLog("房间人数已满"); return; } - this.labelLog("[Err]errCode:"+event.detail.errorCode+" errMsg:"+event.detail.errorMsg); - cc.director.loadScene('login'); + this.labelLog("[Err]errCode:"+eventData.errorCode+" errMsg:"+eventData.errorMsg); + cc.director.loadScene('Login'); break; case msg.MATCHVS_JOIN_ROOM_RSP: - GLB.roomID = event.detail.userInfoList.roomID; + GLB.roomID = eventData.userInfoList.roomID; this.labelLog("加入指定房间成功, roomID:" + GLB.roomID); - cc.director.loadScene('createRoom'); + cc.director.loadScene('CreateRoom'); break; } @@ -111,13 +108,13 @@ cc.Class({ getRoomListExResponse: function(roomListExInfo) { refreshNum ++; this.refreshNumText.string = '获取列表次数'+ refreshNum; - this.totalCount = roomListExInfo.rsp.total; + this.totalCount = roomListExInfo.total; this.content.height = this.totalCount * (this.itemTemplate.height + this.spacing) + this.spacing; // get total content height - for(var i = 0; i < roomListExInfo.rsp.total; i++) { + for(var i = 0; i < roomListExInfo.total; i++) { let item = cc.instantiate(this.itemTemplate); this.content.addChild(item); item.setPosition(0, -item.height * (0.5 + i) - this.spacing * (i + 1)); - item.getComponent('Item').updateItem(roomListExInfo.rsp.roomAttrs[i]); + item.getComponent('Item').updateItem(roomListExInfo.roomAttrs[i]); } }, diff --git a/assets/scripts/SelfDefMatch.js b/assets/scripts/SelfDefMatch.js index 68bf6da..0e1dbee 100644 --- a/assets/scripts/SelfDefMatch.js +++ b/assets/scripts/SelfDefMatch.js @@ -13,35 +13,28 @@ cc.Class({ labelInfoSelfDefineMatch: { default: null, type: cc.Label - } + }, + nickName:cc.Label, }, onLoad () { var self = this; + self.nickName.string = '用户ID:'+ GLB.userID; this.startMatch.on(cc.Node.EventType.TOUCH_END, function(event){ - self.labelLog('开始属性匹配'); if (self.odd.isChecked) { GLB.tagsInfo={"title": "A"}; - self.labelLog('设置标签A'); } else { GLB.tagsInfo={"title": "B"}; - self.labelLog('设置标签B'); } - // 设置当前模式为属性匹配 GLB.matchType = GLB.PROPERTY_MATCH; - cc.director.loadScene('match'); + cc.director.loadScene('Match'); }); this.returnLobby.on(cc.Node.EventType.TOUCH_END, function(event){ - cc.director.loadScene('lobby'); + cc.director.loadScene('Lobby'); }); }, - - labelLog: function (info) { - this.labelInfoSelfDefineMatch.string += '\n' + info; - }, - startGame: function () { this.labelLog('游戏即将开始') cc.director.loadScene('game') diff --git a/assets/scripts/Star.js b/assets/scripts/Star.js index a5c6d75..7a4880f 100644 --- a/assets/scripts/Star.js +++ b/assets/scripts/Star.js @@ -35,7 +35,7 @@ cc.Class({ var playerPos = this.game.players[0].getPosition(); // this.game.players[0].node.x; // 根据两点位置计算两点之间距离 - var dist = cc.pDistance(this.node.position, playerPos); + var dist = this.pDistance(this.node.position, playerPos); return dist; }, @@ -61,4 +61,23 @@ cc.Class({ var minOpacity = 50; this.node.opacity = minOpacity + Math.floor(opacityRatio * (255 - minOpacity)); }, + + pDistance :function(v1, v2) { + return this.pLength(this.pSub(v1, v2)); + }, + + pLength : function(v) { + return Math.sqrt(this.pLengthSQ(v)); + }, + + pSub :function(v1, v2) { + return cc.v2(v1.x - v2.x, v1.y - v2.y); + }, + pLengthSQ : function(v) { + return this.pDot(v, v); + }, + + pDot : function(v1, v2) { + return v1.x * v2.x + v1.y * v2.y; + }, }); diff --git a/assets/scripts/result.js b/assets/scripts/result.js index be5b2c8..6d652f6 100644 --- a/assets/scripts/result.js +++ b/assets/scripts/result.js @@ -1,6 +1,6 @@ // var mvs = require("Matchvs"); + var GLB = require("Glb"); -var engine = require("MatchvsEngine"); var response = require("MatchvsDemoResponse"); var msg = require("MatvhvsMessage"); @@ -8,25 +8,52 @@ cc.Class({ extends: cc.Component, properties: { - - labelFirst: { - default: null, - type: cc.Label - }, + roomNum:cc.Label, + ownerID:cc.Label, + ownerScore:cc.Label, + oneID:cc.Label, + oneScore:cc.Label, + twoID:cc.Label, + twoScore:cc.Label, buttonBack: cc.Node, }, onLoad () { var self = this; - this.labelFirst.string = GLB.number1 + "\n" + GLB.number2 + "\n" + GLB.number3 + "\n"; + this.sortScore(self); this.initEvent(self); this.buttonBack.on(cc.Node.EventType.TOUCH_END, function(event){ - // engine.prototype.leaveRoom(); - cc.director.loadScene('lobby'); + cc.director.loadScene('Lobby'); }); }, + sortScore() { + var nums = [GLB.number1,GLB.number2,GLB.number3]; + for(var i = 0; i < nums.length;i++) { + var num = nums[i].split(":") + //如果自己是房主 + this.showNum(num); + } + }, + + showNum(num) { + var IDS = [this.oneID,this.twoID]; + var scoreS = [this.oneScore,this.twoScore]; + if (num[0] == GLB.ownew) { + this.ownerID .string= num[0]; + this.ownerScore.string = num[1]; + } else { + for(var i = 0; i < IDS.length ;i++) { + if(IDS[i].string === "") { + IDS[i].string = num[0]; + scoreS[i].string = num[1] + return; + } + } + } + }, + /** * 注册对应的事件监听和把自己的原型传递进入,用于发送事件使用 @@ -34,7 +61,6 @@ cc.Class({ initEvent:function (self) { response.prototype.init(self); this.node.on(msg.MATCHVS_ERROE_MSG, this.onEvent, this); - this.node.on(msg.MATCHVS_LEAVE_ROOM, this.onEvent, this); }, @@ -42,14 +68,13 @@ cc.Class({ switch (event.type){ case msg.MATCHVS_ERROE_MSG: console.log("[Err]errCode:"+event.detail.errorCode+" errMsg:"+event.detail.errorMsg); - cc.director.loadScene('login'); + cc.director.loadScene('Login'); break; } }, start () { - }, onDestroy() { @@ -57,7 +82,6 @@ cc.Class({ GLB.number2 = 0; GLB.number3 = 0; this.node.off(msg.MATCHVS_ERROE_MSG, this.onEvent, this); - this.node.off(msg.MATCHVS_LEAVE_ROOM, this.onEvent, this); } }); diff --git a/assets/selfDefMatch.fire.meta b/assets/selfDefMatch.fire.meta deleted file mode 100644 index 3940b31..0000000 --- a/assets/selfDefMatch.fire.meta +++ /dev/null @@ -1,7 +0,0 @@ -{ - "ver": "1.0.0", - "uuid": "8b693ca5-7df4-4f8d-b1a0-71e5c43b2e69", - "asyncLoadAssets": false, - "autoReleaseAssets": false, - "subMetas": {} -} \ No newline at end of file diff --git a/assets/textures/PurpleMonster.png b/assets/textures/PurpleMonster.png deleted file mode 100644 index be142b55e49d87c019e3a223a892e8ef351fd17d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3013 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 diff --git a/assets/textures/PurpleMonster2.png b/assets/textures/PurpleMonster2.png deleted file mode 100644 index 0a32b9911d47139ad6862575ea6d9ab7e7347737..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4785 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 S1}Mk?0000QVrZp#@`3dNPu;x&^9!TNEC-(Q|7; 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