英雄的黎明2,自1250版本起,将在剧本编辑器中支持自定义UI系统。剧本开发者可以自行设计自己的UI界面,用以自己剧本个性化的需要。
例如,一位剧本作者利用脚本系统开发了比武大会系统。但是系统中没有自带武将对阵表。此时可以使用自定义UI系统制作一份武将对阵表。
自定义UI系统支持2种基本控件:
用以显示一副图片。
用以显示一段文字。
用以处理玩家的点击事件。
{
"app":"com.zlmcd.sanlite2",
"ver":1,
"name":"my_ui",
"res":{
"img_panel":{
"texture":"",
"width":47,
"height":47,
"border":{"l":8,"r":8,"t":8,"b":8}
},
"img_button":{
"texture":"",
"width":47,
"height":20,
"border":{"l":8,"r":8,"t":8,"b":8}
}
},
"children":[
{
"name":"win_1",
"comment":"这是一个显示窗口的例子,窗口上有一个按钮和一个武将头像",
"type":"image",
"size":{"x":400, "y":250},
"position":{"x":0,"y":0},
"touchmask":true,
"filltype":"sliced",
"texture":"ui:img_panel",
"active":true,
"children":[
{
"name":"text_msg",
"type":"text",
"size":{"x":380, "y":230},
"position":{"x":0,"y":0},
"text":"就快要爆炸",
"fontsize":24,
"halign":-1,
"valign":-1,
"active":true
},
{
"name":"btn_ok",
"type":"image",
"size":{"x":128, "y":32},
"position":{"x":0,"y":-100},
"touchmask":true,
"filltype":"sliced",
"texture":"ui:img_button",
"active":true,
"children":[
{
"name":"text_button",
"type":"text",
"size":{"x":128, "y":32},
"position":{"x":0,"y":0},
"text":"确定",
"fontsize":24,
"halign":0,
"valign":0,
"active":true
}
]
}
]
}
]
}
自定义UI由根节点和孩子挂件组成。当然,孩子挂件还可以有孩子挂件。 通常,一个剧本里只有一个自定义UI根节点。具体自定义的UI窗口全部放在此根节点之下即可。
根节点
|---窗口1背景框
|---窗口1图片1
|---窗口1图片2
|---窗口1按钮1
|---窗口2背景框
|---窗口2文字1
|---窗口1文字2
....
....
....
{
app:"com.zlmcd.sanlite2", // 数据应用范围。!!!请不要修改!!!。
ver:1, // 数据版本。!!!请不要修改!!!。
name:"my_ui", // 根节点名字。用以从脚本中定位访问。
res:"...", // 本根节点下所有使用到的第三方图片资源数据合集。
children:[], // 孩子节点列表。用于存放各种自定义窗口的挂件。
}
{
name:"win_1", // 挂件名字。用以从脚本中定位访问。
type:"image", // 挂件类型。image表示该挂件为图片。
size:{"x":400, "y":250}, // 挂件尺寸。
position:{"x":0,"y":0}, // 挂件位置。
touchmask:true, // 挂件是否可接收点击事件。
filltype:"sliced", // 挂件的显示类型
// single:直接显示图片。
// sliced:9宫格图片。
texture:"ui:img_panel", // 图片id
active:true, // 是否显示
children:[], // 孩子节点列表。用于存放本窗口中的其他部件,例如文字或者其他小图片。
}
{
name:"text_msg", // 挂件名字。用以从脚本中定位访问。
type:"text", // 挂件类型。image表示该挂件为图片。
size:{"x":64, "y":32}, // 挂件尺寸。文字挂件背景半透明黑框的大小。
position:{"x":0,"y":0}, // 挂件位置。
color:"#ff0000", // 文字颜色。html风格的颜色显示。#号+RGB颜色格式。
text:"你好~", // 文字默认内容。
// 支持富文本标签让文字不同部分显示不同颜色。例如:你好,我是<color=0xff00ffff>鱼怪</color>,欢迎下载!
// 富文本方式通常不和color字段混用。
fontsize:24, // 字体大小
halign:-1, // 水平方向对齐方式
// -1:左对齐
// 0:居中对齐
// 1:右对齐
valign:-1, // 垂直方向对齐方式
// -1:上对齐
// 0:居中对齐
// 1:下对齐
active:true, // 是否显示
children:[], // 孩子节点列表。用于存放本窗口中的其他部件,例如文字或者其他小图片。
}
UI.LoadWidget("my_custom_ui.json");
var win = UI.GetWidget("my_ui/win_1"); // 查询获取名叫my_ui下的win_1挂件。
win.active = true; // 显示该挂件
win.active = false; // 关闭该挂件
var msg = UI.GetWidget("my_ui/win_1/text_msg"); // 查询获取my_ui下win_1下text_msg的文字挂件。
msg.text = "oh’baby"; // 修改文字挂件内容
var btn_ok = UI.GetWidget("my_ui/win_1/btn_ok");
btn_ok.OnClick=()=>{
console.log("btn_ok按钮被点击!");
};
与Unity3D的ugui坐标系一致。采用笛卡尔坐标系。 至下而上变大,从左至右变大。 屏幕中心为原点(0,0)
TODO
使用九宫格图片显示技术,可以让UI不会因为“拉伸”而变形。原理如下: (图片引用来至:https://www.shuzhiduo.com/A/Vx5MBYRpdN/)
先将图片转换成base64格式的字符串
图片转base64编码字符串网站
然后参考res中的现有数据,让你的图片添加进根节点res中。