Compare commits

...

24 Commits

Author SHA1 Message Date
AncTe
6dde0334e1
Merge pull request #3 from unanmed/dev-strawberry
feat(dev-strawberry): graphics & 图标 & winskin & 事件
2025-01-12 15:45:28 +08:00
c7b2e6dd30 refactor: Winskin.image 2025-01-12 14:16:52 +08:00
52c5126997 fix: warn code. 2025-01-12 13:10:52 +08:00
b2a391a212 fix: icon 2025-01-12 13:09:10 +08:00
ba1e7ea228 fix : graphic类别问题 2025-01-12 12:53:32 +08:00
2a03d7c98d refactor: 事件块更改完成 2025-01-05 14:12:11 +08:00
f29c76ffc9 fix: rectr 标签 2025-01-02 13:52:43 +08:00
77dfbb5a62 Merge branch 'dev-strawberry' of github.com:unanmed/HumanBreak into dev-strawberry 2025-01-02 13:51:52 +08:00
7ae1eb1e21 fix: graphic元素错位问题 2025-01-02 13:51:34 +08:00
285dc2e48f feat: 圆角矩形接口 2025-01-02 13:50:44 +08:00
dbe633290e feat: Icon\winskin完成 2025-01-02 13:48:58 +08:00
d61beada0b fix: strokeAndFill in checkMode 2025-01-02 13:48:58 +08:00
2aa0ffe12a feat: patchProp for GraphicItemBase 2025-01-02 13:48:58 +08:00
5c9419280e style: graphics.ts 2025-01-02 13:48:58 +08:00
29f1f00e23 feat: graphic的patchProp写完了 2025-01-02 13:48:58 +08:00
1650865a6a feat:graphics完成 2025-01-02 13:48:58 +08:00
b48dfae211 fix: graphic元素错位问题 2024-12-28 16:46:22 +08:00
3057d740b6 feat: 圆角矩形接口 2024-12-26 18:16:59 +08:00
9d48e9c09d feat: Icon\winskin完成 2024-12-25 17:56:59 +08:00
136de3072b fix: strokeAndFill in checkMode 2024-12-24 19:57:44 +08:00
733b6908c8 feat: patchProp for GraphicItemBase 2024-12-24 19:55:52 +08:00
26600c2154 style: graphics.ts 2024-12-24 18:18:53 +08:00
4e583fb121 feat: graphic的patchProp写完了 2024-12-24 17:11:49 +08:00
2a17749adc feat:graphics完成 2024-12-23 19:23:13 +08:00
12 changed files with 986 additions and 611 deletions

View File

@ -806,22 +806,13 @@ return code;
//为了避免关键字冲突,全部加了_s //为了避免关键字冲突,全部加了_s
//动作 //动作
action action
: text_0_s : text_s
| text_1_s
| text_2_s
| moveTextBox_s
| clearTextBox_s
| comment_s | comment_s
| autoText_s | autoText_s
| scrollText_s | scrollText_s
| setText_s | setText_s
| tip_s | tip_s
| setValue_s | setValue_s
| setEnemy_s
| setEnemyOnPoint_s
| resetEnemyOnPoint_s
| moveEnemyOnPoint_s
| moveEnemyOnPoint_1_s
| setEquip_s | setEquip_s
| setFloor_s | setFloor_s
| setGlobalAttribute_s | setGlobalAttribute_s
@ -831,7 +822,6 @@ action
| show_s | show_s
| hide_s | hide_s
| setBlockOpacity_s | setBlockOpacity_s
| setBlockFilter_s
| trigger_s | trigger_s
| insert_1_s | insert_1_s
| insert_2_s | insert_2_s
@ -866,8 +856,6 @@ action
| unloadEquip_s | unloadEquip_s
| openShop_s | openShop_s
| disableShop_s | disableShop_s
| follow_s
| unfollow_s
| animate_s | animate_s
| animate_1_s | animate_1_s
| stopAnimate_s | stopAnimate_s
@ -879,7 +867,6 @@ action
| moveImage_s | moveImage_s
| rotateImage_s | rotateImage_s
| scaleImage_s | scaleImage_s
| showGif_s
| setCurtain_0_s | setCurtain_0_s
| setCurtain_1_s | setCurtain_1_s
| screenFlash_s | screenFlash_s
@ -950,188 +937,31 @@ action
| pass_s | pass_s
; ;
text_0_s
: '显示文章' ':' EvalString_Multi Newline
/* text_0_s text_s
tooltip : text显示一段文字剧情 : '标题' EvalString? '图标' EvalString? '像素坐标 x' IntString? 'y' IntString? '宽' IntString? '高' IntString? '维持文本' Bool '打字间隔' IntString? '行高' IntString? BGNL? Newline
helpUrl : /_docs/#/instruction EvalString_Multi Newline
previewBlock : true
default : ["欢迎使用事件编辑器(双击方块可直接预览)"]
var code = '"'+EvalString_Multi_0+'"';
if (block.isCollapsed() || !block.isEnabled()) {
code = '{"type": "text", "text": '+code;
if (block.isCollapsed()) code += ', "_collapsed": true';
if (!block.isEnabled()) code += ', "_disabled": true';
code += '}';
}
return code+',\n';
*/;
text_1_s
: '标题' EvalString? '图像' EvalString? '对话框效果' EvalString? '起点 px' PosString? 'py' PosString? '宽' PosString? '编号' Int '不等待操作' Bool BGNL? Newline EvalString_Multi Newline
/* text_1_s /* text_s
tooltip : text显示一段文字剧情,选项较多请右键点击帮助 tooltip : text显示一段文字剧情,选项较多请右键点击帮助
helpUrl : /_docs/#/instruction helpUrl : /_docs/#/instruction
previewBlock : true previewBlock : true
allIds : ['EvalString_1'] allIds : ['EvalString_1']
default : ["小妖精","fairy","","","","",0,false,"欢迎使用事件编辑器(双击方块可直接预览)"] default : ["小妖精","fairy","","","","",false,"","","欢迎使用事件编辑器"]
var title=''; EvalString_0= EvalString_0 ? (', "title": "'+EvalString_0+'"') : '';
if (EvalString_0==''){ EvalString_1= EvalString_1 ? (', "icon": "'+EvalString_1+'"') : '';
if (EvalString_1=='' )title=''; IntString_0= IntString_0 ? (', "x": '+IntString_0) : '';
else title='\\t['+EvalString_1+']'; IntString_1= IntString_1 ? (', "y": '+IntString_1) : '';
} else { IntString_2= IntString_2 ? (', "width": '+IntString_2) : '';
if (EvalString_1=='')title='\\t['+EvalString_0+']'; IntString_3= IntString_3 ? (', "height": '+IntString_3) : '';
else title='\\t['+EvalString_0+','+EvalString_1+']'; IntString_4= IntString_4 ? (', "interval": '+IntString_4) : '';
} IntString_5= IntString_5 ? (', "lineHeight": '+IntString_5) : '';
var pos = ''; var code = '{"type": "text"'+EvalString_0+EvalString_1+IntString_0+IntString_1+IntString_2+IntString_3+',"keepLast":'+Bool_0+IntString_4+IntString_5+'"text":"'+EvalString_Multi_0+'"},\n';
if (PosString_0 || PosString_1) { return code
if (EvalString_2) throw new Error('对话框效果和起点像素位置只能设置一项!');
pos = '[' + (PosString_0||0) + ',' + (PosString_1||0);
if (PosString_2) pos += ',' + PosString_2;
pos += ']';
}
if(EvalString_2 && !(/^(up|center|down|hero|this)(,(hero|null|\d+,\d+|\d+))?$/.test(EvalString_2))) {
throw new Error('对话框效果的用法请右键点击帮助');
}
EvalString_2 = EvalString_2 && ('\\b['+EvalString_2+']');
var code = '"'+title+EvalString_2+EvalString_Multi_0+'"';
if (block.isCollapsed() || !block.isEnabled() || pos || Int_0 || Bool_0) {
code = '{"type": "text", "text": '+code;
if (pos) code += ', "pos": ' + pos;
if (Int_0) code += ', "code": ' + Int_0;
if (Bool_0) code += ', "async": true';
if (block.isCollapsed()) code += ', "_collapsed": true';
if (!block.isEnabled()) code += ', "_disabled": true';
code += '}';
}
return code+',\n';
*/; */;
text_2_s
: '标题' EvalString? '图像' EvalString? '对话框效果' EvalString? '起点 px' PosString? 'py' PosString? '宽' PosString? '编号' Int '不等待操作' Bool BGNL? Newline EvalString_Multi BGNL? Newline textDrawingList* Newline
/* text_2_s
tooltip : text显示一段文字剧情,选项较多请右键点击帮助
helpUrl : /_docs/#/instruction
previewBlock : true
allIds : ['EvalString_1']
default : ["小妖精","fairy","","","","",0,"欢迎使用事件编辑器(双击方块可直接预览)",null]
var title='';
if (EvalString_0==''){
if (EvalString_1=='' )title='';
else title='\\t['+EvalString_1+']';
} else {
if (EvalString_1=='')title='\\t['+EvalString_0+']';
else title='\\t['+EvalString_0+','+EvalString_1+']';
}
var pos = '';
if (PosString_0 || PosString_1) {
if (EvalString_2) throw new Error('对话框效果和起点像素位置只能设置一项!');
pos = '[' + (PosString_0||0) + ',' + (PosString_1||0);
if (PosString_2) pos += ',' + PosString_2;
pos += ']';
}
if(EvalString_2 && !(/^(up|center|down|hero|this)(,(hero|null|\d+,\d+|\d+))?$/.test(EvalString_2))) {
throw new Error('对话框效果的用法请右键点击帮助');
}
EvalString_2 = EvalString_2 && ('\\b['+EvalString_2+']');
var code = '"'+title+EvalString_2+textDrawingList_0.replace(/\s/g, '')+EvalString_Multi_0+'"';
if (block.isCollapsed() || !block.isEnabled() || pos || Int_0 || Bool_0) {
code = '{"type": "text", "text": '+code;
if (pos) code += ', "pos": ' + pos;
if (Int_0) code += ', "code": ' + Int_0;
if (Bool_0) code += ', "async": true';
if (block.isCollapsed()) code += ', "_collapsed": true';
if (!block.isEnabled()) code += ', "_disabled": true';
code += '}';
}
return code+',\n';
*/;
textDrawingList
: textDrawing
| textDrawingEmpty;
textDrawing
: '立绘' EvalString '翻转' Reverse_List '绘制坐标' 'x' IntString 'y' IntString '宽' IntString? '高' IntString? BGNL? Newline
'裁剪坐标' 'x' IntString? 'y' IntString? '宽' IntString? '高' IntString? '不透明度' EvalString? '旋转角度' IntString?
/* textDrawing
tooltip : 立绘
helpUrl : /_docs/#/instruction
default : ["fairy.png","null","0","0","","","","","","","",""]
colour : this.subColor
previewBlock : true
allImages : ['EvalString_0']
if (Reverse_List_0 && Reverse_List_0 != 'null') EvalString_0 += Reverse_List_0;
var list = [EvalString_0, IntString_0, IntString_1];
if (IntString_2 || IntString_3) {
if (list.length != 3 || !IntString_2 || !IntString_3) {
throw "绘制的宽和高需同时设置";
}
list.push(IntString_2);
list.push(IntString_3);
}
if (IntString_4 || IntString_5 || IntString_6 || IntString_7) {
if (list.length != 5) throw "如设置裁剪区域,请先设置绘制区域的宽高";
if (!IntString_4 || !IntString_5 || !IntString_6 || !IntString_7) {
throw "如设置裁剪区域,请同时设置全部的裁剪坐标和宽高";
}
list.splice(1, 0, IntString_4, IntString_5, IntString_6, IntString_7);
}
if (EvalString_1) {
if (list.length != 9) throw "如设置不透明度,需填满所有坐标和宽高";
var opacity = parseFloat(EvalString_1);
if (isNaN(opacity) || opacity < 0 || opacity > 1) throw "不合法的不透明度必须是0到1之间"
list.push(opacity);
}
if (IntString_8) {
if (list.length != 10) throw "如设置旋转角度,需填满所有坐标和宽高,以及不透明度";
list.push(IntString_8);
}
return "\\f[" + list.join(",")+"]";
*/;
textDrawingEmpty
: Newline
/* textDrawingEmpty
var code = '';
return code;
*/;
moveTextBox_s
: '移动对话框' ':' Int 'px' PosString 'py' PosString '使用增量' Bool '移动方式' MoveMode_List '动画时间' Int '不等待执行完毕' Bool Newline
/* moveTextBox_s
tooltip : 移动对话框
helpUrl : /_docs/#/instruction
default : [1,"0","0",false,'',500,false]
MoveMode_List_0 = (MoveMode_List_0!=='') ? (', "moveMode": "'+MoveMode_List_0+'"'):'';
Bool_0 = Bool_0 ?', "relative": true':'';
Bool_1 = Bool_1 ?', "async": true':'';
var code = '{"type": "moveTextBox", "code": '+Int_0+', "loc": ['+PosString_0+','+PosString_1+']'+Bool_0+MoveMode_List_0+', "time": '+Int_1+Bool_1+'},\n';
return code;
*/;
clearTextBox_s
: '清除对话框' ':' EvalString? Newline
/* clearTextBox_s
tooltip : 清除对话框
helpUrl : /_docs/#/instruction
default : ["1"]
if (EvalString_0 && !/^\d+(,\d+)*$/.test(EvalString_0)) throw new Error('对话框编号需要以逗号分隔');
EvalString_0 = EvalString_0 ? (', "code": ['+EvalString_0+']') : '';
var code = '{"type": "clearTextBox"'+EvalString_0+'},\n';
return code;
*/;
comment_s comment_s
@ -1189,39 +1019,38 @@ return code;
*/; */;
setText_s setText_s
: '设置剧情文本的属性' '位置' SetTextPosition_List '偏移像素' IntString? '对齐' TextAlign_List? '粗体' B_1_List? BGNL? '标题颜色' ColorString? Colour '正文颜色' ColorString? Colour '背景色' EvalString? Colour BGNL? '标题大小' IntString? '正文大小' IntString? '行距' IntString? '打字间隔' IntString? '字符间距' IntString? '淡入淡出时间' IntString? Newline : '设置剧情文本的属性' '位置像素x' IntString? 'y' IntString? '宽' IntString? '高' IntString? '字体类型' EvalString? '字体大小' IntString? '字体线宽' IntString? BGNL?
'是否斜体' Bool? '维持文本' Bool? '打字间隔' IntString? '行高' IntString? '文字颜色' ColorString? Colour '文字描边颜色' ColorString? Colour '描边线宽' IntString? '是否填充' Bool '是否描边' Bool BGNL?
'背景色' ColorString? Colour '背景winskin' EvalString? '文字与边框距离' IntString? '标题是否填充' Bool '标题是否描边' Bool'标题与边框的距离' IntString? BGNL?
'对齐方式' TextAlign_List '分词原则' WordBreak_List '行首禁则' EvalString? '行尾禁则' EvalString? '分词规则识别字符' EvalString? Newline
/* setText_s /* setText_s
tooltip : setText设置剧情文本的属性,颜色为RGB三元组或RGBA四元组,打字间隔为剧情文字添加的时间间隔,为整数或不填,字符间距为字符之间的距离,为整数或不填。 tooltip : setText设置文本的属性,颜色为RGB三元组或RGBA四元组,打字间隔为剧情文字添加的时间间隔,为整数或不填,字符间距为字符之间的距离,为整数或不填。
helpUrl : /_docs/#/instruction helpUrl : /_docs/#/instruction
previewBlock : true previewBlock : true
default : [null,"",null,null,"",'rgba(255,255,255,1)',"",'rgba(255,255,255,1)',"",'rgba(255,255,255,1)',"","","","","",""] default : ["","","","","","","",false,false,"","","",'rgba(255,255,255,1)',"",'rgba(255,255,255,1)',"",true,false,"",'rgba(255,255,255,1)',"","",true,false,"",'null','space',"","",""]
SetTextPosition_List_0 =SetTextPosition_List_0==='null'?'': ', "position": "'+SetTextPosition_List_0+'"'; IntString_0= IntString_0 ? (', "x": '+IntString_0) : '';
TextAlign_List_0 = TextAlign_List_0==='null'?'': ', "align": "'+TextAlign_List_0+'"'; IntString_1 = IntString_1 ? (', "y": '+IntString_1) : '';
var colorRe = MotaActionFunctions.pattern.colorRe; IntString_2 = IntString_2 ? (', "width": '+IntString_2) : '';
IntString_0 = IntString_0 ? (', "offset": '+IntString_0) : ''; IntString_3 = IntString_3 ? (', "height": '+IntString_3) : '';
ColorString_0 = ColorString_0 ? (', "title": ['+ColorString_0+']') : ''; EvalString_0 = EvalString_0 ? (', "fontFamily": '+EvalString_0) : '';
ColorString_1 = ColorString_1 ? (', "text": ['+ColorString_1+']') : ''; IntString_4 = IntString_4 ? (', "fontSize": '+IntString_4) : '';
if (EvalString_0) { IntString_5 = IntString_5 ? (', " interval": '+IntString_5) : '';
if (colorRe.test(EvalString_0)) { IntString_6 = IntString_6 ? (', "lineHeight": ' + IntString_6) : '';
EvalString_0 = ', "background": ['+EvalString_0+']'; IntString_7 = IntString_7? (', "strokeWidth": ' + IntString_7) : '';
} EvalString_1 = EvalString_1 ? (', "winskin": '+EvalString_1) : '';
else if (/^\w+\.png$/.test(EvalString_0)) { IntString_8 = IntString_8? (', "padding": ' + IntString_8) : '';
EvalString_0 = ', "background": "'+EvalString_0+'"'; IntString_9 = IntString_9? (', "titlePadding": ' + IntString_9) : '';
} TextAlign_List_0 = TextAlign_List_0==='null'?'':', "textAlign": "'+TextAlign_List_0+'"';
else { WordBreak_List_0 = WordBreak_List_0==='null'?'':', "wordBreak": "'+WordBreak_List_0+'"';
throw new Error('背景格式错误,必须是形如0~255,0~255,0~255,0~1的颜色或一个WindowSkin的png图片名称'); EvalString_2 = EvalString_2? (', "ignoreLineStart": '+EvalString_2) : '';
} EvalString_3 = EvalString_3 ? (', "ignoreLineEnd": '+EvalString_3) : '';
} EvalString_4 = EvalString_4 ? (', "breakChars": '+EvalString_4) : '';
IntString_1 = IntString_1 ? (', "titlefont": '+IntString_1) : ''; ColorString_0=ColorString_0?(', "fillStyle": ['+ColorString_0+']'):'';
IntString_2 = IntString_2 ? (', "textfont": '+IntString_2) : ''; ColorString_1=ColorString_1?(', "strokeStyle": ['+ColorString_1+']'):'';
IntString_3 = IntString_3 ? (', "lineHeight": '+IntString_3) : ''; ColorString_2=ColorString_2?(', "backColor": ['+ColorString_2+']'):'';
IntString_4 = IntString_4 ? (', "time": '+IntString_4) : ''; var code = '{"type": "setText"'+IntString_0+IntString_1+IntString_2+IntString_3+EvalString_0+IntString_4+', " fontItalic": '+Bool_0+', " keepLast": '+Bool_1+IntString_5+IntString_6+ColorString_0+ColorString_1+IntString_7 +',"fill":'+Bool_2+',"stroke":'+Bool_3+ColorString_2+EvalString_1+IntString_8+',"titleFill":'+Bool_4+',"titleStroke":'+Bool_5+IntString_9 +TextAlign_List_0+WordBreak_List_0+EvalString_2+EvalString_3+EvalString_4+'},\n';
IntString_5 = IntString_5 ? (', "letterSpacing": '+IntString_5) : '';
IntString_6 = IntString_6 ? (', "animateTime": ' + IntString_6) : '';
B_1_List_0 = B_1_List_0==='null'?'':', "bold": '+B_1_List_0;
var code = '{"type": "setText"'+SetTextPosition_List_0+IntString_0+TextAlign_List_0+B_1_List_0+ColorString_0+ColorString_1+EvalString_0+IntString_1+IntString_2+IntString_3+IntString_4+IntString_5+IntString_6+'},\n';
return code; return code;
*/; */;
@ -1257,23 +1086,6 @@ return code;
*/; */;
setEnemy_s
: '设置怪物属性' ':' '怪物ID' IdString '的' EnemyId_List AssignOperator_List expression '不刷新显伤' Bool Newline
/* setEnemy_s
tooltip : setEnemy设置某个怪物的属性
helpUrl : /_docs/#/instruction
default : ["greenSlime", "atk", "=", "", false]
allEnemys : ['IdString_0']
colour : this.dataColor
if (AssignOperator_List_0 && AssignOperator_List_0 != '=') {
AssignOperator_List_0 = ', "operator": "' + AssignOperator_List_0 + '"';
} else AssignOperator_List_0 = '';
Bool_0 = Bool_0 ? ', "norefresh": true' : '';
var code = '{"type": "setEnemy", "id": "'+IdString_0+'", "name": "'+EnemyId_List_0+'"'+AssignOperator_List_0+', "value": "'+expression_0+'"'+Bool_0+'},\n';
return code;
*/;
setEquip_s setEquip_s
@ -1295,84 +1107,6 @@ return code;
*/; */;
setEnemyOnPoint_s
: '设置某点怪物属性' ':' 'x' EvalString? ',' 'y' EvalString? '楼层' IdString? '的' EnemyPoint_List AssignOperator_List expression '不刷新显伤' Bool Newline
/* setEnemyOnPoint_s
tooltip : setEnemyOnPoint设置某个点上怪物的属性
helpUrl : /_docs/#/instruction
default : ["", "", "", "atk", "=", "", false]
selectPoint : ["EvalString_0", "EvalString_1", "IdString_0"]
allFloorIds : ['IdString_0']
colour : this.dataColor
var floorstr = MotaActionFunctions.processMultiLoc(EvalString_0, EvalString_1);
if (AssignOperator_List_0 && AssignOperator_List_0 != '=') {
AssignOperator_List_0 = ', "operator": "' + AssignOperator_List_0 + '"';
} else AssignOperator_List_0 = '';
IdString_0 = IdString_0 && (', "floorId": "'+IdString_0+'"');
Bool_0 = Bool_0 ? ', "norefresh": true' : '';
var code = '{"type": "setEnemyOnPoint"'+floorstr+IdString_0+', "name": "'+EnemyPoint_List_0+'"'+AssignOperator_List_0+', "value": "'+expression_0+'"'+Bool_0+'},\n';
return code;
*/;
resetEnemyOnPoint_s
: '重置某点怪物属性' ':' 'x' EvalString? ',' 'y' EvalString? '楼层' IdString? '不刷新显伤' Bool Newline
/* resetEnemyOnPoint_s
tooltip : resetEnemyOnPoint重置某个点上怪物的属性
helpUrl : /_docs/#/instruction
default : ["", "", "", false]
selectPoint : ["EvalString_0", "EvalString_1", "IdString_0"]
allFloorIds : ['IdString_0']
colour : this.dataColor
var floorstr = MotaActionFunctions.processMultiLoc(EvalString_0, EvalString_1);
IdString_0 = IdString_0 && (', "floorId": "'+IdString_0+'"');
Bool_0 = Bool_0 ? ', "norefresh": true' : '';
var code = '{"type": "resetEnemyOnPoint"'+floorstr+IdString_0+Bool_0+'},\n';
return code;
*/;
moveEnemyOnPoint_s
: '移动某点怪物属性' ':' '起点' 'x' PosString? ',' 'y' PosString? '终点' 'x' PosString? 'y' PosString? '楼层' IdString? '不刷新显伤' Bool Newline
/* moveEnemyOnPoint_s
tooltip : moveEnemyOnPoint移动某个点上怪物的属性到其他点
helpUrl : /_docs/#/instruction
default : ["", "", "", "", "", false]
allFloorIds : ['IdString_0']
selectPoint : ["PosString_2", "PosString_3"]
menu : [['选择起点位置','editor_blockly.selectPoint(block,["PosString_0", "PosString_1"])']]
colour : this.dataColor
IdString_0 = IdString_0 && (', "floorId": "'+IdString_0+'"');
var floorstr = PosString_0 && PosString_1 ? ', "from": ['+PosString_0+','+PosString_1+']' : '';
if (PosString_2 && PosString_3) floorstr += ', "to": ['+PosString_2+','+PosString_3+']'
Bool_0 = Bool_0 ? ', "norefresh": true' : '';
var code = '{"type": "moveEnemyOnPoint"'+floorstr+IdString_0+Bool_0+'},\n';
return code;
*/;
moveEnemyOnPoint_1_s
: '移动某点怪物属性' ':' '起点' 'x' PosString? ',' 'y' PosString? '增量' 'dx' PosString? 'dy' PosString? '楼层' IdString? '不刷新显伤' Bool Newline
/* moveEnemyOnPoint_1_s
tooltip : moveEnemyOnPoint移动某个点上怪物的属性到其他点
helpUrl : /_docs/#/instruction
default : ["", "", "", "", "", false]
allFloorIds : ['IdString_0']
selectPoint : ["PosString_0", "PosString_1"]
colour : this.dataColor
IdString_0 = IdString_0 && (', "floorId": "'+IdString_0+'"');
var floorstr = PosString_0 && PosString_1 ? ', "from": ['+PosString_0+','+PosString_1+']' : '';
if (PosString_2 && PosString_3) floorstr += ', "dxy": ['+PosString_2+','+PosString_3+']'
Bool_0 = Bool_0 ? ', "norefresh": true' : '';
var code = '{"type": "moveEnemyOnPoint"'+floorstr+IdString_0+Bool_0+'},\n';
return code;
*/;
setFloor_s setFloor_s
: '设置楼层属性' ':' Floor_Meta_List '楼层名' IdString? '为' JsonEvalString Newline : '设置楼层属性' ':' Floor_Meta_List '楼层名' IdString? '为' JsonEvalString Newline
@ -1432,7 +1166,7 @@ return code;
setNameMap_s setNameMap_s
: '设置文件别名' ':' EvalString '为' EvalString? Newline : '(已弃用)设置文件别名' ':' EvalString '为' EvalString? Newline
/* setNameMap_s /* setNameMap_s
@ -1504,27 +1238,6 @@ var code = '{"type": "setBlockOpacity"'+floorstr+IdString_0+', "opacity": '+Numb
return code; return code;
*/; */;
setBlockFilter_s
: '设置图块特效' 'x' EvalString? ',' 'y' EvalString? '楼层' IdString? '虚化' Number '色相' Int '灰度' Number '反色' Bool '阴影' Number Newline
/* setBlockFilter_s
tooltip : setBlockFilter: 设置图块特效
helpUrl : /_docs/#/instruction
default : ["","","",0,0,0,false,0]
selectPoint : ["EvalString_0", "EvalString_1", "IdString_0"]
allFloorIds : ['IdString_0']
colour : this.mapColor
var floorstr = MotaActionFunctions.processMultiLoc(EvalString_0, EvalString_1);
if (Number_0 < 0) throw '虚化不得小于00为完全没有虚化';
if (Int_0 < 0 || Int_0 >= 360) throw '色相需要在0~359之间';
if (Number_1 < 0 || Number_1 > 1) throw '灰度需要在0~1之间';
if (Number_2 < 0) throw '阴影不得小于00为完全没有阴影';
var code = '{"type": "setBlockFilter"'+floorstr+IdString_0+', "blur": '+Number_0+', "hue": '+Int_0+', "grayscale": '+Number_1+', "invert": '+Bool_0+', "shadow": '+Number_2+'},\n';
return code;
*/;
trigger_s trigger_s
: '触发系统事件' 'x' PosString? ',' 'y' PosString? Newline : '触发系统事件' 'x' PosString? ',' 'y' PosString? Newline
@ -2003,36 +1716,6 @@ var code = '{"type": "disableShop", "id": "'+IdString_0+'"},\n';
return code; return code;
*/; */;
follow_s
: '跟随勇士' '行走图' EvalString Newline
/* follow_s
tooltip : follow: 跟随勇士
helpUrl : /_docs/#/instruction
default : ["npc.png"]
allImages : ['EvalString_0']
material : ["./project/images/:images", "EvalString_0"]
colour : this.dataColor
var code = '{"type": "follow", "name": "'+EvalString_0+'"},\n';
return code;
*/;
unfollow_s
: '取消跟随' '行走图' EvalString? Newline
/* unfollow_s
tooltip : unfollow: 取消跟随
helpUrl : /_docs/#/instruction
default : [""]
allImages : ['EvalString_0']
material : ["./project/images/:images", "EvalString_0"]
colour : this.dataColor
EvalString_0 = EvalString_0 ? (', "name": "' + EvalString_0 + '"') : "";
var code = '{"type": "unfollow"' + EvalString_0 + '},\n';
return code;
*/;
vibrate_s vibrate_s
: '画面震动' '方向' Vibrate_List '时间' Int '速度' Int '振幅' Int '不等待执行完毕' Bool Newline : '画面震动' '方向' Vibrate_List '时间' Int '速度' Int '振幅' Int '不等待执行完毕' Bool Newline
@ -2229,22 +1912,6 @@ var code = '{"type": "hideImage", "code": '+NInt_0+', "time": '+Int_0+async+'},\
return code; return code;
*/; */;
showGif_s
: '显示或清除动图' EvalString? '起点像素位置' 'x' PosString? 'y' PosString? Newline
/* showGif_s
tooltip : showGif显示动图
helpUrl : /_docs/#/instruction
default : ["","",""]
allImages : ['EvalString_0']
previewBlock : true
colour : this.imageColor
EvalString_0 = EvalString_0 ? (', "name": "'+EvalString_0+'"') : '';
var loc = (PosString_0 && PosString_1) ? (', "loc": ['+PosString_0+','+PosString_1+']') : '';
var code = '{"type": "showGif"'+EvalString_0+loc+'},\n';
return code;
*/;
moveImage_s moveImage_s
: '图片移动' '图片编号' NInt '终点像素位置' 'x' PosString? 'y' PosString? BGNL? : '图片移动' '图片编号' NInt '终点像素位置' 'x' PosString? 'y' PosString? BGNL?
@ -2354,7 +2021,7 @@ return code;
*/; */;
setWeather_s setWeather_s
: '更改天气' Weather_List '强度' Int '持续到下个本事件' Bool Newline : '(已弃用)更改天气' Weather_List '强度' Int '持续到下个本事件' Bool Newline
/* setWeather_s /* setWeather_s
@ -2964,7 +2631,7 @@ return code;
wait_s wait_s
: '等待用户操作并获得按键或点击信息' '仅检测子块' Bool '超时毫秒数' Int BGNL? Newline waitContext* BEND Newline : '(已弃用)等待用户操作并获得按键或点击信息' '仅检测子块' Bool '超时毫秒数' Int BGNL? Newline waitContext* BEND Newline
/* wait_s /* wait_s
@ -3162,7 +2829,7 @@ return code;
previewUI_s previewUI_s
: 'ui绘制并预览' '(双击此项可进行预览)' BGNL? Newline action+ BEND Newline : '(已弃用)ui绘制并预览' '(双击此项可进行预览)' BGNL? Newline action+ BEND Newline
/* previewUI_s /* previewUI_s
@ -3177,7 +2844,7 @@ return code;
clearMap_s clearMap_s
: '清除画布' '起点像素' 'x' PosString? 'y' PosString? '宽' PosString? '高' PosString? Newline : '(已弃用)清除画布' '起点像素' 'x' PosString? 'y' PosString? '宽' PosString? '高' PosString? Newline
/* clearMap_s /* clearMap_s
tooltip : clearMap: 清除画布 tooltip : clearMap: 清除画布
@ -3195,7 +2862,7 @@ return code;
setAttribute_s setAttribute_s
: '设置画布属性' '字体' FontString? '填充样式' ColorString? Colour '边框样式' ColorString? Colour BGNL? '线宽度' IntString? '不透明度' EvalString? '对齐' TextAlign_List '基准线' TextBaseline_List 'z值' IntString? Newline : '(已弃用)设置画布属性' '字体' FontString? '填充样式' ColorString? Colour '边框样式' ColorString? Colour BGNL? '线宽度' IntString? '不透明度' EvalString? '对齐' TextAlign_List '基准线' TextBaseline_List 'z值' IntString? Newline
/* setAttribute_s /* setAttribute_s
tooltip : setAttribute设置画布属性 tooltip : setAttribute设置画布属性
@ -3222,7 +2889,7 @@ return code;
setFilter_s setFilter_s
: '设置画布特效' '虚化' Number '色相' Int '灰度' Number '反色' Bool '阴影' Number Newline : '(已弃用)设置画布特效' '虚化' Number '色相' Int '灰度' Number '反色' Bool '阴影' Number Newline
/* setFilter_s /* setFilter_s
@ -3241,7 +2908,7 @@ return code;
fillText_s fillText_s
: '绘制文本' 'x' PosString 'y' PosString '样式' ColorString? Colour '字体' FontString? '最大宽度' IntString? BGNL? EvalString Newline : '(已弃用)绘制文本' 'x' PosString 'y' PosString '样式' ColorString? Colour '字体' FontString? '最大宽度' IntString? BGNL? EvalString Newline
/* fillText_s /* fillText_s
tooltip : fillText绘制一行文本可以设置最大宽度进行放缩 tooltip : fillText绘制一行文本可以设置最大宽度进行放缩
@ -3257,7 +2924,7 @@ return code;
*/; */;
fillBoldText_s fillBoldText_s
: '绘制描边文本' 'x' PosString 'y' PosString '样式' ColorString? Colour '描边颜色' ColorString? Colour '字体' FontString? BGNL? EvalString Newline : '(已弃用)绘制描边文本' 'x' PosString 'y' PosString '样式' ColorString? Colour '描边颜色' ColorString? Colour '字体' FontString? BGNL? EvalString Newline
/* fillBoldText_s /* fillBoldText_s
tooltip : fillBoldText绘制一行描边文本 tooltip : fillBoldText绘制一行描边文本
@ -3273,7 +2940,7 @@ return code;
*/; */;
drawTextContent_s drawTextContent_s
: '绘制多行文本' EvalString_Multi BGNL? '起点像素' 'x' PosString 'y' PosString '最大宽度' IntString? '颜色' ColorString? Colour BGNL? '对齐' TextAlign_List '字体大小' IntString? '行距' IntString? '粗体' Bool Newline : '(已弃用)绘制多行文本' EvalString_Multi BGNL? '起点像素' 'x' PosString 'y' PosString '最大宽度' IntString? '颜色' ColorString? Colour BGNL? '对齐' TextAlign_List '字体大小' IntString? '行距' IntString? '粗体' Bool Newline
/* drawTextContent_s /* drawTextContent_s
tooltip : drawTextContent绘制多行文本 tooltip : drawTextContent绘制多行文本
@ -3293,7 +2960,7 @@ return code;
*/; */;
fillRect_s fillRect_s
: '绘制矩形' '起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString '圆角半径' PosString? '旋转度数' PosString? '颜色' ColorString? Colour Newline : '(已弃用)绘制矩形' '起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString '圆角半径' PosString? '旋转度数' PosString? '颜色' ColorString? Colour Newline
/* fillRect_s /* fillRect_s
tooltip : fillRect绘制矩形 tooltip : fillRect绘制矩形
@ -3309,7 +2976,7 @@ return code;
*/; */;
strokeRect_s strokeRect_s
: '绘制矩形边框' '起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString '圆角半径' PosString? '旋转度数' PosString? '颜色' ColorString? Colour '线宽' IntString? Newline : '(已弃用)绘制矩形边框' '起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString '圆角半径' PosString? '旋转度数' PosString? '颜色' ColorString? Colour '线宽' IntString? Newline
/* strokeRect_s /* strokeRect_s
tooltip : strokeRect绘制矩形边框 tooltip : strokeRect绘制矩形边框
@ -3326,7 +2993,7 @@ return code;
*/; */;
drawLine_s drawLine_s
: '绘制线段' '起点像素' 'x' PosString 'y' PosString '终点像素' 'x' PosString 'y' PosString '颜色' ColorString? Colour '线宽' IntString? Newline : '(已弃用)绘制线段' '起点像素' 'x' PosString 'y' PosString '终点像素' 'x' PosString 'y' PosString '颜色' ColorString? Colour '线宽' IntString? Newline
/* drawLine_s /* drawLine_s
tooltip : drawLine绘制线段 tooltip : drawLine绘制线段
@ -3341,7 +3008,7 @@ return code;
*/; */;
drawArrow_s drawArrow_s
: '绘制箭头' '起点像素' 'x' PosString 'y' PosString '终点像素' 'x' PosString 'y' PosString '颜色' ColorString? Colour '线宽' IntString? Newline : '(已弃用)绘制箭头' '起点像素' 'x' PosString 'y' PosString '终点像素' 'x' PosString 'y' PosString '颜色' ColorString? Colour '线宽' IntString? Newline
/* drawArrow_s /* drawArrow_s
tooltip : drawArrow绘制箭头 tooltip : drawArrow绘制箭头
@ -3357,7 +3024,7 @@ return code;
fillPolygon_s fillPolygon_s
: '绘制多边形' '顶点像素列表' 'x' EvalString 'y' EvalString '颜色' ColorString? Colour Newline : '(已弃用)绘制多边形' '顶点像素列表' 'x' EvalString 'y' EvalString '颜色' ColorString? Colour Newline
/* fillPolygon_s /* fillPolygon_s
tooltip : fillPolygon绘制多边形 tooltip : fillPolygon绘制多边形
@ -3378,7 +3045,7 @@ return code;
strokePolygon_s strokePolygon_s
: '绘制多边形边框' '顶点像素列表' 'x' EvalString 'y' EvalString '颜色' ColorString? Colour '线宽' IntString? Newline : '(已弃用)绘制多边形边框' '顶点像素列表' 'x' EvalString 'y' EvalString '颜色' ColorString? Colour '线宽' IntString? Newline
/* strokePolygon_s /* strokePolygon_s
tooltip : strokePolygon绘制多边形边框 tooltip : strokePolygon绘制多边形边框
@ -3399,7 +3066,7 @@ return code;
*/; */;
fillEllipse_s fillEllipse_s
: '绘制椭圆' '中心' 'x' PosString 'y' PosString '长半径' PosString '短半径' PosString '旋转度数' PosString? '颜色' ColorString? Colour Newline : '(已弃用)绘制椭圆' '中心' 'x' PosString 'y' PosString '长半径' PosString '短半径' PosString '旋转度数' PosString? '颜色' ColorString? Colour Newline
/* fillEllipse_s /* fillEllipse_s
tooltip : fillEllipse绘制椭圆 tooltip : fillEllipse绘制椭圆
@ -3414,7 +3081,7 @@ return code;
*/; */;
strokeEllipse_s strokeEllipse_s
: '绘制椭圆边框' '中心' 'x' PosString 'y' PosString '长半径' PosString '短半径' PosString '旋转度数' PosString? '颜色' ColorString? Colour '线宽' IntString? Newline : '(已弃用)绘制椭圆边框' '中心' 'x' PosString 'y' PosString '长半径' PosString '短半径' PosString '旋转度数' PosString? '颜色' ColorString? Colour '线宽' IntString? Newline
/* strokeEllipse_s /* strokeEllipse_s
tooltip : strokeEllipse绘制椭圆边框 tooltip : strokeEllipse绘制椭圆边框
@ -3430,7 +3097,7 @@ return code;
*/; */;
fillArc_s fillArc_s
: '绘制扇形' '中心' 'x' PosString 'y' PosString '半径' PosString '起点角度' PosString '终点角度' PosString '颜色' ColorString? Colour Newline : '(已弃用)绘制扇形' '中心' 'x' PosString 'y' PosString '半径' PosString '起点角度' PosString '终点角度' PosString '颜色' ColorString? Colour Newline
/* fillArc_s /* fillArc_s
tooltip : fillArc绘制扇形 tooltip : fillArc绘制扇形
@ -3444,7 +3111,7 @@ return code;
strokeArc_s strokeArc_s
: '绘制弧' '中心' 'x' PosString 'y' PosString '半径' PosString '起点角度' PosString '终点角度' PosString '颜色' ColorString? Colour '线宽' IntString? Newline : '(已弃用)绘制弧' '中心' 'x' PosString 'y' PosString '半径' PosString '起点角度' PosString '终点角度' PosString '颜色' ColorString? Colour '线宽' IntString? Newline
/* strokeArc_s /* strokeArc_s
tooltip : strokeArc绘制弧 tooltip : strokeArc绘制弧
@ -3460,7 +3127,7 @@ return code;
drawImage_s drawImage_s
: '绘制图片' EvalString '翻转' Reverse_List '起点像素' 'x' PosString 'y' PosString '宽' PosString? '高' PosString? '旋转度数' PosString? Newline : '(已弃用)绘制图片' EvalString '翻转' Reverse_List '起点像素' 'x' PosString 'y' PosString '宽' PosString? '高' PosString? '旋转度数' PosString? Newline
/* drawImage_s /* drawImage_s
@ -3481,7 +3148,7 @@ return code;
*/; */;
drawImage_1_s drawImage_1_s
: '绘制图片' EvalString '翻转' Reverse_List '裁剪的起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString BGNL? : '(已弃用)绘制图片' EvalString '翻转' Reverse_List '裁剪的起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString BGNL?
'绘制的起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString '旋转度数' PosString? Newline '绘制的起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString '旋转度数' PosString? Newline
@ -3503,7 +3170,7 @@ return code;
*/; */;
drawIcon_s drawIcon_s
: '绘制图标' 'ID' IdString '帧' Int '起点像素' 'x' PosString 'y' PosString '宽' PosString? '高' PosString? Newline : '(已弃用)绘制图标' 'ID' IdString '帧' Int '起点像素' 'x' PosString 'y' PosString '宽' PosString? '高' PosString? Newline
/* drawIcon_s /* drawIcon_s
@ -3521,7 +3188,7 @@ return code;
*/; */;
drawBackground_s drawBackground_s
: '绘制背景图' EvalString Colour '起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString Newline : '(已弃用)绘制背景图' EvalString Colour '起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString Newline
/* drawBackground_s /* drawBackground_s
@ -3545,7 +3212,7 @@ return code;
*/; */;
drawSelector_s drawSelector_s
: '绘制闪烁光标' EvalString '编号' Int '起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString Newline : '(已弃用)绘制闪烁光标' EvalString '编号' Int '起点像素' 'x' PosString 'y' PosString '宽' PosString '高' PosString Newline
/* drawSelector_s /* drawSelector_s
@ -3559,7 +3226,7 @@ return code;
*/; */;
drawSelector_1_s drawSelector_1_s
: '清除闪烁光标' '编号' Int Newline : '(已弃用)清除闪烁光标' '编号' Int Newline
/* drawSelector_1_s /* drawSelector_1_s
@ -4005,6 +3672,10 @@ TextAlign_List
: '不改变'|'左对齐'|'左右居中'|'右对齐' : '不改变'|'左对齐'|'左右居中'|'右对齐'
/*TextAlign_List ['null','left','center','right']*/; /*TextAlign_List ['null','left','center','right']*/;
WordBreak_List
: '不改变'|'不分词'|'空格分词'|'全部分词'
/*WordBreak_List ['null','none','space','all']*/;
TextBaseline_List TextBaseline_List
: '不改变'|'顶部'|'悬挂'|'居中'|'标准值'|'ideographic'|'底部' : '不改变'|'顶部'|'悬挂'|'居中'|'标准值'|'ideographic'|'底部'
/*TextBaseline_List ['null','top','hanging','middle','alphabetic','ideographic','bottom']*/; /*TextBaseline_List ['null','top','hanging','middle','alphabetic','ideographic','bottom']*/;

View File

@ -249,10 +249,6 @@ ActionParser.prototype.parseAction = function() {
// 不同种类的事件 // 不同种类的事件
// 如果是文字:显示
if (typeof data == "string") {
data={"type": "text", "text": data}
}
this.event.data.type=data.type; this.event.data.type=data.type;
switch (data.type) { switch (data.type) {
case "_next": case "_next":
@ -260,56 +256,8 @@ ActionParser.prototype.parseAction = function() {
this.next = data.next; this.next = data.next;
return; return;
case "text": // 文字/对话 case "text": // 文字/对话
var info = this.getTitleAndPosition(data.text); this.next = MotaActionBlocks['text_s'].xmlText([
var textDrawing = []; data.title, data.icon, data.x, data.y, data.width, data.height, data.keepLast,data.interval,data.lineHeight, this.next]);
info[3] = (info[3] || "").replace(/(\f|\\f)\[(.*?)]/g, function (text, sympol, str) {
var ss = str.split(",");
if (ss.length == 3 || ss.length == 5 || ss.length >=9) {
var swap = function (i, j) { var x = ss[i]; ss[i] = ss[j]; ss[j] = x;}
if (ss.length >= 9) {
swap(1,5); swap(2,6); swap(3,7); swap(4,8);
}
textDrawing.push(ss);
}
return '';
});
if (textDrawing.length > 0) {
var buildTextDrawing = function (obj) {
if(!obj) obj=[];
var text_choices = null;
for(var ii=obj.length-1,choice;choice=obj[ii];ii--) {
var reverse = 'null';
if (choice[0].endsWith(':o') || choice[0].endsWith(':x') || choice[0].endsWith(':y')) {
reverse = choice[0].substring(choice[0].length - 2);
choice[0] = choice[0].substring(0, choice[0].length - 2);
}
text_choices=MotaActionBlocks['textDrawing'].xmlText([
choice[0], reverse, choice[1], choice[2], choice[3], choice[4], choice[5], choice[6],
choice[7], choice[8], choice[9], choice[10], text_choices]);
}
return text_choices;
}
data.pos = data.pos || [];
this.next = MotaActionFunctions.xmlText('text_2_s', [
info[0], info[1], info[2], data.pos[0], data.pos[1], data.pos[2], data.code||0, data.async||false, info[3], buildTextDrawing(textDrawing), this.next
], /* isShadow */false, /*comment*/ null, /*collapsed*/ data._collapsed, /*disabled*/ data._disabled);
} else if (info[0] || info[1] || info[2] || data.pos || data.code) {
data.pos = data.pos || [];
this.next = MotaActionFunctions.xmlText('text_1_s',[
info[0], info[1], info[2], data.pos[0], data.pos[1], data.pos[2], data.code||0, data.async||false, info[3], this.next], /* isShadow */false, /*comment*/ null, /*collapsed*/ data._collapsed, /*disabled*/ data._disabled);
}
else {
this.next = MotaActionFunctions.xmlText('text_0_s', [info[3],this.next],
/* isShadow */false, /*comment*/ null, /*collapsed*/ data._collapsed, /*disabled*/ data._disabled);
}
break;
case "moveTextBox": // 移动对话框
data.loc = data.loc || ['',''];
this.next = MotaActionBlocks['moveTextBox_s'].xmlText([
data.code, data.loc[0], data.loc[1], data.relative||false, data.moveMode, data.time, data.async, this.next]);
break;
case "clearTextBox": // 清除对话框
this.next = MotaActionBlocks['clearTextBox_s'].xmlText([(data.code||"").toString(),this.next]);
break; break;
case "autoText": // 自动剧情文本 case "autoText": // 自动剧情文本
var info = this.getTitleAndPosition(data.text); var info = this.getTitleAndPosition(data.text);
@ -324,14 +272,14 @@ ActionParser.prototype.parseAction = function() {
this.next = MotaActionBlocks['comment_s'].xmlText([this.EvalString_Multi(data.text),this.next]); this.next = MotaActionBlocks['comment_s'].xmlText([this.EvalString_Multi(data.text),this.next]);
break; break;
case "setText": // 设置剧情文本的属性 case "setText": // 设置剧情文本的属性
data.title=this.Colour(data.title); //data.backColor=this.Colour(data.backColor);
data.text=this.Colour(data.text); //data.fillStyle=this.Colour(data.fillStyle);
if (!/^\w+\.png$/.test(data.background)) //data.strokeStyle=this.Colour(data.strokeStyle);
data.background=this.Colour(data.background);
this.next = MotaActionBlocks['setText_s'].xmlText([ this.next = MotaActionBlocks['setText_s'].xmlText([
data.position,data.offset,data.align,data.bold,data.title,'rgba('+data.title+')', data.x,data.y,data.width,data.height,data.fontFamily,data.fontSize,data.fontWeight,
data.text,'rgba('+data.text+')',data.background,'rgba('+data.background+')', data.fontItalic,data.keepLast,data.interval,data.lineHeight,,data.fillStyle,'rgba('+data.fillStyle+')',
data.titlefont,data.textfont,data.lineHeight,data.time,data.letterSpacing,data.animateTime,this.next]); data.strokeStyle,'rgba('+data.strokeStyle+')',data.strokeWidth,data.fill,data.stroke,data.backColor,'rgba('+data.backColor+')',
data.winskin,data.padding,data.titleFill,data.titleStroke,data.titlePadding,data.textAlign,data.wordBreak,data.ignoreLineStart,data.ignoreLineEnd,data.breakChars,this.next]);
break; break;
case "tip": case "tip":
this.next = MotaActionBlocks['tip_s'].xmlText([ this.next = MotaActionBlocks['tip_s'].xmlText([
@ -385,18 +333,6 @@ ActionParser.prototype.parseAction = function() {
this.next = MotaActionBlocks['setBlockOpacity_s'].xmlText([ this.next = MotaActionBlocks['setBlockOpacity_s'].xmlText([
x_str.join(','),y_str.join(','),data.floorId||'',data.opacity,data.time,data.async||false,this.next]); x_str.join(','),y_str.join(','),data.floorId||'',data.opacity,data.time,data.async||false,this.next]);
break; break;
case "setBlockFilter": // 设置图块不透明度
data.loc=data.loc||[];
if (!(data.loc[0] instanceof Array))
data.loc = [data.loc];
var x_str=[],y_str=[];
data.loc.forEach(function (t) {
x_str.push(t[0]);
y_str.push(t[1]);
})
this.next = MotaActionBlocks['setBlockFilter_s'].xmlText([
x_str.join(','),y_str.join(','),data.floorId||'',data.blur,data.hue,data.grayscale,data.invert||false,data.shadow,this.next]);
break;
case "turnBlock": // 事件转向 case "turnBlock": // 事件转向
data.loc=data.loc||[]; data.loc=data.loc||[];
if (!(data.loc[0] instanceof Array)) if (!(data.loc[0] instanceof Array))
@ -542,12 +478,6 @@ ActionParser.prototype.parseAction = function() {
this.next = MotaActionBlocks['changePos_s'].xmlText([ this.next = MotaActionBlocks['changePos_s'].xmlText([
data.loc[0],data.loc[1],data.direction,this.next]); data.loc[0],data.loc[1],data.direction,this.next]);
break; break;
case "follow": // 跟随勇士
this.next = MotaActionBlocks['follow_s'].xmlText([data.name||"", this.next]);
break;
case "unfollow": // 取消跟随
this.next = MotaActionBlocks['unfollow_s'].xmlText([data.name||"", this.next]);
break;
case "animate": // 显示动画 case "animate": // 显示动画
if (data.loc == 'hero') { if (data.loc == 'hero') {
this.next = MotaActionBlocks['animate_1_s'].xmlText([ this.next = MotaActionBlocks['animate_1_s'].xmlText([
@ -616,11 +546,6 @@ ActionParser.prototype.parseAction = function() {
this.next = MotaActionBlocks['scaleImage_s'].xmlText([ this.next = MotaActionBlocks['scaleImage_s'].xmlText([
data.code, data.center[0], data.center[1], data.moveMode||'', data.scale, data.time||0, data.async||false, this.next]); data.code, data.center[0], data.center[1], data.moveMode||'', data.scale, data.time||0, data.async||false, this.next]);
break; break;
case "showGif": // 显示动图
data.loc=data.loc||['','']
this.next = MotaActionBlocks['showGif_s'].xmlText([
data.name,data.loc[0],data.loc[1],this.next]);
break;
case "setCurtain": // 颜色渐变 case "setCurtain": // 颜色渐变
if(this.isset(data.color)){ if(this.isset(data.color)){
data.color = this.Colour(data.color); data.color = this.Colour(data.color);
@ -750,47 +675,6 @@ ActionParser.prototype.parseAction = function() {
data.norefresh || false, data.norefresh || false,
this.next]); this.next]);
break; break;
case "setEnemy":
this.next = MotaActionBlocks['setEnemy_s'].xmlText([
MotaActionFunctions.replaceToName_token(data.id), data.name, data["operator"]||'=', this.expandEvalBlock([data.value]),
data.norefresh||false, this.next]);
break;
case "setEnemyOnPoint":
data.loc=data.loc||[];
if (!(data.loc[0] instanceof Array))
data.loc = [data.loc];
var x_str=[],y_str=[];
data.loc.forEach(function (t) {
x_str.push(t[0]);
y_str.push(t[1]);
})
this.next = MotaActionBlocks['setEnemyOnPoint_s'].xmlText([
x_str.join(','),y_str.join(','),data.floorId||'',data.name, data["operator"]||'=', this.expandEvalBlock([data.value]),
data.norefresh||false, this.next]);
break;
case "resetEnemyOnPoint":
data.loc=data.loc||[];
if (!(data.loc[0] instanceof Array))
data.loc = [data.loc];
var x_str=[],y_str=[];
data.loc.forEach(function (t) {
x_str.push(t[0]);
y_str.push(t[1]);
})
this.next = MotaActionBlocks['resetEnemyOnPoint_s'].xmlText([
x_str.join(','),y_str.join(','), data.floorId||'',data.norefresh||false,this.next]);
break;
case "moveEnemyOnPoint":
data.from=data.from||['','']
if (data.dxy) {
this.next = MotaActionBlocks['moveEnemyOnPoint_1_s'].xmlText([
data.from[0], data.from[1], data.dxy[0], data.dxy[1], data.floorId||'',data.norefresh||false,this.next]);
} else {
data.to=data.to||['','']
this.next = MotaActionBlocks['moveEnemyOnPoint_s'].xmlText([
data.from[0], data.from[1], data.to[0], data.to[1], data.floorId||'',data.norefresh||false,this.next]);
}
break;
case "setEquip": case "setEquip":
this.next = MotaActionBlocks['setEquip_s'].xmlText([ this.next = MotaActionBlocks['setEquip_s'].xmlText([
MotaActionFunctions.replaceToName_token(data.id), data.valueType||'value', data.name, data["operator"]||'=', this.expandEvalBlock([data.value]), this.next]); MotaActionFunctions.replaceToName_token(data.id), data.valueType||'value', data.name, data["operator"]||'=', this.expandEvalBlock([data.value]), this.next]);

View File

@ -96,11 +96,8 @@ editor_blocklyconfig=(function(){
], 'splitImages'), ], 'splitImages'),
], ],
'显示文字':[ '显示文字':[
MotaActionBlocks['text_0_s'].xmlText(), MotaActionBlocks['text_s'].xmlText(),
MotaActionBlocks['text_1_s'].xmlText(),
MotaActionFunctions.actionParser.parseList("\t[小妖精,fairy]\f[fairy.png,0,0]欢迎使用事件编辑器(双击方块可直接预览)"),
MotaActionBlocks['moveTextBox_s'].xmlText(),
MotaActionBlocks['clearTextBox_s'].xmlText(),
MotaActionBlocks['comment_s'].xmlText(), MotaActionBlocks['comment_s'].xmlText(),
MotaActionBlocks['autoText_s'].xmlText(), MotaActionBlocks['autoText_s'].xmlText(),
MotaActionBlocks['scrollText_s'].xmlText(), MotaActionBlocks['scrollText_s'].xmlText(),
@ -120,11 +117,6 @@ editor_blocklyconfig=(function(){
MotaActionBlocks['setValue_s'].xmlText([ MotaActionBlocks['setValue_s'].xmlText([
MotaActionBlocks['idIdList_e'].xmlText(['status','生命']), '=', '', false MotaActionBlocks['idIdList_e'].xmlText(['status','生命']), '=', '', false
]), ]),
MotaActionBlocks['setEnemy_s'].xmlText(),
MotaActionBlocks['setEnemyOnPoint_s'].xmlText(),
MotaActionBlocks['resetEnemyOnPoint_s'].xmlText(),
MotaActionBlocks['moveEnemyOnPoint_s'].xmlText(),
MotaActionBlocks['moveEnemyOnPoint_1_s'].xmlText(),
MotaActionBlocks['setEquip_s'].xmlText(), MotaActionBlocks['setEquip_s'].xmlText(),
MotaActionBlocks['setFloor_s'].xmlText(), MotaActionBlocks['setFloor_s'].xmlText(),
MotaActionBlocks['setGlobalAttribute_s'].xmlText(), MotaActionBlocks['setGlobalAttribute_s'].xmlText(),
@ -143,9 +135,7 @@ editor_blocklyconfig=(function(){
MotaActionBlocks['unloadEquip_s'].xmlText(), MotaActionBlocks['unloadEquip_s'].xmlText(),
MotaActionBlocks['openShop_s'].xmlText(), MotaActionBlocks['openShop_s'].xmlText(),
MotaActionBlocks['disableShop_s'].xmlText(), MotaActionBlocks['disableShop_s'].xmlText(),
MotaActionBlocks['setHeroIcon_s'].xmlText(), MotaActionBlocks['setHeroIcon_s'].xmlText()
MotaActionBlocks['follow_s'].xmlText(),
MotaActionBlocks['unfollow_s'].xmlText(),
], ],
'地图处理':[ '地图处理':[
MotaActionBlocks['battle_1_s'].xmlText(), MotaActionBlocks['battle_1_s'].xmlText(),
@ -155,7 +145,6 @@ editor_blocklyconfig=(function(){
MotaActionBlocks['hide_s'].xmlText(), MotaActionBlocks['hide_s'].xmlText(),
MotaActionBlocks['setBlock_s'].xmlText(), MotaActionBlocks['setBlock_s'].xmlText(),
MotaActionBlocks['setBlockOpacity_s'].xmlText(), MotaActionBlocks['setBlockOpacity_s'].xmlText(),
MotaActionBlocks['setBlockFilter_s'].xmlText(),
MotaActionBlocks['turnBlock_s'].xmlText(), MotaActionBlocks['turnBlock_s'].xmlText(),
MotaActionBlocks['moveHero_s'].xmlText(), MotaActionBlocks['moveHero_s'].xmlText(),
MotaActionBlocks['move_s'].xmlText(), MotaActionBlocks['move_s'].xmlText(),
@ -225,7 +214,6 @@ editor_blocklyconfig=(function(){
MotaActionBlocks['moveImage_s'].xmlText(), MotaActionBlocks['moveImage_s'].xmlText(),
MotaActionBlocks['rotateImage_s'].xmlText(), MotaActionBlocks['rotateImage_s'].xmlText(),
MotaActionBlocks['scaleImage_s'].xmlText(), MotaActionBlocks['scaleImage_s'].xmlText(),
MotaActionBlocks['showGif_s'].xmlText(),
MotaActionBlocks['playBgm_s'].xmlText(), MotaActionBlocks['playBgm_s'].xmlText(),
MotaActionBlocks['pauseBgm_s'].xmlText(), MotaActionBlocks['pauseBgm_s'].xmlText(),
MotaActionBlocks['resumeBgm_s'].xmlText(), MotaActionBlocks['resumeBgm_s'].xmlText(),

View File

@ -211,6 +211,7 @@ class TextureCache extends EventEmitter<TextureCacheEvent> {
// enemy48和npc48都应该视为大怪物 // enemy48和npc48都应该视为大怪物
if (cls === 'enemy48' || cls === 'npc48') { if (cls === 'enemy48' || cls === 'npc48') {
const img = core.material.images[cls]; const img = core.material.images[cls];
if (!img) return null;
// @ts-ignore // @ts-ignore
const line = icons[cls][id]; const line = icons[cls][id];
const w = 32; const w = 32;
@ -234,6 +235,7 @@ class TextureCache extends EventEmitter<TextureCacheEvent> {
} }
// 自动元件 // 自动元件
if (cls === 'autotile') { if (cls === 'autotile') {
if (!this.autotile) return null;
const auto = this.autotile[num as AllNumbersOf<'autotile'>]; const auto = this.autotile[num as AllNumbersOf<'autotile'>];
const cell = 32; const cell = 32;
const render: [number, number, number, number][] = []; const render: [number, number, number, number][] = [];
@ -264,6 +266,7 @@ class TextureCache extends EventEmitter<TextureCacheEvent> {
core.material.images[ core.material.images[
cls as Exclude<Cls, 'tileset' | 'autotile'> cls as Exclude<Cls, 'tileset' | 'autotile'>
]; ];
if (!image) return null;
const frame = core.getAnimateFrames(cls); const frame = core.getAnimateFrames(cls);
const cell = 32; const cell = 32;
// @ts-ignore // @ts-ignore

View File

@ -69,6 +69,7 @@ Mota.require('var', 'loading').once('coreInit', () => {
</layer-group> </layer-group>
<Textbox id="main-textbox" {...mainTextboxProps}></Textbox> <Textbox id="main-textbox" {...mainTextboxProps}></Textbox>
<FloorChange id="floor-change" zIndex={50}></FloorChange> <FloorChange id="floor-change" zIndex={50}></FloorChange>
<icon icon={13} animate></icon>
</container> </container>
); );
}); });

View File

@ -1,7 +1,8 @@
import { MotaOffscreenCanvas2D } from '@/core/fx/canvas2d'; import { MotaOffscreenCanvas2D } from '@/core/fx/canvas2d';
import { ERenderItemEvent, RenderItem } from '../item'; import { ERenderItemEvent, RenderItem, RenderItemPosition } from '../item';
import { Transform } from '../transform'; import { Transform } from '../transform';
import { ElementNamespace, ComponentInternalInstance } from 'vue'; import { ElementNamespace, ComponentInternalInstance } from 'vue';
import { isNil } from 'lodash-es';
/* /*
* Expected usage (this comment needs to be deleted after implementing correctly): * Expected usage (this comment needs to be deleted after implementing correctly):
@ -50,52 +51,124 @@ export const enum GraphicMode {
StrokeAndFill StrokeAndFill
} }
const enum GraphicModeProp {
Fill,
Stroke,
StrokeAndFill
}
export interface EGraphicItemEvent extends ERenderItemEvent {} export interface EGraphicItemEvent extends ERenderItemEvent {}
export abstract class GraphicItemBase export abstract class GraphicItemBase
extends RenderItem<EGraphicItemEvent> extends RenderItem<EGraphicItemEvent>
implements IGraphicProperty implements Required<ILineProperty>
{ {
mode: number = GraphicMode.Fill; mode: number = GraphicMode.Fill;
fill: CanvasStyle = '#fff'; fill: CanvasStyle = '#fff';
stroke: CanvasStyle = '#fff'; stroke: CanvasStyle = '#fff';
lineWidth: number = 2; lineWidth: number = 2;
lineDash?: number[] | undefined; lineDash: number[] = [];
lineDashOffset?: number | undefined; lineDashOffset: number = 0;
lineJoin: CanvasLineJoin = 'bevel'; lineJoin: CanvasLineJoin = 'bevel';
lineCap: CanvasLineCap = 'butt'; lineCap: CanvasLineCap = 'butt';
miterLimit: number = 10; miterLimit: number = 10;
fillRule: CanvasFillRule = 'nonzero'; fillRule: CanvasFillRule = 'nonzero';
private propFill: boolean = true;
private propStroke: boolean = false;
private strokeAndFill: boolean = false;
private propFillSet: boolean = false;
/** /**
* *
* @param options 线 * @param options 线
*/ */
setLineOption(options: Partial<ILineProperty>) {} setLineOption(options: Partial<ILineProperty>) {
if (!isNil(options.lineWidth)) this.lineWidth = options.lineWidth;
if (!isNil(options.lineDash)) this.lineDash = options.lineDash;
if (!isNil(options.lineDashOffset))
this.lineDashOffset = options.lineDashOffset;
if (!isNil(options.lineJoin)) this.lineJoin = options.lineJoin;
if (!isNil(options.lineCap)) this.lineCap = options.lineCap;
if (!isNil(options.miterLimit)) this.miterLimit = options.miterLimit;
this.update();
}
/** /**
* *
* @param style * @param style
*/ */
setFillStyle(style: CanvasStyle) {} setFillStyle(style: CanvasStyle) {
this.fill = style;
this.update();
}
/** /**
* *
* @param style * @param style
*/ */
setStrokeStyle(style: CanvasStyle) {} setStrokeStyle(style: CanvasStyle) {
this.stroke = style;
this.update();
}
/** /**
* *
* @param rule * @param rule
*/ */
setFillRule(rule: CanvasFillRule) {} setFillRule(rule: CanvasFillRule) {
this.fillRule = rule;
this.update();
}
/** /**
* *
* @param mode * @param mode
*/ */
setMode(mode: GraphicMode) {} setMode(mode: GraphicMode) {
this.mode = mode;
this.update();
}
/**
* {@link GraphicPropsBase} fill stroke strokeAndFill
*/
private checkMode(mode: GraphicModeProp, value: boolean) {
switch (mode) {
case GraphicModeProp.Fill:
this.propFill = value;
this.propFillSet = true;
break;
case GraphicModeProp.Stroke:
this.propStroke = value;
break;
case GraphicModeProp.StrokeAndFill:
this.strokeAndFill = value;
break;
}
if (this.strokeAndFill) {
this.mode = GraphicMode.StrokeAndFill;
} else {
if (!this.propFillSet) {
if (this.propStroke) {
this.mode = GraphicMode.Stroke;
} else {
this.mode = GraphicMode.Fill;
}
} else {
if (this.propFill && this.propStroke) {
this.mode = GraphicMode.FillAndStroke;
} else if (this.propFill) {
this.mode = GraphicMode.Fill;
} else if (this.propStroke) {
this.mode = GraphicMode.Stroke;
} else {
this.mode = GraphicMode.Fill;
}
}
}
this.update();
}
/** /**
* *
@ -103,7 +176,14 @@ export abstract class GraphicItemBase
*/ */
protected setCanvasState(canvas: MotaOffscreenCanvas2D) { protected setCanvasState(canvas: MotaOffscreenCanvas2D) {
const ctx = canvas.ctx; const ctx = canvas.ctx;
ctx.fillStyle = this.fill; // 示例后面的都按这个写不需要save restore写完把这个注释删了 ctx.fillStyle = this.fill;
ctx.strokeStyle = this.stroke;
ctx.lineWidth = this.lineWidth;
ctx.setLineDash(this.lineDash);
ctx.lineDashOffset = this.lineDashOffset;
ctx.lineJoin = this.lineJoin;
ctx.lineCap = this.lineCap;
ctx.miterLimit = this.miterLimit;
} }
patchProp( patchProp(
@ -113,7 +193,60 @@ export abstract class GraphicItemBase
namespace?: ElementNamespace, namespace?: ElementNamespace,
parentComponent?: ComponentInternalInstance | null parentComponent?: ComponentInternalInstance | null
): void { ): void {
if (isNil(prevValue) && isNil(nextValue)) return;
switch (key) { switch (key) {
case 'fill':
if (!this.assertType(nextValue, 'boolean', key)) return;
this.checkMode(GraphicModeProp.Fill, nextValue);
break;
case 'stroke':
if (!this.assertType(nextValue, 'boolean', key)) return;
this.checkMode(GraphicModeProp.Stroke, nextValue);
break;
case 'strokeAndFill':
if (!this.assertType(nextValue, 'number', key)) return;
this.checkMode(GraphicModeProp.StrokeAndFill, nextValue);
break;
case 'fillRule':
if (!this.assertType(nextValue, 'string', key)) return;
this.setFillRule(nextValue);
break;
case 'fillStyle':
this.setFillStyle(nextValue);
break;
case 'strokeStyle':
this.setStrokeStyle(nextValue);
break;
case 'lineWidth':
if (!this.assertType(nextValue, 'number', key)) return;
this.lineWidth = nextValue;
this.update();
break;
case 'lineDash':
if (!this.assertType(nextValue, Array, key)) return;
this.lineDash = nextValue;
this.update();
break;
case 'lineDashOffset':
if (!this.assertType(nextValue, 'number', key)) return;
this.lineDashOffset = nextValue;
this.update();
break;
case 'lineJoin':
if (!this.assertType(nextValue, 'string', key)) return;
this.lineJoin = nextValue;
this.update();
break;
case 'lineCap':
if (!this.assertType(nextValue, 'string', key)) return;
this.lineCap = nextValue;
this.update();
break;
case 'miterLimit':
if (!this.assertType(nextValue, 'number', key)) return;
this.miterLimit = nextValue;
this.update();
break;
} }
super.patchProp(key, prevValue, nextValue, namespace, parentComponent); super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
} }
@ -122,7 +255,7 @@ export abstract class GraphicItemBase
export class Rect extends GraphicItemBase { export class Rect extends GraphicItemBase {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void { ): void {
const ctx = canvas.ctx; const ctx = canvas.ctx;
this.setCanvasState(canvas); this.setCanvasState(canvas);
@ -155,21 +288,51 @@ export class Circle extends GraphicItemBase {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void {} ): void {
const ctx = canvas.ctx;
this.setCanvasState(canvas);
ctx.beginPath();
ctx.arc(this.x, this.y, this.radius, this.start, this.end);
switch (this.mode) {
case GraphicMode.Fill:
ctx.fill(this.fillRule);
break;
case GraphicMode.Stroke:
ctx.stroke();
break;
case GraphicMode.FillAndStroke:
ctx.fill(this.fillRule);
ctx.stroke();
break;
case GraphicMode.StrokeAndFill:
ctx.stroke();
ctx.fill(this.fillRule);
break;
}
}
/** /**
* *
* @param radius * @param radius
*/ */
setRadius(radius: number) {} setRadius(radius: number) {
this.radius = radius;
this.size(radius * 2, radius * 2);
this.update();
}
/** /**
* *
* @param start * @param start
* @param end * @param end
*/ */
setAngle(start: number, end: number) {} setAngle(start: number, end: number) {
this.start = start;
this.end = end;
this.update();
}
patchProp( patchProp(
key: string, key: string,
@ -179,6 +342,18 @@ export class Circle extends GraphicItemBase {
parentComponent?: ComponentInternalInstance | null parentComponent?: ComponentInternalInstance | null
): void { ): void {
switch (key) { switch (key) {
case 'radius':
if (!this.assertType(nextValue, 'number', key)) return;
this.setRadius(nextValue);
return;
case 'start':
if (!this.assertType(nextValue, 'number', key)) return;
this.setAngle(nextValue, this.end);
return;
case 'end':
if (!this.assertType(nextValue, 'number', key)) return;
this.setAngle(this.start, nextValue);
return;
} }
super.patchProp(key, prevValue, nextValue, namespace, parentComponent); super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
} }
@ -192,22 +367,60 @@ export class Ellipse extends GraphicItemBase {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void {} ): void {
const ctx = canvas.ctx;
this.setCanvasState(canvas);
ctx.beginPath();
ctx.ellipse(
this.x,
this.y,
this.radiusX,
this.radiusY,
0,
this.start,
this.end
);
switch (this.mode) {
case GraphicMode.Fill:
ctx.fill(this.fillRule);
break;
case GraphicMode.Stroke:
ctx.stroke();
break;
case GraphicMode.FillAndStroke:
ctx.fill(this.fillRule);
ctx.stroke();
break;
case GraphicMode.StrokeAndFill:
ctx.stroke();
ctx.fill(this.fillRule);
break;
}
}
/** /**
* *
* @param x * @param x
* @param y * @param y
*/ */
setRadius(x: number, y: number) {} setRadius(x: number, y: number) {
this.radiusX = x;
this.radiusY = y;
this.update();
}
/** /**
* *
* @param start * @param start
* @param end * @param end
*/ */
setAngle(start: number, end: number) {} setAngle(start: number, end: number) {
this.start = start;
this.end = end;
this.update();
}
patchProp( patchProp(
key: string, key: string,
@ -217,6 +430,22 @@ export class Ellipse extends GraphicItemBase {
parentComponent?: ComponentInternalInstance | null parentComponent?: ComponentInternalInstance | null
): void { ): void {
switch (key) { switch (key) {
case 'radiusX':
if (!this.assertType(nextValue, 'number', key)) return;
this.setRadius(nextValue, this.radiusY);
return;
case 'radiusY':
if (!this.assertType(nextValue, 'number', key)) return;
this.setRadius(this.radiusY, nextValue);
return;
case 'start':
if (!this.assertType(nextValue, 'number', key)) return;
this.setAngle(nextValue, this.end);
return;
case 'end':
if (!this.assertType(nextValue, 'number', key)) return;
this.setAngle(this.start, nextValue);
return;
} }
super.patchProp(key, prevValue, nextValue, namespace, parentComponent); super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
} }
@ -230,18 +459,33 @@ export class Line extends GraphicItemBase {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void {} ): void {
const ctx = canvas.ctx;
this.setCanvasState(canvas);
ctx.beginPath();
ctx.moveTo(this.x1, this.y1);
ctx.lineTo(this.x2, this.y2);
ctx.stroke();
}
/** /**
* *
*/ */
setPoint1(x: number, y: number) {} setPoint1(x: number, y: number) {
this.x1 = x;
this.y1 = y;
this.update();
}
/** /**
* *
*/ */
setPoint2(x: number, y: number) {} setPoint2(x: number, y: number) {
this.x2 = x;
this.y2 = y;
this.update();
}
patchProp( patchProp(
key: string, key: string,
@ -251,6 +495,22 @@ export class Line extends GraphicItemBase {
parentComponent?: ComponentInternalInstance | null parentComponent?: ComponentInternalInstance | null
): void { ): void {
switch (key) { switch (key) {
case 'x1':
if (!this.assertType(nextValue, 'number', key)) return;
this.setPoint1(nextValue, this.y1);
return;
case 'y1':
if (!this.assertType(nextValue, 'number', key)) return;
this.setPoint1(this.x1, nextValue);
return;
case 'x2':
if (!this.assertType(nextValue, 'number', key)) return;
this.setPoint2(nextValue, this.y2);
return;
case 'y2':
if (!this.assertType(nextValue, 'number', key)) return;
this.setPoint2(this.x2, nextValue);
return;
} }
super.patchProp(key, prevValue, nextValue, namespace, parentComponent); super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
} }
@ -268,28 +528,58 @@ export class BezierCurve extends GraphicItemBase {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void {} ): void {
const ctx = canvas.ctx;
this.setCanvasState(canvas);
ctx.beginPath();
ctx.moveTo(this.sx, this.sy);
ctx.bezierCurveTo(
this.cp1x,
this.cp1y,
this.cp2x,
this.cp2y,
this.ex,
this.ey
);
ctx.stroke();
}
/** /**
* *
*/ */
setStart(x: number, y: number) {} setStart(x: number, y: number) {
this.sx = x;
this.sy = y;
this.update();
}
/** /**
* 1 * 1
*/ */
setControl1(x: number, y: number) {} setControl1(x: number, y: number) {
this.cp1x = x;
this.cp1y = y;
this.update();
}
/** /**
* 2 * 2
*/ */
setControl2(x: number, y: number) {} setControl2(x: number, y: number) {
this.cp2x = x;
this.cp2y = y;
this.update();
}
/** /**
* *
*/ */
setEnd(x: number, y: number) {} setEnd(x: number, y: number) {
this.ex = x;
this.ey = y;
this.update();
}
patchProp( patchProp(
key: string, key: string,
@ -299,6 +589,38 @@ export class BezierCurve extends GraphicItemBase {
parentComponent?: ComponentInternalInstance | null parentComponent?: ComponentInternalInstance | null
): void { ): void {
switch (key) { switch (key) {
case 'sx':
if (!this.assertType(nextValue, 'number', key)) return;
this.setStart(nextValue, this.sy);
return;
case 'sy':
if (!this.assertType(nextValue, 'number', key)) return;
this.setStart(this.sx, nextValue);
return;
case 'cp1x':
if (!this.assertType(nextValue, 'number', key)) return;
this.setControl1(nextValue, this.cp1y);
return;
case 'cp1y':
if (!this.assertType(nextValue, 'number', key)) return;
this.setControl1(this.cp1x, nextValue);
return;
case 'cp2x':
if (!this.assertType(nextValue, 'number', key)) return;
this.setControl2(nextValue, this.cp2y);
return;
case 'cp2y':
if (!this.assertType(nextValue, 'number', key)) return;
this.setControl2(this.cp2x, nextValue);
return;
case 'ex':
if (!this.assertType(nextValue, 'number', key)) return;
this.setEnd(nextValue, this.ey);
return;
case 'ey':
if (!this.assertType(nextValue, 'number', key)) return;
this.setEnd(this.ex, nextValue);
return;
} }
super.patchProp(key, prevValue, nextValue, namespace, parentComponent); super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
} }
@ -314,23 +636,42 @@ export class QuadraticCurve extends GraphicItemBase {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void {} ): void {
const ctx = canvas.ctx;
this.setCanvasState(canvas);
ctx.beginPath();
ctx.moveTo(this.sx, this.sy);
ctx.quadraticCurveTo(this.cpx, this.cpy, this.ex, this.ey);
ctx.stroke();
}
/** /**
* *
*/ */
setStart(x: number, y: number) {} setStart(x: number, y: number) {
this.sx = x;
this.sy = y;
this.update();
}
/** /**
* *
*/ */
setControl(x: number, y: number) {} setControl(x: number, y: number) {
this.cpx = x;
this.cpy = y;
this.update();
}
/** /**
* *
*/ */
setEnd(x: number, y: number) {} setEnd(x: number, y: number) {
this.ex = x;
this.ey = y;
this.update();
}
patchProp( patchProp(
key: string, key: string,
@ -340,6 +681,30 @@ export class QuadraticCurve extends GraphicItemBase {
parentComponent?: ComponentInternalInstance | null parentComponent?: ComponentInternalInstance | null
): void { ): void {
switch (key) { switch (key) {
case 'sx':
if (!this.assertType(nextValue, 'number', key)) return;
this.setStart(nextValue, this.sy);
return;
case 'sy':
if (!this.assertType(nextValue, 'number', key)) return;
this.setStart(this.sx, nextValue);
return;
case 'cpx':
if (!this.assertType(nextValue, 'number', key)) return;
this.setControl(nextValue, this.cpy);
return;
case 'cpy':
if (!this.assertType(nextValue, 'number', key)) return;
this.setControl(this.cpx, nextValue);
return;
case 'ex':
if (!this.assertType(nextValue, 'number', key)) return;
this.setEnd(nextValue, this.ey);
return;
case 'ey':
if (!this.assertType(nextValue, 'number', key)) return;
this.setEnd(this.ex, nextValue);
return;
} }
super.patchProp(key, prevValue, nextValue, namespace, parentComponent); super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
} }
@ -351,8 +716,27 @@ export class Path extends GraphicItemBase {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void {} ): void {
const ctx = canvas.ctx;
this.setCanvasState(canvas);
switch (this.mode) {
case GraphicMode.Fill:
ctx.fill(this.path, this.fillRule);
break;
case GraphicMode.Stroke:
ctx.stroke(this.path);
break;
case GraphicMode.FillAndStroke:
ctx.fill(this.path, this.fillRule);
ctx.stroke(this.path);
break;
case GraphicMode.StrokeAndFill:
ctx.stroke(this.path);
ctx.fill(this.path, this.fillRule);
break;
}
}
/** /**
* *
@ -365,7 +749,115 @@ export class Path extends GraphicItemBase {
* *
* @param path * @param path
*/ */
addPath(path: Path2D) {} addPath(path: Path2D) {
this.path.addPath(path);
this.update();
}
patchProp(
key: string,
prevValue: any,
nextValue: any,
namespace?: ElementNamespace,
parentComponent?: ComponentInternalInstance | null
): void {
switch (key) {
case 'path':
if (!this.assertType(nextValue, Path2D, key)) return;
this.path = nextValue;
this.update();
return;
}
super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
}
}
const enum RectRType {
/** 圆角为椭圆 */
Ellipse,
/** 圆角为二次贝塞尔曲线 */
Quad,
/** 圆角为三次贝塞尔曲线。该模式下,包含两个控制点,一个控制点位于上下矩形边延长线,另一个控制点位于左右矩形边延长线 */
Cubic,
/** 圆角为直线连接 */
Line
}
export class RectR extends GraphicItemBase {
/** 矩形路径 */
private path: Path2D;
/** 圆角类型 */
roundType: RectRType = RectRType.Ellipse;
/** 横向圆角半径 */
radiusX: number = 0;
/** 纵向圆角半径 */
radiusY: number = 0;
/**
* 线0线1
* 线线
*/
cpx: number = 0;
/**
* 线0线1
* 线线
*/
cpy: number = 0;
constructor(
type: RenderItemPosition,
cache: boolean = false,
fall: boolean = false
) {
super(type, cache, fall);
const path = new Path2D();
path.rect(this.x, this.y, this.width, this.height);
this.path = path;
}
/**
*
*/
private updatePath() {}
/**
*
* @param x
* @param y
*/
setRadius(x: number, y: number) {}
/**
* 线
* @param x cpx
* @param y cpy
*/
setControl(x: number, y: number) {}
protected render(
canvas: MotaOffscreenCanvas2D,
_transform: Transform
): void {
const ctx = canvas.ctx;
this.setCanvasState(canvas);
switch (this.mode) {
case GraphicMode.Fill:
ctx.fill(this.path, this.fillRule);
break;
case GraphicMode.Stroke:
ctx.stroke(this.path);
break;
case GraphicMode.FillAndStroke:
ctx.fill(this.path, this.fillRule);
ctx.stroke(this.path);
break;
case GraphicMode.StrokeAndFill:
ctx.stroke(this.path);
ctx.fill(this.path, this.fillRule);
break;
}
}
patchProp( patchProp(
key: string, key: string,

View File

@ -1,9 +1,17 @@
import { MotaOffscreenCanvas2D } from '@/core/fx/canvas2d'; import { MotaOffscreenCanvas2D } from '@/core/fx/canvas2d';
import { Sprite } from '../sprite'; import {
import { ERenderItemEvent, RenderItem, RenderItemPosition } from '../item'; ERenderItemEvent,
IAnimateFrame,
renderEmits,
RenderItem,
RenderItemPosition
} from '../item';
import { Transform } from '../transform'; import { Transform } from '../transform';
import { ElementNamespace, ComponentInternalInstance } from 'vue'; import { ElementNamespace, ComponentInternalInstance } from 'vue';
import { AutotileRenderable, RenderableData } from '../cache'; import { AutotileRenderable, RenderableData } from '../cache';
import { texture } from '../cache';
import { isNil } from 'lodash-es';
import { logger } from '@/core/common/logger';
type CanvasStyle = string | CanvasGradient | CanvasPattern; type CanvasStyle = string | CanvasGradient | CanvasPattern;
@ -33,7 +41,7 @@ export class Text extends RenderItem<ETextEvent> {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void { ): void {
const ctx = canvas.ctx; const ctx = canvas.ctx;
ctx.textBaseline = 'bottom'; ctx.textBaseline = 'bottom';
@ -162,7 +170,7 @@ export class Image extends RenderItem<EImageEvent> {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void { ): void {
const ctx = canvas.ctx; const ctx = canvas.ctx;
ctx.drawImage(this.image, 0, 0, canvas.width, canvas.height); ctx.drawImage(this.image, 0, 0, canvas.width, canvas.height);
@ -200,33 +208,108 @@ export class Comment extends RenderItem {
} }
protected render( protected render(
canvas: MotaOffscreenCanvas2D, _canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void {} ): void {}
} }
export interface EIconEvent extends ERenderItemEvent {} export interface EIconEvent extends ERenderItemEvent {}
export class Icon extends RenderItem<EIconEvent> { export class Icon extends RenderItem<EIconEvent> implements IAnimateFrame {
/** 图标id */ /** 图标id */
icon: AllNumbers = 0; icon: AllNumbers = 0;
/** 帧数 */ /** 帧数 */
frame: number = 0; frame?: number = 0;
/** 是否启用动画 */ /** 是否启用动画 */
animate: boolean = false; animate?: boolean = false;
/** 图标的渲染信息 */ /** 图标的渲染信息 */
private renderable?: RenderableData | AutotileRenderable; private renderable?: RenderableData | AutotileRenderable;
private pendingIcon?: AllNumbers;
constructor(type: RenderItemPosition, cache?: boolean, fall?: boolean) {
super(type, cache, fall);
this.setAntiAliasing(false);
this.setHD(false);
}
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void {} ): void {
const ctx = canvas.ctx;
const renderable = this.renderable;
if (!renderable) return;
const [x, y, w, h] = renderable.render[0];
const cw = canvas.width;
const ch = canvas.height;
const frame = this.animate
? RenderItem.animatedFrame % renderable.frame
: 0;
if (!this.animate) {
if (renderable.autotile) {
ctx.drawImage(renderable.image[0], x, y, w, h, 0, 0, cw, ch);
} else {
ctx.drawImage(renderable.image, x, y, w, h, 0, 0, cw, ch);
}
} else {
const [x1, y1, w1, h1] = renderable.render[frame];
if (renderable.autotile) {
const img = renderable.image[0];
ctx.drawImage(img, x1, y1, w1, h1, 0, 0, cw, ch);
} else {
ctx.drawImage(renderable.image, x1, y1, w1, h1, 0, 0, cw, ch);
}
}
}
/** /**
* *
* @param id id * @param id id
*/ */
setIcon(id: AllIds | AllNumbers) {} setIcon(id: AllIds | AllNumbers) {
const num = typeof id === 'number' ? id : texture.idNumberMap[id];
const loading = Mota.require('var', 'loading');
if (loading.loaded) {
this.setIconRenderable(num);
} else {
if (isNil(this.pendingIcon)) {
loading.once('loaded', () => {
this.setIconRenderable(this.pendingIcon ?? 0);
delete this.pendingIcon;
});
}
this.pendingIcon = num;
}
}
private setIconRenderable(num: AllNumbers) {
const renderable = texture.getRenderable(num);
if (!renderable) {
logger.warn(43, num.toString());
return;
} else {
this.icon = num;
this.renderable = renderable;
this.frame = renderable.frame;
}
this.update();
}
/**
*
*/
updateFrameAnimate(): void {
this.update(this);
}
destroy(): void {
renderEmits.removeFramer(this);
super.destroy();
}
patchProp( patchProp(
key: string, key: string,
@ -242,10 +325,14 @@ export class Icon extends RenderItem<EIconEvent> {
case 'animate': case 'animate':
if (!this.assertType(nextValue, 'boolean', key)) return; if (!this.assertType(nextValue, 'boolean', key)) return;
this.animate = nextValue; this.animate = nextValue;
if (nextValue) renderEmits.addFramer(this);
else renderEmits.removeFramer(this);
this.update();
return; return;
case 'frame': case 'frame':
if (!this.assertType(nextValue, 'number', key)) return; if (!this.assertType(nextValue, 'number', key)) return;
this.frame = nextValue; this.frame = nextValue;
this.update();
return; return;
} }
super.patchProp(key, prevValue, nextValue, namespace, parentComponent); super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
@ -259,6 +346,8 @@ export class Winskin extends RenderItem<EWinskinEvent> {
/** 边框宽度 */ /** 边框宽度 */
borderSize: number = 32; borderSize: number = 32;
private pendingImage?: ImageIds;
constructor( constructor(
image: SizedCanvasImageSource, image: SizedCanvasImageSource,
type: RenderItemPosition = 'static' type: RenderItemPosition = 'static'
@ -269,20 +358,188 @@ export class Winskin extends RenderItem<EWinskinEvent> {
protected render( protected render(
canvas: MotaOffscreenCanvas2D, canvas: MotaOffscreenCanvas2D,
transform: Transform _transform: Transform
): void {} ): void {
const ctx = canvas.ctx;
const img = this.image;
const x = 0;
const y = 0;
const w = canvas.width;
const h = canvas.height;
const sz = this.borderSize / 32;
ctx.drawImage(img, 128, 0, 16, 16, x, y, 16 * sz, 16 * sz);
let dx;
for (dx = 0; dx < w - 64 * sz; dx += 32 * sz) {
ctx.drawImage(
img,
144,
0,
32,
16,
x + dx + 16,
y,
32 * sz,
16 * sz
);
ctx.drawImage(
img,
144,
48,
32,
16,
x + dx + 16,
y + h - 16 * sz,
32 * sz,
16 * sz
);
}
ctx.drawImage(
img,
144,
0,
w - dx - 32,
16,
x + dx + 16 * sz,
y,
w - dx - 32 * sz,
16 * sz
);
ctx.drawImage(
img,
144,
48,
w - dx - 32,
16,
x + dx + 16 * sz,
y + h - 16 * sz,
w - dx - 32 * sz,
16 * sz
);
ctx.drawImage(
img,
176,
0,
16,
16,
x + w - 16 * sz,
y,
16 * sz,
16 * sz
);
// 左右
let dy;
for (dy = 0; dy < h - 64 * sz; dy += 32 * sz) {
ctx.drawImage(
img,
128,
16,
16,
32,
x,
y + dy + 16 * sz,
16 * sz,
32 * sz
);
ctx.drawImage(
img,
176,
16,
16,
32,
x + w - 16 * sz,
y + dy + 16 * sz,
16 * sz,
32 * sz
);
}
ctx.drawImage(
img,
128,
16,
16,
h - dy - 32,
x,
y + dy + 16 * sz,
16 * sz,
h - dy - 32 * sz
);
ctx.drawImage(
img,
176,
16,
16,
h - dy - 32,
x + w - 16 * sz,
y + dy + 16 * sz,
16 * sz,
h - dy - 32 * sz
);
// 下方
ctx.drawImage(
img,
128,
48,
16,
16,
x,
y + h - 16 * sz,
16 * sz,
16 * sz
);
ctx.drawImage(
img,
176,
48,
16,
16,
x + w - 16 * sz,
y + h - 16 * sz,
16 * sz,
16 * sz
);
this.update();
}
/** /**
* winskin图片 * winskin图片
* @param image winskin图片 * @param image winskin图片
*/ */
setImage(image: SizedCanvasImageSource) {} setImage(image: SizedCanvasImageSource) {
this.image = image;
this.update();
}
/**
* winskin
* @param name
*/
setImageByName(name: ImageIds) {
const loading = Mota.require('var', 'loading');
if (loading.loaded) {
const image = core.material.images.images[name];
this.setImage(image);
} else {
if (isNil(this.pendingImage)) {
loading.once('loaded', () => {
const id = this.pendingImage;
if (!id) return;
const image = core.material.images.images[id];
this.setImage(image);
delete this.pendingImage;
});
}
this.pendingImage = name;
}
}
/** /**
* *
* @param size * @param size
*/ */
setBorderSize(size: number) {} setBorderSize(size: number) {
this.borderSize = size;
this.update();
}
patchProp( patchProp(
key: string, key: string,
@ -292,6 +549,14 @@ export class Winskin extends RenderItem<EWinskinEvent> {
parentComponent?: ComponentInternalInstance | null parentComponent?: ComponentInternalInstance | null
): void { ): void {
switch (key) { switch (key) {
case 'image':
if (!this.assertType(nextValue, 'string', key)) return;
this.setImageByName(nextValue);
return;
case 'borderSize':
if (!this.assertType(nextValue, 'number', key)) return;
this.setBorderSize(nextValue);
return;
} }
super.patchProp(key, prevValue, nextValue, namespace, parentComponent); super.patchProp(key, prevValue, nextValue, namespace, parentComponent);
} }

View File

@ -26,6 +26,7 @@ import {
PathProps, PathProps,
QuadraticProps, QuadraticProps,
RectProps, RectProps,
RectRProps,
ShaderProps, ShaderProps,
SpriteProps, SpriteProps,
TextProps, TextProps,
@ -101,6 +102,7 @@ declare module 'vue/jsx-runtime' {
'g-bezier': TagDefine<BezierProps, EGraphicItemEvent>; 'g-bezier': TagDefine<BezierProps, EGraphicItemEvent>;
'g-quad': TagDefine<QuadraticProps, EGraphicItemEvent>; 'g-quad': TagDefine<QuadraticProps, EGraphicItemEvent>;
'g-path': TagDefine<PathProps, EGraphicItemEvent>; 'g-path': TagDefine<PathProps, EGraphicItemEvent>;
'g-rectr': TagDefine<RectRProps, EGraphicItemEvent>;
icon: TagDefine<IconProps, EIconEvent>; icon: TagDefine<IconProps, EIconEvent>;
winskin: TagDefine<WinskinProps, EWinskinEvent>; winskin: TagDefine<WinskinProps, EWinskinEvent>;
} }

View File

@ -21,9 +21,9 @@ import {
Line, Line,
Path, Path,
QuadraticCurve, QuadraticCurve,
Rect Rect,
RectR
} from '../preset/graphics'; } from '../preset/graphics';
import { BaseProps } from './props';
type OnItemCreate< type OnItemCreate<
E extends ERenderItemEvent = ERenderItemEvent, E extends ERenderItemEvent = ERenderItemEvent,
@ -217,10 +217,10 @@ tagMap.register('layer-group', (_0, _1, props) => {
return l; return l;
} }
}); });
tagMap.register<EDamageEvent, Damage>('damage', (_0, _1, props) => { tagMap.register<EDamageEvent, Damage>('damage', (_0, _1, _props) => {
return new Damage(); return new Damage();
}); });
tagMap.register('animation', (_0, _1, props) => { tagMap.register('animation', (_0, _1, _props) => {
return new Animate(); return new Animate();
}); });
tagMap.register('g-rect', se(Rect, 'absolute', ElementState.None)); tagMap.register('g-rect', se(Rect, 'absolute', ElementState.None));
@ -230,6 +230,7 @@ tagMap.register('g-line', se(Line, 'absolute', ElementState.None));
tagMap.register('g-bezier', se(BezierCurve, 'absolute', ElementState.None)); tagMap.register('g-bezier', se(BezierCurve, 'absolute', ElementState.None));
tagMap.register('g-quad', se(QuadraticCurve, 'absolute', ElementState.None)); tagMap.register('g-quad', se(QuadraticCurve, 'absolute', ElementState.None));
tagMap.register('g-path', se(Path, 'absolute', ElementState.None)); tagMap.register('g-path', se(Path, 'absolute', ElementState.None));
tagMap.register('g-rectr', se(RectR, 'absolute', ElementState.None));
tagMap.register('icon', standardElementNoCache(Icon)); tagMap.register('icon', standardElementNoCache(Icon));
tagMap.register('winskin', (_0, _1, props) => { tagMap.register('winskin', (_0, _1, props) => {
if (!props) return new Winskin(core.material.images.images['winskin.png']); if (!props) return new Winskin(core.material.images.images['winskin.png']);

View File

@ -7,6 +7,7 @@ import {
} from '../preset/layer'; } from '../preset/layer';
import type { EnemyCollection } from '@/game/enemy/damage'; import type { EnemyCollection } from '@/game/enemy/damage';
import { ILineProperty } from '../preset/graphics'; import { ILineProperty } from '../preset/graphics';
import { SizedCanvasImageSource } from '../preset';
export interface CustomProps { export interface CustomProps {
_item: (props: BaseProps) => RenderItem; _item: (props: BaseProps) => RenderItem;
@ -108,18 +109,80 @@ export interface GraphicPropsBase extends BaseProps, Partial<ILineProperty> {
export interface RectProps extends GraphicPropsBase {} export interface RectProps extends GraphicPropsBase {}
export interface CirclesProps extends GraphicPropsBase {} export interface CirclesProps extends GraphicPropsBase {
radius?: number;
start?: number;
end?: number;
}
export interface EllipseProps extends GraphicPropsBase {} export interface EllipseProps extends GraphicPropsBase {
radiusX?: number;
radiusY?: number;
start?: number;
end?: number;
}
export interface LineProps extends GraphicPropsBase {} export interface LineProps extends GraphicPropsBase {
x1?: number;
y1?: number;
x2?: number;
y2?: number;
}
export interface BezierProps extends GraphicPropsBase {} export interface BezierProps extends GraphicPropsBase {
sx?: number;
sy?: number;
cp1x?: number;
cp1y?: number;
cp2x?: number;
cp2y?: number;
ex?: number;
ey?: number;
}
export interface QuadraticProps extends GraphicPropsBase {} export interface QuadraticProps extends GraphicPropsBase {
sx?: number;
sy?: number;
cpx?: number;
cpy?: number;
ex?: number;
ey?: number;
}
export interface PathProps extends GraphicPropsBase {} export interface PathProps extends GraphicPropsBase {
path?: Path2D;
}
export interface IconProps extends BaseProps {} export interface RectRProps extends GraphicPropsBase {
/** 圆角半径此参数传入时radiusX 和 radiusY 应保持一致 */
radius: number;
/** 圆角横向半径 */
radiusX?: number;
/** 圆角纵向半径 */
radiusY?: number;
/** 圆角为线模式 */
line?: boolean;
/** 圆角为椭圆模式,默认值 */
ellipse?: boolean;
/** 圆角为二次贝塞尔曲线模式 */
quad?: boolean;
/** 圆角为三次贝塞尔曲线模式 */
cubic?: boolean;
/** 控制点此参数传入时cpx 和 cpy 应保持一致 */
cp?: number;
/** 横向控制点 */
cpx?: number;
/** 纵向控制点 */
cpy?: number;
}
export interface WinskinProps extends BaseProps {} export interface IconProps extends BaseProps {
icon: AllNumbers;
frame?: number;
animate?: boolean;
}
export interface WinskinProps extends BaseProps {
image: ImageIds;
borderSize?: number;
}

View File

@ -70,6 +70,7 @@
"40": "Cannot return canvas that is not provided by this pool.", "40": "Cannot return canvas that is not provided by this pool.",
"41": "Width of text content components must be positive. receive: $1", "41": "Width of text content components must be positive. receive: $1",
"42": "Repeated Textbox id: '$1'.", "42": "Repeated Textbox id: '$1'.",
"43": "Cannot set icon of '$1', since it does not exists. Please ensure you have delivered correct icon id or number.",
"1001": "Item-detail extension needs 'floor-binder' and 'floor-damage' extension as dependency.", "1001": "Item-detail extension needs 'floor-binder' and 'floor-damage' extension as dependency.",
"1101": "Cannot add new effect to point effect instance, for there's no more reserve space for it. Please increase the max count of the instance." "1101": "Cannot add new effect to point effect instance, for there's no more reserve space for it. Please increase the max count of the instance."
} }

View File

@ -13,12 +13,16 @@ class GameLoading extends EventEmitter<GameLoadEvent> {
private autotileLoaded: number = 0; private autotileLoaded: number = 0;
private autotileNum?: number; private autotileNum?: number;
private autotileListened: boolean = false; private autotileListened: boolean = false;
loaded: boolean = false;
constructor() { constructor() {
super(); super();
this.on('coreInit', () => { this.once('coreInit', () => {
this.autotileNum = Object.keys(core.material.icons.autotile).length; this.autotileNum = Object.keys(core.material.icons.autotile).length;
}); });
this.once('loaded', () => {
this.loaded = true;
});
} }
addAutotileLoaded() { addAutotileLoaded() {