diff --git a/html5/Arthur/cocos2d.js b/html5/Arthur/cocos2d.js new file mode 100755 index 0000000..3d9a234 --- /dev/null +++ b/html5/Arthur/cocos2d.js @@ -0,0 +1,90 @@ +/**************************************************************************** + Copyright (c) 2010-2012 cocos2d-x.org + Copyright (c) 2008-2010 Ricardo Quesada + Copyright (c) 2011 Zynga Inc. + + http://www.cocos2d-x.org + + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in + all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + THE SOFTWARE. + ****************************************************************************/ +(function () { + var d = document; + var c = { + COCOS2D_DEBUG:2, //0 to turn debug off, 1 for basic debug, and 2 for full debug + box2d:true, + chipmunk:true, + showFPS:true, + frameRate:60, + loadExtension:true, + renderMode:0, //Choose of RenderMode: 0(default), 1(Canvas only), 2(WebGL only) + tag:'gameCanvas', //the dom element to run cocos2d on + engineDir:'../cocos2d/', + //SingleEngineFile:'', + appFiles:[ + 'src/resource.js', + 'src/GameConfig.js', // 配置 + 'src/HudLayer.js', // 控制 + 'src/Characters.js', // 人物 + 'src/KeyMap.js', // 键盘映射 + 'src/Joypad.js', // 摇杆控制器 + 'src/ActionButton.js', // 按钮 + 'src/GameLayer.js', // 游戏层 + 'src/Loading.js' // 自定义加载界面 + ] + }; + + if(!d.createElement('canvas').getContext){ + var s = d.createElement('div'); + s.innerHTML = '

Your browser does not support HTML5 canvas!

' + + '

Google Chrome is a browser that combines a minimal design with sophisticated technology to make the web faster, safer, and easier.Click the logo to download.

' + + ''; + var p = d.getElementById(c.tag).parentNode; + p.style.background = 'none'; + p.style.border = 'none'; + p.insertBefore(s); + + d.body.style.background = '#ffffff'; + return; + } + + window.addEventListener('DOMContentLoaded', function () { + //first load engine file if specified + var s = d.createElement('script'); + /*********Delete this section if you have packed all files into one*******/ + if (c.SingleEngineFile && !c.engineDir) { + s.src = c.SingleEngineFile; + } + else if (c.engineDir && !c.SingleEngineFile) { + s.src = c.engineDir + 'platform/jsloader.js'; + } + else { + alert('You must specify either the single engine file OR the engine directory in "cocos2d.js"'); + } + /*********Delete this section if you have packed all files into one*******/ + + //s.src = 'Packed_Release_File.js'; //IMPORTANT: Un-comment this line if you have packed all files into one + + document.ccConfig = c; + s.id = 'cocos2d-html5'; + d.body.appendChild(s); + //else if single file specified, load singlefile + }); +})(); + diff --git a/html5/Arthur/index.html b/html5/Arthur/index.html new file mode 100755 index 0000000..fd6a657 --- /dev/null +++ b/html5/Arthur/index.html @@ -0,0 +1,28 @@ + + + + + Cocos2d-html5 Hello World test + + + + + + + + + +
+ +
+ + + \ No newline at end of file diff --git a/html5/Arthur/main.js b/html5/Arthur/main.js new file mode 100755 index 0000000..a9dac9f --- /dev/null +++ b/html5/Arthur/main.js @@ -0,0 +1,67 @@ +/**************************************************************************** + Copyright (c) 2010-2012 cocos2d-x.org + Copyright (c) 2008-2010 Ricardo Quesada + Copyright (c) 2011 Zynga Inc. + + http://www.cocos2d-x.org + + + Permission is hereby granted, free of charge, to any person obtaining a copy + of this software and associated documentation files (the "Software"), to deal + in the Software without restriction, including without limitation the rights + to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + copies of the Software, and to permit persons to whom the Software is + furnished to do so, subject to the following conditions: + + The above copyright notice and this permission notice shall be included in + all copies or substantial portions of the Software. + + THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN + THE SOFTWARE. + ****************************************************************************/ +var cocos2dApp = cc.Application.extend({ + config:document['ccConfig'], + ctor:function (scene) { + this._super(); + this.startScene = scene; + cc.COCOS2D_DEBUG = this.config['COCOS2D_DEBUG']; + cc.initDebugSetting(); + cc.setup(this.config['tag']); + cc.AppController.shareAppController().didFinishLaunchingWithOptions(); + }, + applicationDidFinishLaunching:function () { + if(cc.RenderDoesnotSupport()){ + //show Information to user + alert("Browser doesn't support WebGL"); + return false; + } + // initialize director + var director = cc.Director.getInstance(); + + // enable High Resource Mode(2x, such as iphone4) and maintains low resource on other devices. + //director.enableRetinaDisplay(true); + + // turn on display FPS + director.setDisplayStats(this.config['showFPS']); + + // set FPS. the default value is 1.0/60 if you don't call this + director.setAnimationInterval(1.0 / this.config['frameRate']); + + //load resources + Loading.preload(g_resources, function () { + // cc.LoaderScene.preload(g_resources, function () { + director.replaceScene(new this.startScene()); + }, this); + // Loading.preload(g_resources, function () { + // director.replaceScene(new this.startScene()); + // }, this); + + return true; + } +}); +var myApp = new cocos2dApp(GameLayer.scene); diff --git a/html5/Arthur/proj.org b/html5/Arthur/proj.org new file mode 100644 index 0000000..454c600 --- /dev/null +++ b/html5/Arthur/proj.org @@ -0,0 +1,71 @@ +* 王者之剑 Demo + +* todo list + +** DONE 英雄血条状态 + CLOSED: [2013-08-19 Mon 15:52] + +** DONE 怪物血条状态 + CLOSED: [2013-08-22 Thu 09:26] + +** DONE 血条状态封装实现 + CLOSED: [2013-08-22 Thu 09:26] + 实现英雄和怪物的通用封装 + +** DONE 人物走动位置边界判断 + CLOSED: [2013-08-20 Tue 11:04] + +** TODO 怪物自动攻击 AI + +** DONE 人物动作封装 + CLOSED: [2013-08-22 Thu 09:26] + +** TODO 怪物动作封装实现 + +** DONE 特效攻击冷冻 + CLOSED: [2013-08-22 Thu 09:26] + +** DONE 攻击按钮实现效果 + CLOSED: [2013-08-22 Thu 09:26] + 完成 API 调用 + +** 攻击按钮键盘映射 + CLOSED: [2013-08-20 Tue 14:58] + +** DONE 状态 标题 + CLOSED: [2013-08-22 Thu 14:11] + 如 "吾名一叶" "锤子兵" 的 Title + +** DONE 层级检测 + CLOSED: [2013-08-22 Thu 13:39] +多层游戏元素,更具位置判断前后关系 + +** DONE 掉血动作 + CLOSED: [2013-08-22 Thu 16:59] +一个数字往上升 + +** TODO 跳跃的位置检测 +需要排除跳跃攻击的 边界检测,否则落地错误 + +** DONE 打击范围判断 + CLOSED: [2013-08-23 Fri 09:47] +当然还有打击方向 +打击前设定当前“打击对象”的攻击区域,和被打击对象的区域 +还需要判断是否在同一个高度,打击对象与被打击对象所在的 y 轴差,在一定值之内 + +** DONE 掉血延迟 + CLOSED: [2013-08-23 Fri 09:47] + +** DONE 血条跟随掉血 + CLOSED: [2013-08-23 Fri 11:26] + +** TODO 不同动作之间过度不流畅 + +** TODO 简单 AI +实现怪物自动攻击 + +* Html5 问题 +BMF 不能使用 FadeOut + +* 美术资源总结 +同样人物,或者元素,动画使用相同大小图片 diff --git a/html5/Arthur/res/Attack.png b/html5/Arthur/res/Attack.png new file mode 100644 index 0000000..5436405 Binary files /dev/null and b/html5/Arthur/res/Attack.png differ diff --git a/html5/Arthur/res/AttackA.png b/html5/Arthur/res/AttackA.png new file mode 100644 index 0000000..11a80aa Binary files /dev/null and b/html5/Arthur/res/AttackA.png differ diff --git a/html5/Arthur/res/AttackB.png b/html5/Arthur/res/AttackB.png new file mode 100644 index 0000000..08bad57 Binary files /dev/null and b/html5/Arthur/res/AttackB.png differ diff --git a/html5/Arthur/res/AttackFreeze.png b/html5/Arthur/res/AttackFreeze.png new file mode 100644 index 0000000..4a54ea0 Binary files /dev/null and b/html5/Arthur/res/AttackFreeze.png differ diff --git a/html5/Arthur/res/AttackO.png b/html5/Arthur/res/AttackO.png new file mode 100644 index 0000000..988d6a1 Binary files /dev/null and b/html5/Arthur/res/AttackO.png differ diff --git a/html5/Arthur/res/BackGround.png b/html5/Arthur/res/BackGround.png new file mode 100644 index 0000000..720791d Binary files /dev/null and b/html5/Arthur/res/BackGround.png differ diff --git a/html5/Arthur/res/CloseNormal.png b/html5/Arthur/res/CloseNormal.png new file mode 100755 index 0000000..5657a13 Binary files /dev/null and b/html5/Arthur/res/CloseNormal.png differ diff --git a/html5/Arthur/res/CloseSelected.png b/html5/Arthur/res/CloseSelected.png new file mode 100755 index 0000000..e4c82da Binary files /dev/null and b/html5/Arthur/res/CloseSelected.png differ diff --git a/html5/Arthur/res/HelloWorld.png b/html5/Arthur/res/HelloWorld.png new file mode 100755 index 0000000..3a20f25 Binary files /dev/null and b/html5/Arthur/res/HelloWorld.png differ diff --git a/html5/Arthur/res/Hero1.png b/html5/Arthur/res/Hero1.png new file mode 100755 index 0000000..2932374 Binary files /dev/null and b/html5/Arthur/res/Hero1.png differ diff --git a/html5/Arthur/res/Hero2.png b/html5/Arthur/res/Hero2.png new file mode 100755 index 0000000..9fabce4 Binary files /dev/null and b/html5/Arthur/res/Hero2.png differ diff --git a/html5/Arthur/res/Hero3.png b/html5/Arthur/res/Hero3.png new file mode 100755 index 0000000..0dae6d2 Binary files /dev/null and b/html5/Arthur/res/Hero3.png differ diff --git a/html5/Arthur/res/HeroAttack1.png b/html5/Arthur/res/HeroAttack1.png new file mode 100644 index 0000000..221bbb5 Binary files /dev/null and b/html5/Arthur/res/HeroAttack1.png differ diff --git a/html5/Arthur/res/HeroAttack2.png b/html5/Arthur/res/HeroAttack2.png new file mode 100644 index 0000000..a1954ae Binary files /dev/null and b/html5/Arthur/res/HeroAttack2.png differ diff --git a/html5/Arthur/res/HeroAttack3.png b/html5/Arthur/res/HeroAttack3.png new file mode 100644 index 0000000..8ca9cb2 Binary files /dev/null and b/html5/Arthur/res/HeroAttack3.png differ diff --git a/html5/Arthur/res/HeroAttack4.png b/html5/Arthur/res/HeroAttack4.png new file mode 100644 index 0000000..d2a0647 Binary files /dev/null and b/html5/Arthur/res/HeroAttack4.png differ diff --git a/html5/Arthur/res/HeroAttack5.png b/html5/Arthur/res/HeroAttack5.png new file mode 100644 index 0000000..06fabfc Binary files /dev/null and b/html5/Arthur/res/HeroAttack5.png differ diff --git a/html5/Arthur/res/HeroAttackJ1.png b/html5/Arthur/res/HeroAttackJ1.png new file mode 100644 index 0000000..d588c59 Binary files /dev/null and b/html5/Arthur/res/HeroAttackJ1.png differ diff --git a/html5/Arthur/res/HeroAttackJ2.png b/html5/Arthur/res/HeroAttackJ2.png new file mode 100644 index 0000000..88e7fa8 Binary files /dev/null and b/html5/Arthur/res/HeroAttackJ2.png differ diff --git a/html5/Arthur/res/HeroAttackJ3.png b/html5/Arthur/res/HeroAttackJ3.png new file mode 100644 index 0000000..5aca464 Binary files /dev/null and b/html5/Arthur/res/HeroAttackJ3.png differ diff --git a/html5/Arthur/res/HeroAttackJ4.png b/html5/Arthur/res/HeroAttackJ4.png new file mode 100644 index 0000000..b134e64 Binary files /dev/null and b/html5/Arthur/res/HeroAttackJ4.png differ diff --git a/html5/Arthur/res/HeroAttackJ5.png b/html5/Arthur/res/HeroAttackJ5.png new file mode 100644 index 0000000..bceff9f Binary files /dev/null and b/html5/Arthur/res/HeroAttackJ5.png differ diff --git a/html5/Arthur/res/HeroAttackJ6.png b/html5/Arthur/res/HeroAttackJ6.png new file mode 100644 index 0000000..0819818 Binary files /dev/null and b/html5/Arthur/res/HeroAttackJ6.png differ diff --git a/html5/Arthur/res/HeroAttackJ7.png b/html5/Arthur/res/HeroAttackJ7.png new file mode 100644 index 0000000..db10eed Binary files /dev/null and b/html5/Arthur/res/HeroAttackJ7.png differ diff --git a/html5/Arthur/res/HeroAttackJ8.png b/html5/Arthur/res/HeroAttackJ8.png new file mode 100644 index 0000000..fae8723 Binary files /dev/null and b/html5/Arthur/res/HeroAttackJ8.png differ diff --git a/html5/Arthur/res/HeroAttackT1.png b/html5/Arthur/res/HeroAttackT1.png new file mode 100644 index 0000000..c5b9064 Binary files /dev/null and b/html5/Arthur/res/HeroAttackT1.png differ diff --git a/html5/Arthur/res/HeroAttackT2.png b/html5/Arthur/res/HeroAttackT2.png new file mode 100644 index 0000000..6d73f6b Binary files /dev/null and b/html5/Arthur/res/HeroAttackT2.png differ diff --git a/html5/Arthur/res/HeroAttackT3.png b/html5/Arthur/res/HeroAttackT3.png new file mode 100644 index 0000000..94deddc Binary files /dev/null and b/html5/Arthur/res/HeroAttackT3.png differ diff --git a/html5/Arthur/res/HeroRun1.png b/html5/Arthur/res/HeroRun1.png new file mode 100755 index 0000000..7230c09 Binary files /dev/null and b/html5/Arthur/res/HeroRun1.png differ diff --git a/html5/Arthur/res/HeroRun10.png b/html5/Arthur/res/HeroRun10.png new file mode 100755 index 0000000..52ab27b Binary files /dev/null and b/html5/Arthur/res/HeroRun10.png differ diff --git a/html5/Arthur/res/HeroRun11.png b/html5/Arthur/res/HeroRun11.png new file mode 100755 index 0000000..a7b9d85 Binary files /dev/null and b/html5/Arthur/res/HeroRun11.png differ diff --git a/html5/Arthur/res/HeroRun2.png b/html5/Arthur/res/HeroRun2.png new file mode 100755 index 0000000..a6713ef Binary files /dev/null and b/html5/Arthur/res/HeroRun2.png differ diff --git a/html5/Arthur/res/HeroRun3.png b/html5/Arthur/res/HeroRun3.png new file mode 100755 index 0000000..c3f89a7 Binary files /dev/null and b/html5/Arthur/res/HeroRun3.png differ diff --git a/html5/Arthur/res/HeroRun4.png b/html5/Arthur/res/HeroRun4.png new file mode 100755 index 0000000..52ab27b Binary files /dev/null and b/html5/Arthur/res/HeroRun4.png differ diff --git a/html5/Arthur/res/HeroRun5.png b/html5/Arthur/res/HeroRun5.png new file mode 100755 index 0000000..a7b9d85 Binary files /dev/null and b/html5/Arthur/res/HeroRun5.png differ diff --git a/html5/Arthur/res/HeroRun6.png b/html5/Arthur/res/HeroRun6.png new file mode 100755 index 0000000..148f099 Binary files /dev/null and b/html5/Arthur/res/HeroRun6.png differ diff --git a/html5/Arthur/res/HeroRun7.png b/html5/Arthur/res/HeroRun7.png new file mode 100755 index 0000000..e017c70 Binary files /dev/null and b/html5/Arthur/res/HeroRun7.png differ diff --git a/html5/Arthur/res/HeroRun8.png b/html5/Arthur/res/HeroRun8.png new file mode 100755 index 0000000..1355a5d Binary files /dev/null and b/html5/Arthur/res/HeroRun8.png differ diff --git a/html5/Arthur/res/HeroRun9.png b/html5/Arthur/res/HeroRun9.png new file mode 100755 index 0000000..7d17eeb Binary files /dev/null and b/html5/Arthur/res/HeroRun9.png differ diff --git a/html5/Arthur/res/HeroState1.png b/html5/Arthur/res/HeroState1.png new file mode 100644 index 0000000..81ffb3d Binary files /dev/null and b/html5/Arthur/res/HeroState1.png differ diff --git a/html5/Arthur/res/HeroState2.png b/html5/Arthur/res/HeroState2.png new file mode 100644 index 0000000..651da72 Binary files /dev/null and b/html5/Arthur/res/HeroState2.png differ diff --git a/html5/Arthur/res/HeroState3.png b/html5/Arthur/res/HeroState3.png new file mode 100644 index 0000000..4a71709 Binary files /dev/null and b/html5/Arthur/res/HeroState3.png differ diff --git a/html5/Arthur/res/HeroState4.png b/html5/Arthur/res/HeroState4.png new file mode 100644 index 0000000..569dcae Binary files /dev/null and b/html5/Arthur/res/HeroState4.png differ diff --git a/html5/Arthur/res/Joypad1.png b/html5/Arthur/res/Joypad1.png new file mode 100644 index 0000000..4d0a137 Binary files /dev/null and b/html5/Arthur/res/Joypad1.png differ diff --git a/html5/Arthur/res/Joypad2.png b/html5/Arthur/res/Joypad2.png new file mode 100644 index 0000000..c3989bd Binary files /dev/null and b/html5/Arthur/res/Joypad2.png differ diff --git a/html5/Arthur/res/Joypad3.png b/html5/Arthur/res/Joypad3.png new file mode 100644 index 0000000..5ef4965 Binary files /dev/null and b/html5/Arthur/res/Joypad3.png differ diff --git a/html5/Arthur/res/Joypad4.png b/html5/Arthur/res/Joypad4.png new file mode 100644 index 0000000..a5b862e Binary files /dev/null and b/html5/Arthur/res/Joypad4.png differ diff --git a/html5/Arthur/res/Robot1.png b/html5/Arthur/res/Robot1.png new file mode 100644 index 0000000..e8f855d Binary files /dev/null and b/html5/Arthur/res/Robot1.png differ diff --git a/html5/Arthur/res/Robot2.png b/html5/Arthur/res/Robot2.png new file mode 100644 index 0000000..0ba7da1 Binary files /dev/null and b/html5/Arthur/res/Robot2.png differ diff --git a/html5/Arthur/res/Robot3.png b/html5/Arthur/res/Robot3.png new file mode 100644 index 0000000..7bb3d3a Binary files /dev/null and b/html5/Arthur/res/Robot3.png differ diff --git a/html5/Arthur/res/RobotAttack1.png b/html5/Arthur/res/RobotAttack1.png new file mode 100644 index 0000000..2a999d2 Binary files /dev/null and b/html5/Arthur/res/RobotAttack1.png differ diff --git a/html5/Arthur/res/RobotAttack2.png b/html5/Arthur/res/RobotAttack2.png new file mode 100644 index 0000000..2faa027 Binary files /dev/null and b/html5/Arthur/res/RobotAttack2.png differ diff --git a/html5/Arthur/res/RobotAttack3.png b/html5/Arthur/res/RobotAttack3.png new file mode 100644 index 0000000..dd32e0d Binary files /dev/null and b/html5/Arthur/res/RobotAttack3.png differ diff --git a/html5/Arthur/res/RobotAttack4.png b/html5/Arthur/res/RobotAttack4.png new file mode 100644 index 0000000..5f5f866 Binary files /dev/null and b/html5/Arthur/res/RobotAttack4.png differ diff --git a/html5/Arthur/res/RobotAttack5.png b/html5/Arthur/res/RobotAttack5.png new file mode 100644 index 0000000..5875d4a Binary files /dev/null and b/html5/Arthur/res/RobotAttack5.png differ diff --git a/html5/Arthur/res/RobotRun1.png b/html5/Arthur/res/RobotRun1.png new file mode 100644 index 0000000..43aae3a Binary files /dev/null and b/html5/Arthur/res/RobotRun1.png differ diff --git a/html5/Arthur/res/RobotRun2.png b/html5/Arthur/res/RobotRun2.png new file mode 100644 index 0000000..3a32630 Binary files /dev/null and b/html5/Arthur/res/RobotRun2.png differ diff --git a/html5/Arthur/res/RobotRun3.png b/html5/Arthur/res/RobotRun3.png new file mode 100644 index 0000000..09f77b0 Binary files /dev/null and b/html5/Arthur/res/RobotRun3.png differ diff --git a/html5/Arthur/res/RobotRun4.png b/html5/Arthur/res/RobotRun4.png new file mode 100644 index 0000000..5ce4d6d Binary files /dev/null and b/html5/Arthur/res/RobotRun4.png differ diff --git a/html5/Arthur/res/RobotRun5.png b/html5/Arthur/res/RobotRun5.png new file mode 100644 index 0000000..a244839 Binary files /dev/null and b/html5/Arthur/res/RobotRun5.png differ diff --git a/html5/Arthur/res/RobotRun6.png b/html5/Arthur/res/RobotRun6.png new file mode 100644 index 0000000..57c6813 Binary files /dev/null and b/html5/Arthur/res/RobotRun6.png differ diff --git a/html5/Arthur/res/RobotState1.png b/html5/Arthur/res/RobotState1.png new file mode 100644 index 0000000..b1f7c99 Binary files /dev/null and b/html5/Arthur/res/RobotState1.png differ diff --git a/html5/Arthur/res/RobotState2.png b/html5/Arthur/res/RobotState2.png new file mode 100644 index 0000000..90e4674 Binary files /dev/null and b/html5/Arthur/res/RobotState2.png differ diff --git a/html5/Arthur/res/RobotState3.png b/html5/Arthur/res/RobotState3.png new file mode 100644 index 0000000..2d179ab Binary files /dev/null and b/html5/Arthur/res/RobotState3.png differ diff --git a/html5/Arthur/res/RobotState4.png b/html5/Arthur/res/RobotState4.png new file mode 100644 index 0000000..be838f9 Binary files /dev/null and b/html5/Arthur/res/RobotState4.png differ diff --git a/html5/Arthur/res/favicon.ico b/html5/Arthur/res/favicon.ico new file mode 100755 index 0000000..1ad6a09 Binary files /dev/null and b/html5/Arthur/res/favicon.ico differ diff --git a/html5/Arthur/res/fonts/futura-48.fnt b/html5/Arthur/res/fonts/futura-48.fnt new file mode 100755 index 0000000..50d6e48 --- /dev/null +++ b/html5/Arthur/res/fonts/futura-48.fnt @@ -0,0 +1,182 @@ +info face="Futura-CondensedExtraBold" size=48 bold=0 italic=0 charset="" unicode=0 stretchH=100 smooth=1 aa=1 padding=0,0,0,0 spacing=2,2 +common lineHeight=62 base=48 scaleW=512 scaleH=256 pages=1 packed=0 +page id=0 file="futura-48.png" +chars count=95 +char id=92 x=2 y=2 width=35 height=56 xoffset=0 yoffset=7 xadvance=32 page=0 chnl=0 letter="\" +char id=47 x=39 y=2 width=35 height=56 xoffset=-1 yoffset=7 xadvance=32 page=0 chnl=0 letter="/" +char id=125 x=76 y=2 width=22 height=56 xoffset=-1 yoffset=7 xadvance=19 page=0 chnl=0 letter="}" +char id=123 x=100 y=2 width=21 height=56 xoffset=1 yoffset=7 xadvance=19 page=0 chnl=0 letter="{" +char id=40 x=123 y=2 width=19 height=56 xoffset=1 yoffset=7 xadvance=18 page=0 chnl=0 letter="(" +char id=41 x=144 y=2 width=19 height=56 xoffset=0 yoffset=7 xadvance=18 page=0 chnl=0 letter=")" +char id=91 x=165 y=2 width=19 height=56 xoffset=2 yoffset=7 xadvance=18 page=0 chnl=0 letter="[" +char id=93 x=186 y=2 width=19 height=56 xoffset=0 yoffset=7 xadvance=18 page=0 chnl=0 letter="]" +char id=106 x=207 y=2 width=16 height=55 xoffset=0 yoffset=8 xadvance=13 page=0 chnl=0 letter="j" +char id=36 x=225 y=2 width=24 height=52 xoffset=3 yoffset=5 xadvance=28 page=0 chnl=0 letter="$" +char id=124 x=251 y=2 width=15 height=50 xoffset=7 yoffset=10 xadvance=27 page=0 chnl=0 letter="|" +char id=81 x=268 y=2 width=33 height=46 xoffset=0 yoffset=10 xadvance=31 page=0 chnl=0 letter="Q" +char id=100 x=303 y=2 width=28 height=45 xoffset=0 yoffset=7 xadvance=26 page=0 chnl=0 letter="d" +char id=98 x=333 y=2 width=28 height=45 xoffset=1 yoffset=7 xadvance=26 page=0 chnl=0 letter="b" +char id=107 x=363 y=2 width=29 height=44 xoffset=1 yoffset=7 xadvance=26 page=0 chnl=0 letter="k" +char id=63 x=394 y=2 width=28 height=44 xoffset=1 yoffset=8 xadvance=27 page=0 chnl=0 letter="?" +char id=104 x=424 y=2 width=27 height=44 xoffset=1 yoffset=7 xadvance=26 page=0 chnl=0 letter="h" +char id=102 x=453 y=2 width=21 height=44 xoffset=-1 yoffset=7 xadvance=16 page=0 chnl=0 letter="f" +char id=33 x=476 y=2 width=16 height=44 xoffset=2 yoffset=8 xadvance=17 page=0 chnl=0 letter="!" +char id=108 x=494 y=2 width=14 height=44 xoffset=1 yoffset=7 xadvance=13 page=0 chnl=0 letter="l" +char id=37 x=2 y=60 width=39 height=43 xoffset=0 yoffset=9 xadvance=37 page=0 chnl=0 letter="%" +char id=105 x=43 y=60 width=16 height=43 xoffset=0 yoffset=8 xadvance=13 page=0 chnl=0 letter="i" +char id=64 x=61 y=60 width=38 height=42 xoffset=1 yoffset=10 xadvance=37 page=0 chnl=0 letter="@" +char id=38 x=101 y=60 width=36 height=42 xoffset=1 yoffset=10 xadvance=34 page=0 chnl=0 letter="&" +char id=79 x=139 y=60 width=33 height=42 xoffset=0 yoffset=10 xadvance=30 page=0 chnl=0 letter="O" +char id=71 x=174 y=60 width=32 height=42 xoffset=0 yoffset=10 xadvance=30 page=0 chnl=0 letter="G" +char id=48 x=208 y=60 width=31 height=42 xoffset=0 yoffset=10 xadvance=28 page=0 chnl=0 letter="0" +char id=85 x=241 y=60 width=30 height=42 xoffset=1 yoffset=10 xadvance=29 page=0 chnl=0 letter="U" +char id=51 x=273 y=60 width=29 height=42 xoffset=1 yoffset=10 xadvance=28 page=0 chnl=0 letter="3" +char id=54 x=304 y=60 width=29 height=42 xoffset=1 yoffset=10 xadvance=28 page=0 chnl=0 letter="6" +char id=53 x=335 y=60 width=29 height=42 xoffset=1 yoffset=10 xadvance=28 page=0 chnl=0 letter="5" +char id=56 x=366 y=60 width=29 height=42 xoffset=1 yoffset=10 xadvance=28 page=0 chnl=0 letter="8" +char id=103 x=397 y=60 width=28 height=42 xoffset=0 yoffset=21 xadvance=26 page=0 chnl=0 letter="g" +char id=112 x=427 y=60 width=28 height=42 xoffset=1 yoffset=21 xadvance=26 page=0 chnl=0 letter="p" +char id=113 x=457 y=60 width=28 height=42 xoffset=0 yoffset=21 xadvance=26 page=0 chnl=0 letter="q" +char id=67 x=2 y=105 width=26 height=42 xoffset=0 yoffset=10 xadvance=24 page=0 chnl=0 letter="C" +char id=83 x=30 y=105 width=24 height=42 xoffset=0 yoffset=10 xadvance=21 page=0 chnl=0 letter="S" +char id=74 x=56 y=105 width=21 height=42 xoffset=-1 yoffset=10 xadvance=19 page=0 chnl=0 letter="J" +char id=87 x=79 y=105 width=45 height=41 xoffset=-1 yoffset=10 xadvance=40 page=0 chnl=0 letter="W" +char id=77 x=126 y=105 width=43 height=41 xoffset=0 yoffset=10 xadvance=41 page=0 chnl=0 letter="M" +char id=65 x=171 y=105 width=33 height=41 xoffset=-1 yoffset=10 xadvance=28 page=0 chnl=0 letter="A" +char id=86 x=206 y=105 width=32 height=41 xoffset=-1 yoffset=10 xadvance=28 page=0 chnl=0 letter="V" +char id=88 x=240 y=105 width=32 height=41 xoffset=-1 yoffset=10 xadvance=28 page=0 chnl=0 letter="X" +char id=90 x=274 y=105 width=32 height=41 xoffset=-1 yoffset=10 xadvance=27 page=0 chnl=0 letter="Z" +char id=89 x=308 y=105 width=31 height=41 xoffset=-1 yoffset=10 xadvance=27 page=0 chnl=0 letter="Y" +char id=52 x=341 y=105 width=31 height=41 xoffset=0 yoffset=10 xadvance=28 page=0 chnl=0 letter="4" +char id=75 x=374 y=105 width=31 height=41 xoffset=1 yoffset=10 xadvance=29 page=0 chnl=0 letter="K" +char id=82 x=407 y=105 width=31 height=41 xoffset=1 yoffset=10 xadvance=28 page=0 chnl=0 letter="R" +char id=55 x=440 y=105 width=31 height=41 xoffset=1 yoffset=10 xadvance=28 page=0 chnl=0 letter="7" +char id=68 x=473 y=105 width=30 height=41 xoffset=1 yoffset=10 xadvance=29 page=0 chnl=0 letter="D" +char id=78 x=2 y=149 width=30 height=41 xoffset=1 yoffset=10 xadvance=30 page=0 chnl=0 letter="N" +char id=50 x=34 y=149 width=30 height=41 xoffset=0 yoffset=10 xadvance=28 page=0 chnl=0 letter="2" +char id=66 x=66 y=149 width=30 height=41 xoffset=1 yoffset=10 xadvance=28 page=0 chnl=0 letter="B" +char id=72 x=98 y=149 width=29 height=41 xoffset=1 yoffset=10 xadvance=29 page=0 chnl=0 letter="H" +char id=80 x=129 y=149 width=29 height=41 xoffset=1 yoffset=10 xadvance=27 page=0 chnl=0 letter="P" +char id=57 x=160 y=149 width=29 height=41 xoffset=1 yoffset=10 xadvance=28 page=0 chnl=0 letter="9" +char id=121 x=191 y=149 width=29 height=41 xoffset=-1 yoffset=21 xadvance=24 page=0 chnl=0 letter="y" +char id=35 x=222 y=149 width=27 height=41 xoffset=2 yoffset=10 xadvance=28 page=0 chnl=0 letter="#" +char id=84 x=251 y=149 width=25 height=41 xoffset=-1 yoffset=10 xadvance=20 page=0 chnl=0 letter="T" +char id=69 x=278 y=149 width=23 height=41 xoffset=1 yoffset=10 xadvance=22 page=0 chnl=0 letter="E" +char id=70 x=303 y=149 width=22 height=41 xoffset=1 yoffset=10 xadvance=21 page=0 chnl=0 letter="F" +char id=76 x=327 y=149 width=22 height=41 xoffset=1 yoffset=10 xadvance=20 page=0 chnl=0 letter="L" +char id=49 x=351 y=149 width=18 height=41 xoffset=6 yoffset=10 xadvance=28 page=0 chnl=0 letter="1" +char id=73 x=371 y=149 width=15 height=41 xoffset=1 yoffset=10 xadvance=14 page=0 chnl=0 letter="I" +char id=60 x=388 y=149 width=29 height=39 xoffset=1 yoffset=11 xadvance=28 page=0 chnl=0 letter="<" +char id=62 x=419 y=149 width=29 height=39 xoffset=1 yoffset=11 xadvance=28 page=0 chnl=0 letter=">" +char id=59 x=450 y=149 width=20 height=39 xoffset=-2 yoffset=21 xadvance=14 page=0 chnl=0 letter=";" +char id=116 x=472 y=149 width=20 height=37 xoffset=-1 yoffset=14 xadvance=16 page=0 chnl=0 letter="t" +char id=111 x=2 y=192 width=28 height=31 xoffset=0 yoffset=21 xadvance=26 page=0 chnl=0 letter="o" +char id=97 x=32 y=192 width=28 height=31 xoffset=0 yoffset=21 xadvance=26 page=0 chnl=0 letter="a" +char id=101 x=62 y=192 width=28 height=31 xoffset=0 yoffset=21 xadvance=26 page=0 chnl=0 letter="e" +char id=117 x=92 y=192 width=27 height=31 xoffset=1 yoffset=21 xadvance=27 page=0 chnl=0 letter="u" +char id=115 x=121 y=192 width=24 height=31 xoffset=0 yoffset=21 xadvance=21 page=0 chnl=0 letter="s" +char id=99 x=147 y=192 width=19 height=31 xoffset=0 yoffset=21 xadvance=16 page=0 chnl=0 letter="c" +char id=58 x=168 y=192 width=16 height=31 xoffset=0 yoffset=21 xadvance=14 page=0 chnl=0 letter=":" +char id=119 x=186 y=192 width=41 height=30 xoffset=-1 yoffset=21 xadvance=37 page=0 chnl=0 letter="w" +char id=109 x=229 y=192 width=40 height=30 xoffset=1 yoffset=21 xadvance=39 page=0 chnl=0 letter="m" +char id=120 x=271 y=192 width=30 height=30 xoffset=-1 yoffset=21 xadvance=26 page=0 chnl=0 letter="x" +char id=118 x=303 y=192 width=29 height=30 xoffset=-1 yoffset=21 xadvance=24 page=0 chnl=0 letter="v" +char id=110 x=334 y=192 width=27 height=30 xoffset=1 yoffset=21 xadvance=26 page=0 chnl=0 letter="n" +char id=122 x=363 y=192 width=26 height=30 xoffset=0 yoffset=21 xadvance=23 page=0 chnl=0 letter="z" +char id=114 x=391 y=192 width=21 height=30 xoffset=1 yoffset=21 xadvance=18 page=0 chnl=0 letter="r" +char id=43 x=414 y=192 width=29 height=29 xoffset=1 yoffset=16 xadvance=28 page=0 chnl=0 letter="+" +char id=42 x=445 y=192 width=25 height=24 xoffset=3 yoffset=7 xadvance=28 page=0 chnl=0 letter="*" +char id=94 x=472 y=192 width=31 height=23 xoffset=-1 yoffset=10 xadvance=27 page=0 chnl=0 letter="^" +char id=44 x=2 y=225 width=19 height=22 xoffset=-2 yoffset=38 xadvance=14 page=0 chnl=0 letter="," +char id=34 x=23 y=225 width=24 height=20 xoffset=0 yoffset=10 xadvance=22 page=0 chnl=0 letter=""" +char id=39 x=49 y=225 width=14 height=20 xoffset=0 yoffset=10 xadvance=12 page=0 chnl=0 letter="'" +char id=61 x=65 y=225 width=29 height=19 xoffset=1 yoffset=21 xadvance=28 page=0 chnl=0 letter="=" +char id=46 x=96 y=225 width=16 height=16 xoffset=0 yoffset=36 xadvance=14 page=0 chnl=0 letter="." +char id=126 x=114 y=225 width=31 height=15 xoffset=4 yoffset=6 xadvance=36 page=0 chnl=0 letter="~" +char id=96 x=147 y=225 width=15 height=13 xoffset=5 yoffset=10 xadvance=27 page=0 chnl=0 letter="`" +char id=45 x=164 y=225 width=16 height=12 xoffset=-1 yoffset=30 xadvance=11 page=0 chnl=0 letter="-" +char id=95 x=182 y=225 width=32 height=11 xoffset=-1 yoffset=49 xadvance=27 page=0 chnl=0 letter="_" +char id=32 x=216 y=225 width=0 height=0 xoffset=-106 yoffset=168 xadvance=14 page=0 chnl=0 letter="space" +kernings count=82 +kerning first=81 second=81 amount=-1 +kerning first=63 second=93 amount=-2 +kerning first=63 second=100 amount=-3 +kerning first=63 second=98 amount=-3 +kerning first=63 second=37 amount=-5 +kerning first=63 second=38 amount=-5 +kerning first=63 second=90 amount=-5 +kerning first=63 second=78 amount=-5 +kerning first=63 second=80 amount=-5 +kerning first=63 second=84 amount=-2 +kerning first=63 second=76 amount=-5 +kerning first=63 second=58 amount=-1 +kerning first=63 second=94 amount=-5 +kerning first=63 second=44 amount=-4 +kerning first=63 second=96 amount=-2 +kerning first=63 second=32 amount=-1 +kerning first=65 second=93 amount=-2 +kerning first=65 second=100 amount=-2 +kerning first=65 second=37 amount=-2 +kerning first=65 second=38 amount=-2 +kerning first=65 second=90 amount=-3 +kerning first=65 second=80 amount=-3 +kerning first=65 second=84 amount=-1 +kerning first=65 second=76 amount=-4 +kerning first=65 second=44 amount=-4 +kerning first=65 second=96 amount=-2 +kerning first=55 second=100 amount=-2 +kerning first=55 second=63 amount=-4 +kerning first=55 second=65 amount=-4 +kerning first=55 second=68 amount=-4 +kerning first=55 second=66 amount=-4 +kerning first=55 second=32 amount=-2 +kerning first=68 second=92 amount=-4 +kerning first=68 second=91 amount=-4 +kerning first=68 second=37 amount=-3 +kerning first=68 second=38 amount=-3 +kerning first=68 second=90 amount=-4 +kerning first=68 second=80 amount=-4 +kerning first=68 second=84 amount=-2 +kerning first=68 second=76 amount=-4 +kerning first=68 second=97 amount=-3 +kerning first=68 second=44 amount=-4 +kerning first=68 second=96 amount=-3 +kerning first=68 second=32 amount=-1 +kerning first=66 second=93 amount=-1 +kerning first=66 second=37 amount=-1 +kerning first=66 second=38 amount=-1 +kerning first=66 second=90 amount=-1 +kerning first=66 second=80 amount=-1 +kerning first=66 second=76 amount=-2 +kerning first=66 second=44 amount=-2 +kerning first=66 second=96 amount=-1 +kerning first=70 second=125 amount=-5 +kerning first=70 second=123 amount=-5 +kerning first=49 second=44 amount=-3 +kerning first=60 second=125 amount=-5 +kerning first=60 second=123 amount=-5 +kerning first=60 second=81 amount=-1 +kerning first=59 second=41 amount=-3 +kerning first=59 second=101 amount=-1 +kerning first=59 second=44 amount=-4 +kerning first=59 second=32 amount=-1 +kerning first=58 second=81 amount=-3 +kerning first=58 second=61 amount=-3 +kerning first=43 second=35 amount=-1 +kerning first=42 second=105 amount=-3 +kerning first=44 second=100 amount=-1 +kerning first=44 second=98 amount=-1 +kerning first=44 second=63 amount=-4 +kerning first=44 second=65 amount=-4 +kerning first=44 second=68 amount=-4 +kerning first=44 second=66 amount=-2 +kerning first=44 second=97 amount=-1 +kerning first=44 second=32 amount=-3 +kerning first=61 second=63 amount=-1 +kerning first=61 second=65 amount=-1 +kerning first=61 second=68 amount=-1 +kerning first=61 second=66 amount=-1 +kerning first=32 second=63 amount=-1 +kerning first=32 second=71 amount=-3 +kerning first=32 second=68 amount=-1 +kerning first=32 second=44 amount=-3 diff --git a/html5/Arthur/res/fonts/futura-48.png b/html5/Arthur/res/fonts/futura-48.png new file mode 100755 index 0000000..796a33e Binary files /dev/null and b/html5/Arthur/res/fonts/futura-48.png differ diff --git a/html5/Arthur/src/ActionButton.js b/html5/Arthur/src/ActionButton.js new file mode 100644 index 0000000..fc6151e --- /dev/null +++ b/html5/Arthur/src/ActionButton.js @@ -0,0 +1,168 @@ +// ActionButton.js + +var ActionButton = cc.Node.extend({ + _sprite: null, + _rect: null, + _delegate: null, + _attackType: null, + + _childObj: null, + rect:function(){ + var size = this._sprite.getContentSize(); + return cc.rect(-size.width / 2, -size.height / 2, size.width, size.height); + }, + setChindObj:function(obj){ + this._childObj = obj; + }, + init:function(image){ + this._super(); + + this._sprite = cc.Sprite.create(image); + this.addChild(this._sprite); + return true; + }, + setDelegate:function(delegate){ + this._delegate = delegate; + }, + setAttackType:function(at){ + this._attackType = at; + }, + getAttackType:function(){ + return this._attackType; + }, + onEnter:function(){ + cc.Director.getInstance().getTouchDispatcher().addTargetedDelegate(this, 0, false); + this._super(); + }, + onExit:function(){ + cc.Director.getInstance().getTouchDispatcher().removeDelegate(this); + this._super(); + }, + containsTouchLocation:function(touch){ + return cc.rectContainsPoint(this.rect(), this.convertTouchToNodeSpace(touch)); + }, + onTouchBegan:function(touch, event){ + // 区域判断 + if (!this.containsTouchLocation(touch)) + return false; + this.click(); + // 播放点击动画 + return true; + }, + click:function(){ + if(this._delegate && this._childObj.isCanClick()){ + this._delegate.attackButtonClick(this.getAttackType()); + this.beganAnimation(); + } + }, + onTouchEnded:function(touch, event){ + this.endedAnimation(); + }, + beganAnimation:function(){ + }, + endedAnimation:function(){ + }, + isCanClick:function(){ + return true; + } +}); + +var AttackButton = ActionButton.extend({ + _pt: null, + _ac: null, + + _defaultScale: 0.35, + _maxScale: 0.5, + + _inAction: null, + _outAction: null, + + _timestamp: null, + ctor:function(){ + this._super(); + this._pt= cc.Sprite.create(s_AttackO); + this._pt.setScale(this._maxScale); + this.setChindObj(this); + + // this.addChild(this._pt); + + var aScale = cc.ScaleTo.create(0.1, this._defaultScale); + var aFadein = cc.FadeIn.create(0.1); + this._inAction = cc.Spawn.create(aScale, aFadein); + + var oScale = cc.ScaleTo.create(.2, this._maxScale); + var oFade = cc.FadeOut.create(0.2); + this._outAction = cc.Spawn.create(oScale, oFade); + }, + beganAnimation:function(){ + var timestamp = (new Date()).valueOf(); + this._timestamp = timestamp; + + this.removeChild(this._pt); + this.addChild(this._pt); + this._pt.runAction(this._inAction); + + }, + endedAnimation:function(){ + this._pt.stopAllActions(); + this._pt.runAction(this._outAction); + }, + clickUp:function(){ + this.endedAnimation(); + }, + isCanClick:function(){ + var timestamp = (new Date()).valueOf(); + return timestamp - this._timestamp > 600; + } +}); + +var AttackEffect = ActionButton.extend({ + _pt: null, + _ac: null, + _isCanClick: true, + ctor:function(){ + this._super(); + var h = cc.Sprite.create(s_AttackFreeze); + this._pt = cc.ProgressTimer.create(h); + this._pt.setType(cc.PROGRESS_TIMER_TYPE_RADIAL); + this._pt.setReverseDirection(true); + this._pt.setScale(0.43); + + var to = cc.ProgressTo.create(0, 99.999); + var to1 = cc.ProgressTo.create(2, 0); + var ac2 = cc.CallFunc.create(this.callBack, this); + this._ac = cc.Sequence.create(to, to1, ac2); + this.setChindObj(this); + }, + beganAnimation:function(){ + this.removeChild(this._pt); + this.addChild(this._pt); + this._pt.runAction(this._ac); + this._isCanClick = false; + }, + endedAnimation:function(){ + }, + callBack:function(){ + // cc.log("call back"); + this._isCanClick = true; + }, + isCanClick:function(){ + return this._isCanClick; + } +}); + +AttackButton.initWithImage = function(image){ + var ab = new AttackButton(); + if (ab && ab.init(image)){ + return ab; + } + return null; +}; + +AttackEffect.initWithImage = function(image){ + var ae = new AttackEffect(); + if (ae && ae.init(image)) + return ae; + return null; +}; + diff --git a/html5/Arthur/src/Characters.js b/html5/Arthur/src/Characters.js new file mode 100644 index 0000000..e88b079 --- /dev/null +++ b/html5/Arthur/src/Characters.js @@ -0,0 +1,407 @@ +// Character.js + +var ActionSprite = cc.Node.extend({ + _sprite: null, + _state: null, + + _isRun: false, + _RunDegrees: 0, + _speed: 300, + + _actionStand: null, + _actionRunning: null, + _actionAttack: null, + _actionAttackJump: null, + _actionAttackT: null, + + _zLocation: null, // 脚下所占的位置,y 坐标,用以判断 前后层次关系 + _flipX: false, + _imageflipX: false, // 默认图片是否面向右 + _attackRangt: 150, // 打击距离 + + _obj: null, + _blood: 100, + _bloodMax: 100, + _lossBlood: null, + _roleType: null, + + init:function(obj){ + var bRet = false; + if (this._super()){ + this._obj = obj; + + this.scheduleUpdate(); + + cc.NotificationCenter.getInstance().addObserver(this, this.acceptAttack, "attack", null); + + bRet = true; + } + cc.log("action sprite init ..."); + return bRet; + }, + acceptAttack:function(obj){ + if (this != obj){ + // 同一水平高度 + if (Math.abs(this.getZLocation() - obj.getZLocation()) < 30){ + cc.log("accept attack ..." + obj._attackRangt); + + // 距离 + var value = this.getPosition().x - obj.getPosition().x; + if (!obj.isFlip() && value >= 0 && value < obj._attackRangt){ + this.blood(); + }else if(obj.isFlip() && value <= 0 && -value < obj._attackRangt){ + this.blood(); + } + // cc.log("value: " + value); + } + } + }, + isFlip:function(){ + // return this._imageflipX ? !this._flipX: this._flipX; + return this._flipX; + }, + setSprite:function(image, pos){ + this._sprite = cc.Sprite.create(image); + this.addChild(this._sprite); + this.setPosition(pos); + }, + runWithDegrees:function(degrees){ + this._isRun = true; + this._RunDegrees = degrees; + // var x = Math.sin(this._RunDegrees * (2 * 3.14 / 360)) * 1; + this.hRunning(); + // cc.log("klt:" + this._isRun); + }, + moveWithDegrees:function(degrees){ + this._RunDegrees = degrees; + }, + idle:function(){ + this._isRun = false; + if (!this.isAttack()) + this.hStand(); + }, + update:function(dt){ + // 打斗时是不能够跑动的 + if (this._isRun && !this.isAttack()){ + + var x = Math.sin(this._RunDegrees * 2 * Math.PI / 360) * this._speed * dt; + var y = Math.cos(this._RunDegrees * 2 * Math.PI / 360) * this._speed * dt; + + var p = cc.p(-y, x); + if (y < 0){ + this._flipX = true; + this._sprite.setFlipX(!this._imageflipX); + } + if (y > 0){ + this._sprite.setFlipX(this._imageflipX); + this._flipX = false; + } + + this.setPosition(cc.pSub(this.getPosition(), p)); + } + this.checkLocation(); + this.ai(); + }, + ai:function(){ + + }, + checkLocation:function(){ + + // 检测当前位置,超出范围控制 + var curPoint = this.getPosition(); + var newPoint = this.getPosition(); + if (curPoint.x < 60) + newPoint.x = 60; + if (curPoint.y < 120) + newPoint.y = 120; + if (curPoint.x > _winSize.width - 60) + newPoint.x = _winSize.width - 60; + if (curPoint.y > _winSize.height / 2 + 80) + newPoint.y = _winSize.height / 2 + 80; + this.setPosition(newPoint); + }, + hStand:function(){ + this._sprite.stopAllActions(); + this._sprite.runAction(this._actionStand); + this._state = AC.STATE_HERO_STAND; + }, + hRunning:function(){ + this._sprite.stopAllActions(); + this._sprite.runAction(this._actionRunning); + this._state = AC.STATE_HERO_RUNNING; + }, + isAttack:function(){ + return this._state == AC.STATE_HERO_ATTACK; + }, + setZLocatoin:function(zl){ + this._zLocation = zl; + // var sprite = cc.Sprite.create(s_HeroState2); + // sprite.setPosition(cc.p(0, zl)); + // this.addChild(sprite); + }, + getZLocation:function(){ + return this.getPosition().y + this._zLocation; + }, + + blood:function(){ // 掉血 + var lb = 30; + this._blood -= lb; + this.removeChild(this._lossBlood); + this._lossBlood = cc.LabelTTF.create("-" + lb, AC.FONT, 20); + this._lossBlood.setPosition(cc.p(0, -this._zLocation)); + this.addChild(this._lossBlood); + + var fadeIn = cc.FadeIn.create(0.8); + var fadeOut = cc.FadeOut.create(1); + var mu = cc.MoveTo.create(1, cc.p(0, 30 + -this._zLocation)); + var a = cc.Spawn.create(fadeIn,fadeOut, mu); + // this._lossBlood.runAction(cc.Sequence.create(cc.DelayTime.create(0.5), a)); + this._lossBlood.runAction(a); + + // 控制掉血,发送一个掉血的消息 + cc.NotificationCenter.getInstance().postNotification("status", this); + }, + postAttack:function(){ + this.setAttackRect(); + cc.NotificationCenter.getInstance().postNotification("attack", this); + }, + setAttackRect:function(){ // 设置打击范围 + // cc.log("set attack rect ..."); + + // var point = this.getPosition(); + // var attackWidth = 100; + // + // var newPoint = this._flipX ? cc.pSub(point, cc.p(100, 0)) : point; + // this._attackRect = cc.rect(point.x - 100 * 2, point.y, 100, 5); + + // var tagLayer = 10001; + // var layer = cc.LayerColor.create(cc.c4b(0, 200, 200, 64), 100, 5); + // layer.setPosition(newPoint); + // this.getParent().removeChildByTag(tagLayer); + // this.getParent().addChild(layer, 0, tagLayer); + }, + getBloodPercent:function(){ + var p = this._blood / this._bloodMax; + cc.log("k" + p); + return p; + }, + setRoleType:function(type){ + this._roleType = type; + }, + getRoleType:function(){ + return this._roleType; + } +}); + +var Hero = ActionSprite.extend({ + + init:function(){ + var bRet = false; + if (this._super()){ + + this.setSprite(s_Hero1, cc.p(300, 300)); + this.setZLocatoin(-80); + this.initAction(); + this.hStand(); + this.setRoleType(AC.ROLE_HERO); + bRet = true; + } + return bRet; + }, + initAction:function(){ + // stand action + var sa = cc.Animation.create(); + for (var si = 1; si < 4; si++){ + var frameName1 = "res/Hero" + si + ".png"; + sa.addSpriteFrameWithFile(frameName1); + } + sa.setDelayPerUnit(5.8 / 14); + sa.setRestoreOriginalFrame(true); + this._actionStand = cc.RepeatForever.create(cc.Animate.create(sa)); + + // running action + var animation = cc.Animation.create(); + for (var i = 1; i < 12; i++){ + var frameName = "res/HeroRun" + i + ".png"; + animation.addSpriteFrameWithFile(frameName); + } + animation.setDelayPerUnit(2.8 / 14); + animation.setRestoreOriginalFrame(true); + this._actionRunning = cc.RepeatForever.create(cc.Animate.create(animation)); + + + // 普通攻击 + var anAttack = cc.Animation.create(); + for (var attackIndex = 1; attackIndex < 6; attackIndex ++){ + var attackFrame = "res/HeroAttack" + attackIndex + ".png"; + anAttack.addSpriteFrameWithFile(attackFrame); + } + anAttack.setDelayPerUnit(1.8 / 14); + // anAttack.setRestoreOriginalFrame(false); + this._actionAttack = cc.Animate.create(anAttack); + + // 跳跃攻击 + var jmpAttack = cc.Animation.create(); + for (var ji = 1; ji < 9; ji ++){ + var jiFrame = "res/HeroAttackJ" + ji + ".png"; + jmpAttack.addSpriteFrameWithFile(jiFrame); + } + jmpAttack.setDelayPerUnit(0.1); + // jmpAttack.setRestoreOriginalFrame(false) + this._actionAttackJump = cc.Animate.create(jmpAttack); + + // 突刺攻击 + var tAttack = cc.Animation.create(); + for (var ti = 1; ti < 4; ti ++){ + var tiFrame = "res/HeroAttackT" + ti + ".png"; + tAttack.addSpriteFrameWithFile(tiFrame); + } + tAttack.setDelayPerUnit(0.1); + this._actionAttackT = cc.Animate.create(tAttack); + }, + hAttack:function(at){ + var aa = null; + if (at == AT.ATTACK){ + aa = this._actionAttack; + this._attackRangt = 150; + }else if (at == AT.ATTACK_A){ + aa = this._actionAttackJump; + // 当前位置跳跃 + var jump = cc.JumpTo.create( + 0.6, cc.pSub(this.getPosition(), cc.p(this._flipX ? 200: -200)), 120, 1); + this.runAction(jump); + this._attackRangt = 300; + }else if (at == AT.ATTACK_B){ + aa = this._actionAttackT; + // 当前位置移动 + var move = cc.MoveTo.create(0.3, cc.pSub(this.getPosition(), cc.p( + this._flipX ? 200:-200, 0))); + this.runAction(move); + this._attackRangt = 300; + } + + if (aa){ + this._sprite.stopAllActions(); + var action = cc.Sequence.create( + aa, + cc.CallFunc.create(this.callBackEndAttack, this)); + this._sprite.runAction(action); + this._state = AC.STATE_HERO_ATTACK; + this.postAttack(); + } + }, + attack:function(at){ + this.hAttack(at); + }, + callBackEndAttack:function(){ + if (this._isRun){ + this.hRunning(); + }else{ + this.hStand(); + } + } +}); + +Hero.create = function(){ + var hero = new Hero(); + if (hero && hero.init(hero)){ + return hero; + } + return null; +}; + + +var Robot = ActionSprite.extend({ + init:function(){ + var bRet = false; + if (this._super()){ + + this.setSprite(s_RobotAttack1, cc.p(500, 300)); + this.setZLocatoin(-80); + this.initAction(); + this.runWithDegrees(180); + cc.log("robot init"); + this.setRoleType(AC.ROLE_ROBOT); + this._imageflipX = true; + bRet = true; + this._speed = 150; + } + return bRet; + }, + initAction:function(){ + // action stand + var as = cc.Animation.create(); + for (var si = 1; si < 4; si++){ + var asFrame = "res/Robot" + si + ".png"; + as.addSpriteFrameWithFile(asFrame); + } + as.setDelayPerUnit(0.45); + as.setRestoreOriginalFrame(true); + this._actionStand = cc.RepeatForever.create(cc.Animate.create(as)); + + // action running + var ar = cc.Animation.create(); + for (var ri = 1; ri < 7; ri++){ + riFrame = "res/RobotRun" + ri + ".png"; + ar.addSpriteFrameWithFile(riFrame); + } + ar.setDelayPerUnit(0.15); + ar.setRestoreOriginalFrame(true); + this._actionRunning = cc.RepeatForever.create(cc.Animate.create(ar)); + + // attack + var aa = cc.Animation.create(); + for (var ai = 1; ai < 6; ai ++){ + aiFrame = "res/RobotAttack" + ai + ".png"; + aa.addSpriteFrameWithFile(aiFrame); + } + aa.setDelayPerUnit(0.2); + this._actionAttack = cc.Animate.create(aa); + + cc.log("robot init action"); + }, + hAttack:function(at){ + var aa = this._actionAttack; + this._attackRangt = 150; + if (aa){ + this._sprite.stopAllActions(); + var action = cc.Sequence.create( + aa, + cc.CallFunc.create(this.callBackEndAttack, this)); + this._sprite.runAction(action); + this._state = AC.STATE_HERO_ATTACK; + this.postAttack(); + } + }, + attack:function(button){ + this.hAttack(button); + }, + callBackEndAttack:function(){ + if (this._isRun){ + this.hRunning(); + }else{ + this.hStand(); + } + }, + _timestamp: (new Date()).valueOf(), + ai:function(){ + var newTs = (new Date()).valueOf(); + var value = newTs - this._timestamp; + // cc.log("ai ai ..." + value); + if (value % 3000 < 300 && !this.isAttack()){ + this.attack(); + } + var r = Math.random() * 360; + if (value % 6000 < 300) + this.moveWithDegrees(r); + } +}); + +Robot.create = function(){ + var robot = new Robot(); + if (robot && robot.init(robot)){ + return robot; + } + return null; +}; + diff --git a/html5/Arthur/src/GameConfig.js b/html5/Arthur/src/GameConfig.js new file mode 100644 index 0000000..c6cbd30 --- /dev/null +++ b/html5/Arthur/src/GameConfig.js @@ -0,0 +1,20 @@ +// Arthur Config + +var AC = AC || {}; + +AC.KEYS = []; + +AC.STATE_HERO_STAND = 0; +AC.STATE_HERO_RUNNING = 1; +AC.STATE_HERO_ATTACK = 2; + +AC.FONT = "Tahoma"; + +AC.ROLE_HERO = 0; +AC.ROLE_ROBOT = 1; + +// attack type +var AT = AT || {}; +AT.ATTACK = 1; +AT.ATTACK_A = 2; +AT.ATTACK_B = 3; diff --git a/html5/Arthur/src/GameLayer.js b/html5/Arthur/src/GameLayer.js new file mode 100644 index 0000000..5f709ee --- /dev/null +++ b/html5/Arthur/src/GameLayer.js @@ -0,0 +1,92 @@ + +var GameLayer = cc.Layer.extend({ + mWinSize:null, + mPointCenter:null, + mHero: null, + mRobot: null, + init:function(){ + cc.log("game layer init ..."); + var bRef = false; + if(this._super()){ + mWinSize = cc.Director.getInstance().getWinSize(); + mPointCenter = cc.p(mWinSize.width / 2, mWinSize.height / 2); + + // 添加背景 + var backGround = cc.Sprite.create(s_BackGround); + backGround.setPosition(mPointCenter); + this.addChild(backGround); + + // 添加英雄 + this.mHero = Hero.create(); + + // 添加机器人 + this.mRobot = Robot.create(); + + var characters = cc.Node.create(); + characters.addChild(this.mHero); + characters.addChild(this.mRobot); + this.addChild(characters); + + // 添加控制层 + var hudLayer = HudLayer.create(); + this.addChild(hudLayer); + hudLayer.setDelegate(this); + + if (sys["capabilities"].hasOwnProperty('keyboard')) + this.setKeyboardEnabled(true); + + this.scheduleUpdate(); + + + bRef = true; + } + return bRef; + }, + actionJoypadStart:function(degrees){ + this.mHero.runWithDegrees(degrees); + // this.mRobot.runWithDegrees(degrees); + }, + actionJoypadUpdate:function(degrees){ + this.mHero.moveWithDegrees(degrees); + // this.mRobot.moveWithDegrees(degrees); + }, + actionJoypadEnded:function(degrees){ + this.mHero.idle(); + // this.mRobot.idle(); + }, + attackButtonClick:function(button){ + this.mHero.attack(button); + // this.mRobot.attack(button); + }, + onKeyDown:function(e){ + // 保存所有的按键信息 + AC.KEYS[e] = true; + }, + onKeyUp:function(e){ + AC.KEYS[e] = false; + }, + update:function(dt){ + var b = this.mHero.getZLocation() > this.mRobot.getZLocation(); + this.mHero.setZOrder(b ? 0: 1); + this.mRobot.setZOrder(b ? 1: 0) ; + } +}); + +GameLayer.create = function(){ + var sg = new GameLayer(); + if (sg && sg.init()){ + return sg; + } + return null; +}; + +GameLayer.scene = function(){ + var scene = cc.Scene.create(); + // var layer = new GameLayer(); + // layer.init(); + var layer = GameLayer.create(); + scene.addChild(layer); + return scene; +}; + + diff --git a/html5/Arthur/src/HudLayer.js b/html5/Arthur/src/HudLayer.js new file mode 100644 index 0000000..d123d7f --- /dev/null +++ b/html5/Arthur/src/HudLayer.js @@ -0,0 +1,214 @@ +// HudLayer.js + +var State = cc.Node.extend({ + _bloodSprite: null, + _roleType: null, + ctor:function(){ + this._super(); + }, + setBloodSprite:function(obj){ + this._bloodSprite = obj; + }, + init:function(){ + var bRet = false; + + if(this._super()){ + cc.NotificationCenter.getInstance().addObserver(this, this.notifyChangeStatus, "status", null); + + bRet = true; + } + + return bRet; + }, + notifyChangeStatus:function(obj){ + if (obj.getRoleType() == this._roleType){ + cc.log("notify status ..."); + this.setBlood(obj.getBloodPercent()); + } + }, + setBlood:function(value){ + // 显示血量百分比 + if (value < 0) + value = 0; + if (value > 1) + value = 1; + this._bloodSprite.setScaleX(value); + }, + setRoleType:function(type){ + this._roleType = type; + } +}); + +State.create = function(){ + var state = new State(); + if (state && state.init()){ + return state; + } + return null; +}; + +State.createHero = function(){ + var state = State.create(); + + + var s1 = cc.Sprite.create(s_HeroState1); + var s2 = cc.Sprite.create(s_HeroState2); + var s3 = cc.Sprite.create(s_HeroState3); + var s4 = cc.Sprite.create(s_HeroState4); + + s1.setPosition(cc.p(-80, 3)); + s2.setPosition(cc.p(33, 15)); + + s3.setPosition(cc.p(-45, -12)); + s3.setAnchorPoint(cc.p(0, 0)); + + state.setBloodSprite(s3); + + state.addChild(s1); + state.addChild(s2); + state.addChild(s3); + state.addChild(s4); + state.setRoleType(AC.ROLE_HERO); + + var title = cc.LabelTTF.create("Lv7 一叶", "Tahoma", 14); + title.setPosition(cc.p(-15, 30)); + state.addChild(title); + + + return state; +}; + +State.createRobot = function(){ + var state = State.create(); + var s1 = cc.Sprite.create(s_RobotState1); + var s2 = cc.Sprite.create(s_RobotState2); + var s3 = cc.Sprite.create(s_RobotState3); + var s4 = cc.Sprite.create(s_RobotState4); + + s1.setPosition(cc.p(50, -16)); + state.setBloodSprite(s1); + s1.setAnchorPoint(cc.p(1, 0)); + + // s1.ignoreAnchorPointForPosition(true); + + s2.setPosition(cc.p(-20, -7)); + s4.setPosition(cc.p(65, 1)); + + state.setRoleType(AC.ROLE_ROBOT); + + state.addChild(s2); + state.addChild(s1); + state.addChild(s3); + state.addChild(s4); + + var title = cc.LabelTTF.create("Lv5 子龙山人", "Tahoma", 14); + title.setPosition(cc.p(-15, 12)); + state.addChild(title); + + return state; +}; + +var HudLayer = cc.Layer.extend({ + _winSize: null, + _pCenter: null, + _delegate: null, + + mJoypad: null, + mStateHero: null, + mStateRobot: null, + + mAttack: null, + mAttackA: null, + mAttackB: null, + ctor:function(){ + this._super(); + _winSize = cc.Director.getInstance().getWinSize(); + _pCenter = cc.p(_winSize.width / 2, _winSize.height / 2); + }, + init:function(){ + cc.log("Hud layer init .."); + var bRet = false; + + if(this._super()){ + + // 添加控制器 + this.mJoypad = Joypad.create(); + this.addChild(this.mJoypad); + + var keyMap = KeyMap.create(); + keyMap.setDelegateJoypad(this.mJoypad); + keyMap.setDelegateAttack(this); + this.addChild(keyMap); + + // 添加攻击按钮 + + this.mAttack = AttackButton.initWithImage(s_Attack); + this.mAttack.setPosition(cc.p(mWinSize.width - 80, 80)); + this.mAttack.setDelegate(this); + this.mAttack.setAttackType(AT.ATTACK); + this.addChild(this.mAttack); + + // 添加特效攻击 + // var attackA = cc.Sprite.create(s_AttackA); + this.mAttackA = AttackEffect.initWithImage(s_AttackA); + this.mAttackA.setPosition(cc.p(mWinSize.width - 200, 60)); + this.mAttackA.setDelegate(this); + this.mAttackA.setAttackType(AT.ATTACK_A); + this.addChild(this.mAttackA); + + // var attackB = cc.Sprite.create(s_AttackB); + this.mAttackB = AttackEffect.initWithImage(s_AttackB); + this.mAttackB.setPosition(cc.p(mWinSize.width - 165, 165)); + this.mAttackB.setDelegate(this); + this.mAttackB.setAttackType(AT.ATTACK_B); + this.addChild(this.mAttackB); + + // 添加 Hero 血条状态 + this.mStateHero = State.createHero(); + this.mStateHero.setPosition(cc.p(130, _winSize.height - 55)); + this.addChild(this.mStateHero); + + // 怪物血条 + this.mStateRobot = State.createRobot(); + this.mStateRobot.setPosition(cc.p(800 - 100, _winSize.height - 35)); + this.addChild(this.mStateRobot); + + bRet = true; + } + return bRet; + }, + setDelegate: function(delegate){ + this._delegate = delegate; + this.mJoypad.setDelegate(delegate); + }, + + attackButtonClick:function(button){ + if (this._delegate){ + this._delegate.attackButtonClick(button); + } + }, + keyAttack:function(btnType){ + if (btnType == AT.ATTACK_A && this.mAttackA.isCanClick()) + this.mAttackA.click(); + if (btnType == AT.ATTACK_B && this.mAttackB.isCanClick()) + this.mAttackB.click(); + if (btnType == AT.ATTACK && this.mAttack.isCanClick()) + this.mAttack.click(); + + // this.attackButtonClick(bunType); + }, + keyAttackUp:function(btnType){ + if (btnType == AT.ATTACK) // && this.mAttack.isCanClick()) + this.mAttack.clickUp(); + } +}); + +HudLayer.create = function(){ + var hudlayer = new HudLayer(); + if (hudlayer && hudlayer.init()){ + return hudlayer; + } + return null; +}; + + diff --git a/html5/Arthur/src/Joypad.js b/html5/Arthur/src/Joypad.js new file mode 100644 index 0000000..c3c47ea --- /dev/null +++ b/html5/Arthur/src/Joypad.js @@ -0,0 +1,129 @@ +// Joypad.js + +var Joypad = cc.Layer.extend({ + _winSize: null, + _pCenter: null, + _pControlSprite: null, + _pDefaultPoint: null, + + _pDefaultRotation: null, + _pRotation: null, + + _pDelegate: null, + _pKeyDown: false, + ctor:function(){ + this._super(); + + _winSize = cc.Director.getInstance().getWinSize(); + _pCenter = cc.p(_winSize.width / 2, _winSize.height / 2); + + }, + init:function(){ + var bRet = false; + if (this._super()){ + cc.log("Joypad init .."); + // 控制杆所在位置 + this._pDefaultPoint = cc.p(110, 110); + // 默认旋转角度,以使开口正对右侧 + this._pDefaultRotation = 26; + // 实际旋转角度 + this._pRotation = 0; + + this.setPosition(this._pDefaultPoint); + + this.addChild(cc.Sprite.create(s_Joypad1)); + this.addChild(cc.Sprite.create(s_Joypad2)); + this._pControlSprite = cc.Sprite.create(s_Joypad3); + this.addChild(this._pControlSprite); + this.addChild(cc.Sprite.create(s_Joypad4)); + + this.updateRotation(); + + bRet = true; + } + return bRet; + }, + keyStart:function(degrees){ + if (this._pDelegate) + this._pDelegate.actionJoypadStart(this._pRotation); + }, + keyUpdate:function(degrees){ + this._pRotation = degrees; + this.updateRotation(); + if (this._pDelegate) + this._pDelegate.actionJoypadUpdate(this._pRotation); + }, + keyEnded:function(degrees){ + if (this._pDelegate) + this._pDelegate.actionJoypadEnded(this._pRotation); + }, + onEnter:function(){ + this._super(); + cc.Director.getInstance().getTouchDispatcher().addTargetedDelegate(this, 0, true); + }, + onTouchBegan:function (touch, event){ + // 点击点的范围判断 + var curPoint = touch.getLocation(); + if (curPoint.x > _winSize.width / 2 || curPoint.y > _winSize.height / 2 ){ + return false; + } + + // var sp = cc.pSub(this._pDefaultPoint, curPoint); + // var angle = cc.pToAngle(sp); + + this.updateTouchRotation(touch, event); + this.updateRotation(); + if(this._pDelegate) + this._pDelegate.actionJoypadStart(this._pRotation); + else + cc.log('_pDelegate is null ... '); + + // cc.log("Joypad touch ..."); + return true; + }, + onTouchMoved:function (touch, event){ + this.updateTouchRotation(touch, event); + this.updateRotation(); + + if (this._pDelegate) + this._pDelegate.actionJoypadUpdate(this._pRotation); + else + cc.log('_pDelegate is null ... '); + + // var a = cc.pAngleSigned( curPoint, this._pDefaultPoint); + // cc.log("Joypad touch mvove ..." + rotation) ; + }, + onTouchEnded:function (touch, event){ + this.updateTouchRotation(touch, event); + this.updateRotation(); + if (this._pDelegate) + this._pDelegate.actionJoypadEnded(this._pRotation); + else + cc.log('_pDelegate is null ... '); + }, + updateTouchRotation:function(touch, event){ + var curPoint = touch.getLocation(); + var sp = cc.pSub(curPoint, this._pDefaultPoint); + var angle = cc.pToAngle(sp) ;// * -57.29577951; + var rotation = angle * -57.29577951; + rotation = rotation < 0 ? 360 + rotation: rotation; + this._pRotation = rotation; + }, + updateRotation:function(){ + this._pControlSprite.setRotation(this._pDefaultRotation + this._pRotation); + }, + setDelegate:function(dg){ + this._pDelegate = dg; + } +}); + +Joypad.create = function(){ + var joypad = new Joypad(); + if (joypad && joypad.init()){ + return joypad; + } + return null; +}; + + + diff --git a/html5/Arthur/src/KeyMap.js b/html5/Arthur/src/KeyMap.js new file mode 100644 index 0000000..fc3e25d --- /dev/null +++ b/html5/Arthur/src/KeyMap.js @@ -0,0 +1,142 @@ +// KeyMap.js + +var KeyMap = cc.Layer.extend({ + _delegateJoypad: null, + _delegateAttack: null, + _pJoyKeyDown: false, + _pJKeyDown: false, + _pUKeyDown: false, + _pIKeyDown: false, + init:function(){ + this._super(); + this.scheduleUpdate(); + return true; + }, + setDelegateJoypad:function(delegate){ + this._delegateJoypad = delegate; + }, + setDelegateAttack:function(delegate){ + this._delegateAttack = delegate; + }, + update:function(dt){ + this._super(); + + // 控制杆键盘映射处理 + var au = false; + var al = false; + var ad = false; + var ar = false; + + if ((AC.KEYS[cc.KEY.w] || AC.KEYS[cc.KEY.up])){ + au = true; + } + if ((AC.KEYS[cc.KEY.a] || AC.KEYS[cc.KEY.left])){ + al = true; + } + if ((AC.KEYS[cc.KEY.s] || AC.KEYS[cc.KEY.down])){ + ad = true; + } + if ((AC.KEYS[cc.KEY.d] || AC.KEYS[cc.KEY.right])){ + ar = true; + } + + var newDegrees = -1; + if (au && !al && !ad && !ar) + newDegrees = 270; + if (!au && al && !ad && !ar) + newDegrees = 180; + if (!au && !al && ad && !ar) + newDegrees = 90; + if (!au && !al && !ad && ar) + newDegrees = 0; + + if (au && al && !ad && !ar) + newDegrees = 225; + if (!au && al && ad && !ar) + newDegrees = 135; + if (!au && !al && ad && ar) + newDegrees = 45; + if (au && !al && !ad && ar) + newDegrees = -45; + + if (this._delegateJoypad){ + if (au || al || ad || ar){ + if (!this._pJoyKeyDown) + this._delegateJoypad.keyStart(newDegrees); + this._pJoyKeyDown = true; + } + else if(this._pJoyKeyDown){ + this._pJoyKeyDown = false; + this._delegateJoypad.keyEnded(newDegrees); + } + if (newDegrees != -1 && this._pJoyKeyDown){ + this._delegateJoypad.keyUpdate(newDegrees); + } + } + + + // 攻击按钮控制映射 + var keyJ = false; + var keyU = false; + var keyI = false; + if (AC.KEYS[cc.KEY.j]) + keyJ = true; + if (AC.KEYS[cc.KEY.u]) + keyU = true; + if (AC.KEYS[cc.KEY.i]) + keyI = true; + + var pressJ = false; + var pressU = false; + var pressI = false; + + if (keyJ){ + if (!this._pJKeyDown){ + this._pJKeyDown = true; + pressJ = true; + } + }else{ + if (this._pJKeyDown){ + // 发送一个攻击键松开的操作 + this._delegateAttack.keyAttackUp(AT.ATTACK); + } + this._pJKeyDown = false; + } + + if (keyU){ + if (!this._pUKeyDown){ + this._pUKeyDown = true; + pressU = true; + } + }else{ + this._pUKeyDown = false; + } + + if (keyI){ + if (!this._pIKeyDown){ + this._pIKeyDown = true; + pressI = true; + } + }else{ + this._pIKeyDown = false; + } + + if (this._delegateAttack){ + if (pressJ) + this._delegateAttack.keyAttack(AT.ATTACK); + if (pressU) + this._delegateAttack.keyAttack(AT.ATTACK_A); + if (pressI) + this._delegateAttack.keyAttack(AT.ATTACK_B); + } + + } +}); + +KeyMap.create = function(){ + var km = new KeyMap(); + if (km && km.init()) + return km; + return null; +}; + diff --git a/html5/Arthur/src/Loading.js b/html5/Arthur/src/Loading.js new file mode 100644 index 0000000..88e8635 --- /dev/null +++ b/html5/Arthur/src/Loading.js @@ -0,0 +1,182 @@ + +var logoData = ""; + +// cc.LoaderScene.prototype.init = function(){ +// cc.Scene.prototype.init.call(this); +// var logoHeight = 200; +// var centerPos = cc.p(this._winSize.width / 2, this._winSize.height / 2); + +// this._logoTexture = new Image(); +// var _this = this; +// this._logoTexture.addEventListener("load", function () { +// _this._initStage(centerPos); +// }); +// this._logoTexture.src = logoData; +// // this._logoTexture.width = 160; +// // this._logoTexture.height = 200; +// this._logoTexture.width = 242; +// this._logoTexture.height = 114; + +// // bg +// this._bgLayer = cc.LayerColor.create(cc.c4(232, 232, 232, 255)); +// this._bgLayer.setPosition(cc.p(0, 0)); +// this.addChild(this._bgLayer, 0); + +// //loading percent +// this._label = cc.LabelTTF.create("Loading... 0%", "Arial", 14); +// this._label.setColor(cc.c3(180, 180, 180)); +// this._label.setOpacity(0); +// this._label.setPosition(cc.pAdd(centerPos, cc.p(0, -logoHeight / 2 - 10))); +// this._label.setPosition(cc.pAdd(centerPos, cc.p(0, -logoHeight / 2 - 100))); +// this._bgLayer.addChild(this._label, 10); +// }; + +/** + * Used to display the loading screen + * @class + * @extends cc.Scene + */ +Loading = cc.Scene.extend(/** @lends cc.LoaderScene# */{ + _logo: null, + _logoTexture: null, + _texture2d: null, + _bgLayer: null, + _label: null, + _winSize:null, + _processLayer: null, + _processLayerLength: null, + + /** + * Constructor + */ + ctor: function () { + this._super(); + this._winSize = cc.Director.getInstance().getWinSize(); + }, + init:function(){ + cc.Scene.prototype.init.call(this); + + //logo + var logoHeight = 200; + var centerPos = cc.p(this._winSize.width / 2, this._winSize.height / 2); + + this._logoTexture = new Image(); + var _this = this; + this._logoTexture.addEventListener("load", function () { + _this._initStage(centerPos); + }); + this._logoTexture.src = logoData; + this._logoTexture.width = 242; + this._logoTexture.height = 114; + + // bg + this._bgLayer = cc.LayerColor.create(cc.c4(200, 200, 200, 255)); + this._bgLayer.setPosition(cc.p(0, 0)); + this.addChild(this._bgLayer, 0); + + //loading percent + this._label = cc.LabelTTF.create("Loading... 0%", "Arial", 14); + this._label.setColor(cc.c3(80, 80, 80)); + this._label.setOpacity(0); + // this._label.setPosition(cc.pAdd(centerPos, cc.p(0, -logoHeight / 2 - 10))); + this._label.setPosition(cc.pAdd(centerPos, cc.p(0, -logoHeight / 2 - 100))); + this._bgLayer.addChild(this._label, 10); + + this._processLayerLength = 500; + this._processLayer = cc.LayerColor.create(cc.c4b(255, 100, 100, 128), 1, 30); + this._processLayer.setPosition(cc.pAdd(centerPos, cc.p(- this._processLayerLength / 2, -logoHeight / 2 - 50))); + // this._processLayer.ignoreAnchorPointForPosition(false); + // this._processLayer.setAnchorPoint(cc.p(0, 0)); + this._bgLayer.addChild(this._processLayer); + }, + + _initStage: function (centerPos) { + if (cc.renderContextType === cc.CANVAS) { + this._logo = cc.Sprite.createWithTexture(this._logoTexture); + } else { + this._texture2d = new cc.Texture2D(); + this._texture2d.initWithElement(this._logoTexture); + this._texture2d.handleLoadedTexture(); + this._logo = cc.Sprite.createWithTexture(this._texture2d); + } + this._logo.setPosition(centerPos); + this._bgLayer.addChild(this._logo, 10); + + //load resources + this._logoFadeIn(); + }, + + onEnter: function () { + cc.Node.prototype.onEnter.call(this); + this.schedule(this._startLoading, 0.3); + }, + + onExit: function () { + cc.Node.prototype.onExit.call(this); + var tmpStr = "Loading... 0%"; + this._label.setString(tmpStr); + }, + + /** + * init with resources + * @param {Array} resources + * @param {Function|String} selector + * @param {Object} target + */ + initWithResources: function (resources, selector, target) { + this.resources = resources; + this.selector = selector; + this.target = target; + }, + + _startLoading: function () { + this.unschedule(this._startLoading); + cc.Loader.preload(this.resources, this.selector, this.target); + this.schedule(this._updatePercent); + }, + + _logoFadeIn: function () { + var logoAction = cc.Spawn.create( + cc.EaseBounce.create(cc.MoveBy.create(0.25, cc.p(0, 10))), + cc.FadeIn.create(0.5)); + + var labelAction = cc.Sequence.create( + cc.DelayTime.create(0.15), + logoAction.clone()); + + this._logo.runAction(logoAction); + this._label.runAction(labelAction); + }, + + _updatePercent: function () { + var percent = cc.Loader.getInstance().getPercentage(); + var tmpStr = "Loading... " + percent + "%"; + this._label.setString(tmpStr); + + this._processLayer.changeWidth(this._processLayerLength * percent / 100); + + if (percent >= 100) + this.unschedule(this._updatePercent); + } +}); + +Loading.preload = function (resources, selector, target) { + if (!this._instance) { + this._instance = new Loading(); + this._instance.init(); + } + + this._instance.initWithResources(resources, selector, target); + + var director = cc.Director.getInstance(); + if (director.getRunningScene()) { + director.replaceScene(this._instance); + + } else { + director.runWithScene(this._instance); + } + + return this._instance; +}; + + diff --git a/html5/Arthur/src/resource.js b/html5/Arthur/src/resource.js new file mode 100755 index 0000000..0cc018a --- /dev/null +++ b/html5/Arthur/src/resource.js @@ -0,0 +1,166 @@ +var s_HelloWorld = "res/HelloWorld.png"; +var s_CloseNormal = "res/CloseNormal.png"; +var s_CloseSelected = "res/CloseSelected.png"; + +var s_BackGround = "res/BackGround.png"; +var s_Attack = "res/Attack.png"; +var s_AttackO = "res/AttackO.png"; +var s_AttackA = "res/AttackA.png"; +var s_AttackB = "res/AttackB.png"; +var s_AttackFreeze = "res/AttackFreeze.png"; + +var s_Joypad1 = "res/Joypad1.png"; +var s_Joypad2 = "res/Joypad2.png"; +var s_Joypad3 = "res/Joypad3.png"; +var s_Joypad4 = "res/Joypad4.png"; + + +var s_Hero1 = "res/Hero1.png"; +var s_Hero2 = "res/Hero2.png"; +var s_Hero3 = "res/Hero3.png"; + +var s_HeroState1 = "res/HeroState1.png"; +var s_HeroState2 = "res/HeroState2.png"; +var s_HeroState3 = "res/HeroState3.png"; +var s_HeroState4 = "res/HeroState4.png"; + +var s_HeroRun1 = "res/HeroRun1.png"; +var s_HeroRun2 = "res/HeroRun2.png"; +var s_HeroRun3 = "res/HeroRun3.png"; +var s_HeroRun4 = "res/HeroRun4.png"; +var s_HeroRun5 = "res/HeroRun5.png"; +var s_HeroRun6 = "res/HeroRun6.png"; +var s_HeroRun7 = "res/HeroRun7.png"; +var s_HeroRun8 = "res/HeroRun8.png"; +var s_HeroRun9 = "res/HeroRun9.png"; +var s_HeroRun10 = "res/HeroRun10.png"; +var s_HeroRun11 = "res/HeroRun11.png"; + +var s_HeroAttack1 = "res/HeroAttack1.png"; +var s_HeroAttack2 = "res/HeroAttack2.png"; +var s_HeroAttack3 = "res/HeroAttack3.png"; +var s_HeroAttack4 = "res/HeroAttack4.png"; +var s_HeroAttack5 = "res/HeroAttack5.png"; + +var s_HeroAttackJ1 = "res/HeroAttackJ1.png"; +var s_HeroAttackJ2 = "res/HeroAttackJ2.png"; +var s_HeroAttackJ3 = "res/HeroAttackJ3.png"; +var s_HeroAttackJ4 = "res/HeroAttackJ4.png"; +var s_HeroAttackJ5 = "res/HeroAttackJ5.png"; +var s_HeroAttackJ6 = "res/HeroAttackJ6.png"; +var s_HeroAttackJ7 = "res/HeroAttackJ7.png"; +var s_HeroAttackJ8 = "res/HeroAttackJ8.png"; + +var s_HeroAttackT1 = "res/HeroAttackT1.png"; +var s_HeroAttackT2 = "res/HeroAttackT2.png"; +var s_HeroAttackT3 = "res/HeroAttackT3.png"; + + +var s_Robot1 = "res/Robot1.png"; +var s_Robot2 = "res/Robot2.png"; +var s_Robot3 = "res/Robot3.png"; + +var s_RobotState1 = "res/RobotState1.png"; +var s_RobotState2 = "res/RobotState2.png"; +var s_RobotState3 = "res/RobotState3.png"; +var s_RobotState4 = "res/RobotState4.png"; + +var s_RobotRun1 = "res/RobotRun1.png"; +var s_RobotRun2 = "res/RobotRun2.png"; +var s_RobotRun3 = "res/RobotRun3.png"; +var s_RobotRun4 = "res/RobotRun4.png"; +var s_RobotRun5 = "res/RobotRun5.png"; +var s_RobotRun6 = "res/RobotRun6.png"; + +var s_RobotAttack1 = "res/RobotAttack1.png"; +var s_RobotAttack2 = "res/RobotAttack2.png"; +var s_RobotAttack3 = "res/RobotAttack3.png"; +var s_RobotAttack4 = "res/RobotAttack4.png"; +var s_RobotAttack5 = "res/RobotAttack5.png"; + +var s_futura48 = "res/fonts/futura-48.png"; +var s_fnt_futura48 = "res/fonts/futura-48.fnt"; + +var g_resources = [ + //image + {src:s_HelloWorld}, + {src:s_CloseNormal}, + {src:s_CloseSelected}, + {src:s_BackGround}, + {src:s_Joypad1}, + {src:s_Joypad2}, + {src:s_Joypad3}, + {src:s_Joypad4}, + + {src:s_Attack}, + {src:s_AttackA}, + {src:s_AttackB}, + {src:s_AttackO}, + {src:s_AttackFreeze}, + + {src:s_Hero1}, + {src:s_Hero2}, + {src:s_Hero3}, + {src:s_HeroState1}, + {src:s_HeroState2}, + {src:s_HeroState3}, + {src:s_HeroState4}, + {src:s_HeroRun1}, + {src:s_HeroRun2}, + {src:s_HeroRun3}, + {src:s_HeroRun4}, + {src:s_HeroRun5}, + {src:s_HeroRun6}, + {src:s_HeroRun7}, + {src:s_HeroRun8}, + {src:s_HeroRun9}, + {src:s_HeroRun10}, + {src:s_HeroRun11}, + {src:s_HeroAttack1}, + {src:s_HeroAttack2}, + {src:s_HeroAttack3}, + {src:s_HeroAttack4}, + {src:s_HeroAttack5}, + {src:s_HeroAttackJ1}, + {src:s_HeroAttackJ2}, + {src:s_HeroAttackJ3}, + {src:s_HeroAttackJ4}, + {src:s_HeroAttackJ5}, + {src:s_HeroAttackJ6}, + {src:s_HeroAttackJ7}, + {src:s_HeroAttackJ8}, + {src:s_HeroAttackT1}, + {src:s_HeroAttackT2}, + {src:s_HeroAttackT3}, + + {src:s_Robot1}, + {src:s_Robot2}, + {src:s_Robot3}, + {src:s_RobotState1}, + {src:s_RobotState2}, + {src:s_RobotState3}, + {src:s_RobotState4}, + {src:s_RobotRun1}, + {src:s_RobotRun2}, + {src:s_RobotRun3}, + {src:s_RobotRun4}, + {src:s_RobotRun5}, + {src:s_RobotRun6}, + {src:s_RobotAttack1}, + {src:s_RobotAttack2}, + {src:s_RobotAttack3}, + {src:s_RobotAttack4}, + {src:s_RobotAttack5}, + + //plist + + //fnt + {src:s_futura48}, + {src:s_fnt_futura48} + + //tmx + + //bgm + + //effect +];