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
+];