00003 不思议迷宫.0009.2.2:自动换装:界面模拟
00003 不思议迷宫.0009.2.2:自动换装:界面模拟
这两天一直在研究游戏的csb解析显示、重用luac之类的问题,中间遇到各种问题,各种痛苦。唉,还是知识储备不足啊,耽搁了不少时间。其实这些东西是没必要作的。如果我的手机越狱或者root了,就可以直接在真机上替换有限的几个文件,很方便试验、调试。现在条件有限,只能先在电脑上模拟一下,至少保证界面上不要出错,再打包到真机上试试。
自动换装仅发生于地牢中,地牢界面显示可参考“不思议迷宫.0010.1”中的两篇文章。但这两篇文章中的显示内容并不完整,缺少事件和装备界面等等。本篇文章需要把它补齐,并且实现自动换装的初始操作界面(对cocos2dx-lua真心不熟,查查干干,唉,慢)。
交互:地牢界面中点击“装备按钮”,弹出装备界面
注册事件回调,原版已经帮我们做好了:
self:registerTouchEvent();
不过它做得比我们需要的要多,所以就去除一些:
--注册点击事件
functionUIDungeonMain:registerTouchEvent()
-- 宝物按钮
local btnTreasure =tolua.cast(findChildByName(self.node, "CT2/baowu"),"ccui.Button");
local function onTreasureOnClick(sender,eventType)
if eventType ~=ccui.TouchEventType.ended then return end;
if equipsUI == nil then
equipsUI = UIEquips.create();
equipsUI:retain();
self:addChild(equipsUI);
end
equipsUI:setVisible(true);
end
AddTouchEventListener(btnTreasure,onTreasureOnClick);
end
其中用到了UIEquips,和UIDungeonMain类似,在my下创建luac文件,从原版拷贝所需内容,再修改修改:
UIEquips= class("UIEquips",function()
return cc.Layer:create();
end);
functionUIEquips.create(openType, extraPara)
return UIEquips.new(openType, extraPara);
end
--装备界面打开的方式
EQUIP_OPEN_TYPE_DEFAULT = 0; -- 默认打开
EQUIP_OPEN_TYPE_BLACKSMITH = 1; -- 工坊打开
EQUIP_OPEN_TYPE_DEMON = 2; -- 魔神雕像打开
--构造函数
--@param openType 界面打开的方式
--@param extraPara 附加参数
functionUIEquips:ctor(openType, extraPara)
-- 初始化
me = self;
self:setName("UIEquips");
local node = cc.CSLoader:createNode("layout/equip/equip.csb");
self:addChild(node);
self.node = node;
local CT =node:getChildByName("CT");
local panel =CT:getChildByName("page_view");
openType = openType orEQUIP_OPEN_TYPE_DEFAULT;
self.openType = openType;
self.extraPara = extraPara or {};
self.CT = CT;
local BT =node:getChildByName("BT");
self.BT = BT;
self.panel = panel;
self.data = {};
-- 设置下滚动面板的信息
panel:removeAllPages();
panel:setCustomScrollThreshold(100);
panel:setUsingCustomScrollThreshold(true);
……
-- 注册点击事件
self:registerTouchEvent(node);
-- 适配
self:resize();
-- 设置panel尺寸
panel:setContentSize(panel:getContentSize().width, totalHeight);
end
--注册点击事件
functionUIEquips:registerTouchEvent(node)
-- 注册返回按钮点击事件
local btnBack =tolua.cast(findChildByName(node, "BT/btn_back"),"ccui.Button");
local function onBackClick(sender,eventType)
if eventType ~=ccui.TouchEventType.ended then return end;
self:setVisible(false);
end
-- AddTouchEventListener在引导时自动发布TAEGET_CLICK事件
AddTouchEventListener(btnBack,onBackClick);
TextStyleM.setTextStyle(btnBack,TextStyleM.TEXT_SIZE_MIDDLE, TextStyleM.TEXT_COLOR_BROWN_YELLOW, true);
btnBack:setTitleText(getLocStr("btn_text_back"));
end
functionUIEquips:resize()
local node = self.node;
-- bg居中显示并充满整个屏幕
AlignM.fitToScreen(node, "bg");
-- CT居中并缩放至合适大小
AlignM.alignToCenter(node, "CT");
-- BT置于底部并缩放至合适大小
AlignM.alignToBottomCenter(node,"BT");
end
装备界面的打开、关闭这样就可以了。
交互:装备界面中点击“装备槽”,弹出自动换装配置界面
现在要继续玩上装备界面,当玩家点击“装备槽”时,需要弹出换装配置界面。那这个配置界面怎么来呢?较好的办法是找到和cocos2dx3.3rc0配套的CocosStudio,弄个csb出来。另一个办法是自己用代码手工实现。由于配置界面并不复杂,我就凑合着自己写了。
在my目录下新建UIAutoEquipingConfig.luac,编辑内容:
require("game/logic/base/Equip");
require("my/UIPositioning");
UIAutoEquipingConfig= class("UIAutoEquipingConfig",function()
return cc.Layer:create();
end);
functionUIAutoEquipingConfig.create(equipType)
return UIAutoEquipingConfig.new(equipType);
end
localgrayedEquipments =
{
[EQUIP_TYPE_HELMET] ="images/ui/equip/equip4.png",
[EQUIP_TYPE_ARMOR] ="images/ui/equip/equip6.png",
[EQUIP_TYPE_GLOVE] ="images/ui/equip/equip7.png",
[EQUIP_TYPE_BELT] ="images/ui/equip/equip11.png",
[EQUIP_TYPE_NECKLACE] ="images/ui/equip/equip3.png",
[EQUIP_TYPE_RING] ="images/ui/equip/equip2.png",
[EQUIP_TYPE_BOOT] ="images/ui/equip/equip10.png",
[EQUIP_TYPE_CLOAK] ="images/ui/equip/equip5.png",
[EQUIP_TYPE_TRUMP] = "images/ui/equip/baowu.png",
[EQUIP_TYPE_WEAPON] ="images/ui/equip/equip8.png",
[EQUIP_TYPE_MEDAL] ="images/ui/equip/equip9.png",
[EQUIP_TYPE_RISKER] ="images/ui/equip/equip12.png",
[EQUIP_TYPE_COSTUME] ="images/ui/equip/equip1.png",
}
localHSPACING = 30;
localVSPACING = 30;
localFONT = "fonts/simhei.ttf";
localFONT_SIZE = 20;
localBUTTON_IMAGE_NORMAL = "images/ui/button/btn_large_yellow1.png";
localBUTTON_IMAGE_SELECTED = "images/ui/button/btn_large_yellow2.png";
localBUTTON_TEXT = "更换";
functionUIAutoEquipingConfig:ctor(equipType)
self:setName("UIAutoEquipingConfig");
local background =cc.Sprite:create("images/ui/button/btn_large_disable.png");
self:addChild(background);
UIPositioning.fitToScreen(background);
local button_close =ccui.Button:create("images/ui/equip/222.png");
local function onButton_close(sender,eventType)
self:getParent():removeChild(self)
end
AddTouchEventListener(button_close,onButton_close);
self:addChild(button_close);
UIPositioning.rightTop(button_close);
local grayedEquipment =grayedEquipments[equipType];
local label_goingFloor =cc.Label:createWithTTF("进入下一层",FONT, FONT_SIZE);
local icon_goingFloor =cc.Sprite:create(grayedEquipment);
local button_goingFloor =ccui.Button:create(BUTTON_IMAGE_NORMAL, BUTTON_IMAGE_SELECTED);
button_goingFloor:setTitleText(BUTTON_TEXT);
button_goingFloor:setTitleFontName(FONT);
button_goingFloor:setTitleFontSize(FONT_SIZE);
local function onButton_goingFloor(sender,eventType)
print("onButton_goingFloor");
end
AddTouchEventListener(button_goingFloor,onButton_goingFloor);
self:addChild(label_goingFloor);
self:addChild(icon_goingFloor);
self:addChild(button_goingFloor);
local label_arrivingFloor =cc.Label:createWithTTF("进到下一层",FONT, FONT_SIZE);
local icon_arrivingFloor =cc.Sprite:create(grayedEquipment);
local button_arrivingFloor =ccui.Button:create(BUTTON_IMAGE_NORMAL, BUTTON_IMAGE_SELECTED);
button_arrivingFloor:setTitleText(BUTTON_TEXT);
button_arrivingFloor:setTitleFontName(FONT);
button_arrivingFloor:setTitleFontSize(FONT_SIZE);
local functiononButton_arrivingFloor(sender, eventType)
print("onButton_arrivingFloor");
end
AddTouchEventListener(button_arrivingFloor,onButton_arrivingFloor);
self:addChild(label_arrivingFloor);
self:addChild(icon_arrivingFloor);
self:addChild(button_arrivingFloor);
local label_clickingColumn =cc.Label:createWithTTF("胜利者石柱",FONT, FONT_SIZE);
local icon_clickingColumn =cc.Sprite:create(grayedEquipment);
local button_clickingColumn =ccui.Button:create(BUTTON_IMAGE_NORMAL, BUTTON_IMAGE_SELECTED);
button_clickingColumn:setTitleText(BUTTON_TEXT);
button_clickingColumn:setTitleFontName(FONT);
button_clickingColumn:setTitleFontSize(FONT_SIZE);
local functiononButton_clickingColumn(sender, eventType)
print("onButton_clickingColumn");
end
AddTouchEventListener(button_clickingColumn, onButton_clickingColumn);
self:addChild(label_clickingColumn);
self:addChild(icon_clickingColumn);
self:addChild(button_clickingColumn);
UIPositioning.hvCenter({
{label_goingFloor, icon_goingFloor, button_goingFloor,},
{label_arrivingFloor, icon_arrivingFloor, button_arrivingFloor,},
{label_clickingColumn, icon_clickingColumn, button_clickingColumn,},
}, HSPACING, VSPACING);
return self
end
好几处类似的代码,这个需要重构。
UIPositioning是自己编写的界面排版函数。原版中提供了AlignM,但它有针对性。
用到的一些资源都是原版中自带的,随便找的,所以界面很丑陋:
还有两个交互要做:交互:自动换装配置界面中点击“装备图标”,弹出装备信息界面(含“卸下”按钮)、交互:自动换装配置界面中点击“选择按钮”,弹出装备装备选择界面(不能穿戴的装备灰掉)。但它们需要在真实环境中才能正常运行。
00003 不思议迷宫.0009.2.2:自动换装:界面模拟相关推荐
- 00003 不思议迷宫.0009.9:命运之链
00003 不思议迷宫.0009.9:命运之链 我不知道别人的怎么样,反正在我的手机们上,仅在该功能刚出来时找到过其他玩家.然后,官方说部分玩家该功能不能用,修复了.可惜的是,自从这个"修复 ...
- 00003 不思议迷宫.0009.7:一键采矿(钻石、金蛋等)
00003 不思议迷宫.0009.7:一键采矿(钻石.金蛋等) 矿有很多种,今天要说的是其中的钻石矿这种,也是就神龙许愿"我想要钻石"后进到夹层中,地上显示的那些需要点击99次(初 ...
- 00003 不思议迷宫.0009.6:一键翻开石板捡取物品
00003 不思议迷宫.0009.6:一键翻开石板捡取物品 先上主要代码: local function onMyButton_AutoPickUpAllItems(sender, eventType ...
- 00003 不思议迷宫.0009.10:Bug之二:免称号锻造、升级装备,合成卷轴
00003 不思议迷宫.0009.10:Bug之二:免称号锻造.升级装备,合成卷轴 今天玩德古拉城堡,想击杀100层Boss完成"首领礼包".平时我都是用双大地,但一直听说啥主流套 ...
- 00003 不思议迷宫.0009.2.1:自动换装:简单规划
00003 不思议迷宫.0009.2.1:自动换装:简单规划 我今天白天在思考问题之余,又玩了会游戏,下了个竞技场副本,才第一次注意到竞技场中的观众也是可以杀的.当然,是没办法直接攻击观众的,必 ...
- 00003 不思议迷宫.0009.2.4:自动换装:在事件中实现自动换装
00003 不思议迷宫.0009.2.4:自动换装:在事件中实现自动换装 具体的换装动作如何实现呢?老办法:学原版.在前一章中,我们已经接触过一个叫做"UIEquipsOperatio ...
- 00003 不思议迷宫.0009.2.3:自动换装:回改到真实环境
00003 不思议迷宫.0009.2.3:自动换装:回改到真实环境 在将代码弄到真实环境之前,先将UIAutoEquipingConfig中的类似代码重构一下. local l ...
- 00003 不思议迷宫.0008:分析了半天我们能干什么?
00003 不思议迷宫.0008:分析了半天我们能干什么? 玩家数据不能直接修改,间接的似乎也不行,那我们还能干什么? 能干的有很多. 比如,我先问问,大家是如何在炼金坊捡钱的?除开玩模拟器使用按键精 ...
- 00003 不思议迷宫.0006:客户端的操作如何反应到服务器?
00003 不思议迷宫.0006:客户端的操作如何反应到服务器? 玩家点击手机屏幕,根据点到内容的不同而执行不同的操作,比如切换画面或者场景.播放动画或声音.发送数据等等.我现在所关心的是点到物 ...
最新文章
- Linux系统开发之路-中
- 不需要懂得编程,但却可以使用ggplot2画出论文级别的图?
- 西门子Step7找不到有效授权的解决方法
- 极度舒适的 Python 入门教程,佩奇也能学会~
- ie9 Flash内容无法显示
- oracle函数 INITCAP(c1)
- 麒麟810处理器_何刚口中第二颗7nm处理器麒麟810曝光:将搭载自研NPU
- 准入控制(NAC)技术调研
- java Calendar的学习分享
- Docker+SVN
- 拓端tecdat|R语言蒙特卡洛计算和快速傅立叶变换计算矩生成函数
- Matlab 线性同余法产生随机数
- 华为终端穿戴软件测试,【华为软件测试工程师面试】总共五轮面试外加一个上机的性格测试。-看准网...
- 计算机键盘没有fn,教您fn键设置方法
- 【内存】进程结束后程序员没有释放的内存哪儿去了?
- 日月運行法則이 政治의 原理이다
- 年轻人为何一孩都不愿生?中国人口拐点逼近
- 墨西哥付款方式有哪些
- 【阿里聚安全·安全周刊】科学家警告外星恶意代码|新方法任意解锁iPhone
- Bootstra 警告框
热门文章
- CTF工具收集(持续更新中)
- Java小白StudyDay09---代码块、final、多态、异常
- 显卡升级为啥总显示登录账号_分享买到QQ后应该注意什么,怎么检测买到手QQ的重要属性?如何保证购买的游戏账号不被找回?...
- 通俗易懂VS项目中的web config配置文件
- 一夜爆红的4款国产软件,却一度被大众误以为是外国人开发
- 案例6:Java社区志愿者服务系统设计与实现开题报告
- 神经网络相关性分析方法,神经网络相关性分析图
- 如何将heic格式转化jpg,5种方法汇总
- 关于最新版CentOS-7(1804)相关说明
- apache rewrite 时配置方法