HumanBreak/public/main.js

934 lines
30 KiB
JavaScript
Raw Normal View History

2022-11-14 17:11:23 +08:00
function main() {
2022-11-13 18:02:05 +08:00
//------------------------ 用户修改内容 ------------------------//
2022-11-14 17:11:23 +08:00
this.version = '2.10.0'; // 游戏版本号如果更改了游戏内容建议修改此version以免造成缓存问题。
2022-11-13 18:02:05 +08:00
this.useCompress = false; // 是否使用压缩文件
// 当你即将发布你的塔时请使用“JS代码压缩工具”将所有js代码进行压缩然后将这里的useCompress改为true。
// 请注意只有useCompress是false时才会读取floors目录下的文件为true时会直接读取libs目录下的floors.min.js文件。
// 如果要进行剧本的修改请务必将其改成false。
this.bgmRemote = false; // 是否采用远程BGM
2022-11-14 17:11:23 +08:00
this.bgmRemoteRoot = 'https://h5mota.com/music/'; // 远程BGM的根目录
2022-11-13 18:02:05 +08:00
this.isCompetition = false; // 是否是比赛模式
this.savePages = 1000; // 存档页数每页可存5个默认为1000页5000个存档
this.criticalUseLoop = 1; // 循环临界的分界
//------------------------ 用户修改内容 END ------------------------//
this.dom = {
2022-11-14 17:11:23 +08:00
body: document.body,
gameGroup: document.getElementById('gameGroup'),
mainTips: document.getElementById('mainTips'),
musicBtn: document.getElementById('musicBtn'),
enlargeBtn: document.createElement('img'),
startPanel: document.getElementById('startPanel'),
startTop: document.getElementById('startTop'),
startTopProgressBar: document.getElementById('startTopProgressBar'),
startTopProgress: document.getElementById('startTopProgress'),
startTopLoadTips: document.getElementById('startTopLoadTips'),
floorMsgGroup: document.getElementById('floorMsgGroup'),
logoLabel: document.getElementById('logoLabel'),
versionLabel: document.getElementById('versionLabel'),
floorNameLabel: document.getElementById('floorNameLabel'),
statusBar: document.getElementById('statusBar'),
status: document.getElementsByClassName('status'),
toolBar: document.getElementById('toolBar'),
tools: document.getElementsByClassName('tools'),
gameCanvas: document.getElementsByClassName('gameCanvas'),
gif: document.getElementById('gif'),
gif2: document.getElementById('gif2'),
gameDraw: document.getElementById('gameDraw'),
startButtons: document.getElementById('startButtons'),
playGame: document.getElementById('playGame'),
loadGame: document.getElementById('loadGame'),
replayGame: document.getElementById('replayGame'),
levelChooseButtons: document.getElementById('levelChooseButtons'),
data: document.getElementById('data'),
statusLabels: document.getElementsByClassName('statusLabel'),
statusTexts: document.getElementsByClassName('statusText'),
floorCol: document.getElementById('floorCol'),
nameCol: document.getElementById('nameCol'),
lvCol: document.getElementById('lvCol'),
hpmaxCol: document.getElementById('hpmaxCol'),
hpCol: document.getElementById('hpCol'),
manaCol: document.getElementById('manaCol'),
atkCol: document.getElementById('atkCol'),
defCol: document.getElementById('defCol'),
mdefCol: document.getElementById('mdefCol'),
moneyCol: document.getElementById('moneyCol'),
expCol: document.getElementById('expCol'),
upCol: document.getElementById('upCol'),
keyCol: document.getElementById('keyCol'),
pzfCol: document.getElementById('pzfCol'),
debuffCol: document.getElementById('debuffCol'),
skillCol: document.getElementById('skillCol'),
hard: document.getElementById('hard'),
statusCanvas: document.getElementById('statusCanvas'),
statusCanvasCtx: document
.getElementById('statusCanvas')
.getContext('2d'),
inputDiv: document.getElementById('inputDiv'),
inputMessage: document.getElementById('inputMessage'),
inputBox: document.getElementById('inputBox'),
inputYes: document.getElementById('inputYes'),
inputNo: document.getElementById('inputNo'),
next: document.getElementById('next')
2022-11-13 18:02:05 +08:00
};
this.mode = 'play';
this.loadList = [
2022-11-14 17:11:23 +08:00
'loader',
'control',
'utils',
'items',
'icons',
'maps',
'enemys',
'events',
'actions',
'data',
'ui',
'extensions',
'core'
2022-11-13 18:02:05 +08:00
];
this.pureData = [
2022-11-14 17:11:23 +08:00
'data',
'enemys',
'icons',
'maps',
'items',
'functions',
'events',
'plugins'
2022-11-13 18:02:05 +08:00
];
this.materials = [
2022-11-14 17:11:23 +08:00
'animates',
'enemys',
'items',
'npcs',
'terrains',
'enemy48',
'npc48',
'icons'
2022-11-13 18:02:05 +08:00
];
this.statusBar = {
2022-11-14 17:11:23 +08:00
image: {
floor: document.getElementById('img-floor'),
name: document.getElementById('img-name'),
lv: document.getElementById('img-lv'),
hpmax: document.getElementById('img-hpmax'),
hp: document.getElementById('img-hp'),
mana: document.getElementById('img-mana'),
atk: document.getElementById('img-atk'),
def: document.getElementById('img-def'),
mdef: document.getElementById('img-mdef'),
money: document.getElementById('img-money'),
exp: document.getElementById('img-exp'),
up: document.getElementById('img-up'),
skill: document.getElementById('img-skill'),
book: document.getElementById('img-book'),
fly: document.getElementById('img-fly'),
toolbox: document.getElementById('img-toolbox'),
keyboard: document.getElementById('img-keyboard'),
shop: document.getElementById('img-shop'),
save: document.getElementById('img-save'),
load: document.getElementById('img-load'),
settings: document.getElementById('img-settings'),
btn1: document.getElementById('img-btn1'),
btn2: document.getElementById('img-btn2'),
btn3: document.getElementById('img-btn3'),
btn4: document.getElementById('img-btn4'),
btn5: document.getElementById('img-btn5'),
btn6: document.getElementById('img-btn6'),
btn7: document.getElementById('img-btn7'),
btn8: document.getElementById('img-btn8')
2022-11-13 18:02:05 +08:00
},
2022-11-14 17:11:23 +08:00
icons: {
floor: 0,
name: null,
lv: 1,
hpmax: 2,
hp: 3,
atk: 4,
def: 5,
mdef: 6,
money: 7,
exp: 8,
up: 9,
book: 10,
fly: 11,
toolbox: 12,
keyboard: 13,
shop: 14,
save: 15,
load: 16,
settings: 17,
play: 18,
pause: 19,
stop: 20,
speedDown: 21,
speedUp: 22,
rewind: 23,
equipbox: 24,
mana: 25,
skill: 26,
btn1: 27,
btn2: 28,
btn3: 29,
btn4: 30,
btn5: 31,
btn6: 32,
btn7: 33,
btn8: 34
2022-11-13 18:02:05 +08:00
},
2022-11-14 17:11:23 +08:00
floor: document.getElementById('floor'),
name: document.getElementById('name'),
lv: document.getElementById('lv'),
hpmax: document.getElementById('hpmax'),
hp: document.getElementById('hp'),
mana: document.getElementById('mana'),
atk: document.getElementById('atk'),
def: document.getElementById('def'),
mdef: document.getElementById('mdef'),
money: document.getElementById('money'),
exp: document.getElementById('exp'),
up: document.getElementById('up'),
skill: document.getElementById('skill'),
yellowKey: document.getElementById('yellowKey'),
blueKey: document.getElementById('blueKey'),
redKey: document.getElementById('redKey'),
greenKey: document.getElementById('greenKey'),
poison: document.getElementById('poison'),
weak: document.getElementById('weak'),
curse: document.getElementById('curse'),
pickaxe: document.getElementById('pickaxe'),
bomb: document.getElementById('bomb'),
fly: document.getElementById('fly'),
hard: document.getElementById('hard')
};
this.floors = {};
2022-11-13 18:02:05 +08:00
this.canvas = {};
2022-11-14 17:11:23 +08:00
this.__VERSION__ = '2.10.0';
2022-11-13 18:02:05 +08:00
this.__VERSION_CODE__ = 510;
}
main.prototype.init = function (mode, callback) {
2023-01-11 09:45:18 +08:00
try {
var a = {};
var b = {};
new Proxy(a, b);
2023-02-22 21:39:44 +08:00
const aa = `${123}`;
aa;
2023-01-11 09:45:18 +08:00
} catch (e) {
alert('浏览器版本过低,无法游玩本塔!');
return;
}
2022-11-13 18:02:05 +08:00
for (var i = 0; i < main.dom.gameCanvas.length; i++) {
2022-11-14 17:11:23 +08:00
main.canvas[main.dom.gameCanvas[i].id] =
main.dom.gameCanvas[i].getContext('2d');
2022-11-13 18:02:05 +08:00
}
main.mode = mode;
main.loadJs('project', main.pureData, function () {
var mainData = data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d.main;
for (var ii in mainData) main[ii] = mainData[ii];
2023-02-20 20:34:42 +08:00
// main.levelChoose = main.levelChoose || [];
// main.levelChoose.forEach(function (value) {
// var span = document.createElement('span');
// span.setAttribute('class', 'startButton');
// span.innerText = value.title || '';
// span.id = value.name;
// (function (span, str_) {
// span.onclick = function () {
// core.events.startGame(str_);
// };
// })(span, value.name || '');
// main.dom.levelChooseButtons.appendChild(span);
// });
2022-11-13 18:02:05 +08:00
main.importFonts(main.fonts);
main.loadJs('libs', main.loadList, function () {
main.core = core;
for (i = 0; i < main.loadList.length; i++) {
var name = main.loadList[i];
if (name === 'core') continue;
main.core[name] = new window[name]();
}
main.loadFloors(function () {
var coreData = {};
2022-11-14 17:11:23 +08:00
[
'dom',
'statusBar',
'canvas',
'images',
'tilesets',
'materials',
'animates',
'bgms',
'sounds',
'floorIds',
'floors',
'floorPartitions'
].forEach(function (t) {
coreData[t] = main[t];
});
2023-02-22 21:39:44 +08:00
core.init(coreData, callback);
core.resize();
2022-11-13 18:02:05 +08:00
// 自动放缩最大化
2022-12-30 15:38:21 +08:00
if (core.getLocalStorage('autoScale') == null) {
2023-01-04 16:23:26 +08:00
core.setLocalStorage('autoScale', true);
2022-12-30 15:38:21 +08:00
}
2022-11-14 17:11:23 +08:00
if (
core.getLocalStorage('autoScale') &&
!core.domStyle.isVertical
) {
2022-11-13 18:02:05 +08:00
try {
2023-02-22 21:39:44 +08:00
if (core) {
core.plugin.maxGameScale();
if (!core.getLocalStorage('fullscreen', false)) {
requestAnimationFrame(function () {
var style = getComputedStyle(
main.dom.gameGroup
);
var height = parseFloat(style.height);
if (height > window.innerHeight * 0.95) {
core.control.setDisplayScale(-1);
if (
!core.isPlaying() &&
core.flags.enableHDCanvas
) {
core.domStyle.ratio = Math.max(
window.devicePixelRatio || 1,
core.domStyle.scale
);
core.resize();
}
2022-12-30 15:38:21 +08:00
}
2023-02-22 21:39:44 +08:00
});
}
2022-11-13 18:02:05 +08:00
}
2022-11-14 17:11:23 +08:00
} catch (e) {
console.error(e);
}
2022-11-13 18:02:05 +08:00
}
});
});
});
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 动态加载所有核心JS文件 //////
main.prototype.loadJs = function (dir, loadList, callback) {
// 加载js
2022-11-14 17:11:23 +08:00
main.setMainTipsText('正在加载核心js文件...');
2022-11-13 18:02:05 +08:00
if (this.useCompress) {
main.loadMod(dir, dir, function () {
callback();
2022-11-14 17:11:23 +08:00
});
} else {
2022-11-13 18:02:05 +08:00
var instanceNum = 0;
for (var i = 0; i < loadList.length; i++) {
main.loadMod(dir, loadList[i], function (modName) {
main.setMainTipsText(modName + '.js 加载完毕');
instanceNum++;
if (instanceNum === loadList.length) {
callback();
}
});
}
}
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 加载某一个JS文件 //////
main.prototype.loadMod = function (dir, modName, callback, onerror) {
var script = document.createElement('script');
var name = modName;
2022-11-14 17:11:23 +08:00
script.src =
dir +
'/' +
modName +
(this.useCompress ? '.min' : '') +
'.js?v=' +
this.version;
2022-11-13 18:02:05 +08:00
script.onload = function () {
callback(name);
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
main.dom.body.appendChild(script);
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 动态加载所有楼层(剧本) //////
main.prototype.loadFloors = function (callback) {
// 加载js
2022-11-14 17:11:23 +08:00
main.setMainTipsText('正在加载楼层文件...');
if (this.useCompress) {
// 读取压缩文件
2022-11-13 18:02:05 +08:00
var script = document.createElement('script');
script.src = 'project/floors.min.js?v=' + this.version;
main.dom.body.appendChild(script);
script.onload = function () {
main.dom.mainTips.style.display = 'none';
callback();
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
return;
}
// 高层塔优化
var script = document.createElement('script');
2022-11-14 17:11:23 +08:00
script.src =
2022-11-16 23:01:23 +08:00
'/all/__all_floors__.js?v=' +
2022-11-14 17:11:23 +08:00
this.version +
'&id=' +
main.floorIds.join(',');
2022-11-13 18:02:05 +08:00
script.onload = function () {
main.dom.mainTips.style.display = 'none';
main.supportBunch = true;
callback();
2022-11-14 17:11:23 +08:00
};
script.onerror =
script.onabort =
script.ontimeout =
function (e) {
// console.clear();
for (var i = 0; i < main.floorIds.length; i++) {
main.loadFloor(main.floorIds[i], function (modName) {
main.setMainTipsText(
'楼层 ' + modName + '.js 加载完毕'
);
if (
Object.keys(main.floors).length ===
main.floorIds.length
) {
main.dom.mainTips.style.display = 'none';
callback();
}
});
2022-11-13 18:02:05 +08:00
}
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
main.dom.body.appendChild(script);
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 加载某一个楼层 //////
main.prototype.loadFloor = function (floorId, callback) {
var script = document.createElement('script');
script.src = 'project/floors/' + floorId + '.js?v=' + this.version;
main.dom.body.appendChild(script);
script.onload = function () {
callback(floorId);
2022-11-14 17:11:23 +08:00
};
};
2022-11-13 18:02:05 +08:00
////// 加载过程提示 //////
main.prototype.setMainTipsText = function (text) {
main.dom.mainTips.innerHTML = text;
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
main.prototype.log = function (e, error) {
if (e) {
if (error) return console.error(e);
if (main.core && main.core.platform && !main.core.platform.isPC) {
2022-11-14 17:11:23 +08:00
console.log(e.stack || e.toString());
} else {
2022-11-13 18:02:05 +08:00
console.log(e);
}
}
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
main.prototype.createOnChoiceAnimation = function () {
2022-11-14 17:11:23 +08:00
var borderColor =
main.dom.startButtonGroup.style.caretColor || 'rgb(255, 215, 0)';
2022-11-13 18:02:05 +08:00
// get rgb value
2022-11-14 17:11:23 +08:00
var rgb =
/^rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)\s*(,\s*\d+\s*)?\)$/.exec(
borderColor
);
2022-11-13 18:02:05 +08:00
if (rgb != null) {
2022-11-14 17:11:23 +08:00
var value = rgb[1] + ', ' + rgb[2] + ', ' + rgb[3];
var style = document.createElement('style');
2022-11-13 18:02:05 +08:00
style.type = 'text/css';
2022-11-14 17:11:23 +08:00
var keyFrames =
'onChoice { ' +
'0% { border-color: rgba(' +
value +
', 0.9); } ' +
'50% { border-color: rgba(' +
value +
', 0.3); } ' +
'100% { border-color: rgba(' +
value +
', 0.9); } ' +
'}';
style.innerHTML =
'@-webkit-keyframes ' + keyFrames + ' @keyframes ' + keyFrames;
2022-11-13 18:02:05 +08:00
document.body.appendChild(style);
}
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 创建字体 //////
main.prototype.importFonts = function (fonts) {
if (!(fonts instanceof Array) || fonts.length == 0) return;
var style = document.createElement('style');
style.type = 'text/css';
var html = '';
fonts.forEach(function (font) {
2022-11-14 17:11:23 +08:00
html +=
'@font-face { font-family: "' +
font +
'"; src: url("project/fonts/' +
font +
'.ttf") format("truetype"); }';
2022-11-13 18:02:05 +08:00
});
style.innerHTML = html;
document.body.appendChild(style);
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
main.prototype.listen = function () {
////// 窗口大小变化时 //////
window.onresize = function () {
try {
main.core.resize();
2022-11-14 17:11:23 +08:00
} catch (ee) {
console.error(ee);
}
};
2022-11-13 18:02:05 +08:00
////// 在界面上按下某按键时 //////
main.dom.body.onkeydown = function (e) {
if (main.editorOpened) return;
try {
if (main.dom.inputDiv.style.display == 'block') return;
2022-11-14 17:11:23 +08:00
if (
main.core &&
(main.core.isPlaying() || main.core.status.lockControl)
)
2022-11-13 18:02:05 +08:00
main.core.onkeyDown(e);
2022-11-14 17:11:23 +08:00
} catch (ee) {
console.error(ee);
}
};
2022-11-13 18:02:05 +08:00
////// 在界面上放开某按键时 //////
main.dom.body.onkeyup = function (e) {
if (main.editorOpened) return;
try {
2022-11-14 17:11:23 +08:00
if (
main.dom.startPanel.style.display == 'block' &&
(main.dom.startButtons.style.display == 'block' ||
main.dom.levelChooseButtons.style.display == 'block')
) {
if (e.keyCode == 38 || e.keyCode == 33)
// up/pgup
2022-11-13 18:02:05 +08:00
main.selectButton((main.selectedButton || 0) - 1);
2022-11-14 17:11:23 +08:00
else if (e.keyCode == 40 || e.keyCode == 34)
// down/pgdn
2022-11-13 18:02:05 +08:00
main.selectButton((main.selectedButton || 0) + 1);
2022-11-14 17:11:23 +08:00
else if (e.keyCode == 67 || e.keyCode == 13 || e.keyCode == 32)
// C/Enter/Space
2022-11-13 18:02:05 +08:00
main.selectButton(main.selectedButton);
2022-11-14 17:11:23 +08:00
else if (
e.keyCode == 27 &&
main.dom.levelChooseButtons.style.display == 'block'
) {
// ESC
2022-11-13 18:02:05 +08:00
main.core.showStartAnimate(true);
}
e.stopPropagation();
return;
}
if (main.dom.inputDiv.style.display == 'block') {
if (e.keyCode == 13) {
setTimeout(function () {
main.dom.inputYes.click();
}, 50);
2022-11-14 17:11:23 +08:00
} else if (e.keyCode == 27) {
2022-11-13 18:02:05 +08:00
setTimeout(function () {
main.dom.inputNo.click();
}, 50);
}
return;
}
2022-11-14 17:11:23 +08:00
if (
main.core &&
main.core.isPlaying &&
main.core.status &&
(main.core.isPlaying() || main.core.status.lockControl)
)
2022-11-13 18:02:05 +08:00
main.core.onkeyUp(e);
2022-11-14 17:11:23 +08:00
} catch (ee) {
console.error(ee);
}
2022-11-13 18:02:05 +08:00
};
////// 开始选择时 //////
main.dom.body.onselectstart = function () {
return false;
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 鼠标按下时 //////
main.dom.data.onmousedown = function (e) {
try {
e.stopPropagation();
var loc = main.core.actions._getClickLoc(e.clientX, e.clientY);
if (loc == null) return;
main.core.ondown(loc);
2022-11-14 17:11:23 +08:00
} catch (ee) {
console.error(ee);
}
};
2022-11-13 18:02:05 +08:00
////// 鼠标移动时 //////
main.dom.data.onmousemove = function (e) {
try {
var loc = main.core.actions._getClickLoc(e.clientX, e.clientY);
if (loc == null) return;
main.core.onmove(loc);
2022-11-14 17:11:23 +08:00
} catch (ee) {
console.error(ee);
}
};
2022-11-13 18:02:05 +08:00
////// 鼠标放开时 //////
main.dom.data.onmouseup = function (e) {
try {
var loc = main.core.actions._getClickLoc(e.clientX, e.clientY);
if (loc == null) return;
main.core.onup(loc);
2022-11-14 17:11:23 +08:00
} catch (ee) {
console.error(ee);
}
};
2022-11-13 18:02:05 +08:00
////// 鼠标滑轮滚动时 //////
main.dom.data.onmousewheel = function (e) {
try {
2022-11-14 17:11:23 +08:00
if (e.wheelDelta) main.core.onmousewheel(Math.sign(e.wheelDelta));
else if (e.detail) main.core.onmousewheel(Math.sign(e.detail));
} catch (ee) {
console.error(ee);
}
};
2022-11-13 18:02:05 +08:00
////// 手指在触摸屏开始触摸时 //////
main.dom.data.ontouchstart = function (e) {
try {
e.preventDefault();
2022-11-14 17:11:23 +08:00
var loc = main.core.actions._getClickLoc(
e.targetTouches[0].clientX,
e.targetTouches[0].clientY
);
2022-11-13 18:02:05 +08:00
if (loc == null) return;
main.lastTouchLoc = loc;
main.core.ondown(loc);
2022-11-14 17:11:23 +08:00
} catch (ee) {
console.error(ee);
}
};
2022-11-13 18:02:05 +08:00
////// 手指在触摸屏上移动时 //////
main.dom.data.ontouchmove = function (e) {
try {
e.preventDefault();
2022-11-14 17:11:23 +08:00
var loc = main.core.actions._getClickLoc(
e.targetTouches[0].clientX,
e.targetTouches[0].clientY
);
2022-11-13 18:02:05 +08:00
if (loc == null) return;
main.lastTouchLoc = loc;
main.core.onmove(loc);
2022-11-14 17:11:23 +08:00
} catch (ee) {
console.error(ee);
}
};
2022-11-13 18:02:05 +08:00
////// 手指离开触摸屏时 //////
main.dom.data.ontouchend = function (e) {
try {
e.preventDefault();
if (main.lastTouchLoc == null) return;
var loc = main.lastTouchLoc;
delete main.lastTouchLoc;
main.core.onup(loc);
} catch (e) {
console.error(e);
}
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 点击状态栏中的怪物手册时 //////
main.statusBar.image.book.onclick = function (e) {
e.stopPropagation();
if (core.isReplaying()) {
core.triggerReplay();
return;
}
2022-11-14 17:11:23 +08:00
if (main.core.isPlaying()) main.core.openBook(true);
};
2022-11-13 18:02:05 +08:00
////// 点击状态栏中的楼层传送器/装备栏时 //////
main.statusBar.image.fly.onclick = function (e) {
e.stopPropagation();
// 播放录像时
if (core.isReplaying()) {
core.stopReplay();
return;
}
if (main.core.isPlaying()) {
if (!main.core.flags.equipboxButton) {
main.core.useFly(true);
2022-11-14 17:11:23 +08:00
} else {
main.core.openEquipbox(true);
2022-11-13 18:02:05 +08:00
}
}
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 点击状态栏中的工具箱时 //////
main.statusBar.image.toolbox.onclick = function (e) {
e.stopPropagation();
if (core.isReplaying()) {
core.rewindReplay();
return;
}
if (main.core.isPlaying()) {
main.core.openToolbox(core.status.event.id != 'equipbox');
}
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 双击状态栏中的工具箱时 //////
main.statusBar.image.toolbox.ondblclick = function (e) {
e.stopPropagation();
if (core.isReplaying()) {
return;
}
2022-11-14 17:11:23 +08:00
if (main.core.isPlaying()) main.core.openEquipbox(true);
};
2022-11-13 18:02:05 +08:00
////// 点击状态栏中的虚拟键盘时 //////
main.statusBar.image.keyboard.onclick = function (e) {
e.stopPropagation();
if (core.isReplaying()) {
core.control._replay_book();
return;
}
2022-11-14 17:11:23 +08:00
if (main.core.isPlaying()) main.core.openKeyBoard(true);
};
2022-11-13 18:02:05 +08:00
////// 点击状态栏中的快捷商店时 //////
main.statusBar.image.shop.onclick = function (e) {
e.stopPropagation();
if (core.isReplaying()) {
core.control._replay_viewMap();
return;
}
2022-11-14 17:11:23 +08:00
if (main.core.isPlaying()) main.core.openQuickShop(true);
};
2022-11-13 18:02:05 +08:00
////// 点击金币时也可以开启快捷商店 //////
main.statusBar.image.money.onclick = function (e) {
e.stopPropagation();
2022-11-14 17:11:23 +08:00
if (main.core.isPlaying()) main.core.openQuickShop(true);
};
2022-11-13 18:02:05 +08:00
////// 点击楼梯图标也可以浏览地图 //////
main.statusBar.image.floor.onclick = function (e) {
e.stopPropagation();
2022-11-14 17:11:23 +08:00
if (
main.core &&
main.core.isPlaying() &&
!core.isMoving() &&
!core.status.lockControl
) {
2022-11-13 18:02:05 +08:00
core.ui._drawViewMaps();
}
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 点击状态栏中的存档按钮时 //////
main.statusBar.image.save.onclick = function (e) {
e.stopPropagation();
if (core.isReplaying()) {
core.speedDownReplay();
return;
}
2022-11-14 17:11:23 +08:00
if (main.core.isPlaying()) main.core.save(true);
};
2022-11-13 18:02:05 +08:00
////// 点击状态栏中的读档按钮时 //////
main.statusBar.image.load.onclick = function (e) {
e.stopPropagation();
if (core.isReplaying()) {
core.speedUpReplay();
return;
}
2022-11-14 17:11:23 +08:00
if (main.core.isPlaying()) main.core.load(true);
};
2022-11-13 18:02:05 +08:00
////// 点击状态栏中的系统菜单时 //////
main.statusBar.image.settings.onclick = function (e) {
e.stopPropagation();
if (core.isReplaying()) {
core.control._replay_SL();
return;
}
2022-11-14 17:11:23 +08:00
if (main.core.isPlaying()) main.core.openSettings(true);
};
2022-11-13 18:02:05 +08:00
////// 点击工具栏时 //////
main.dom.hard.onclick = function () {
main.core.control.setToolbarButton(!core.domStyle.toolbarBtn);
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
////// 手机端的按钮1-7 //////
main.statusBar.image.btn1.onclick = function (e) {
e.stopPropagation();
2022-11-14 17:11:23 +08:00
main.core.onkeyUp({
keyCode: 49,
altKey: core.getLocalStorage('altKey')
});
2022-11-13 18:02:05 +08:00
};
main.statusBar.image.btn2.onclick = function (e) {
e.stopPropagation();
2022-11-14 17:11:23 +08:00
main.core.onkeyUp({
keyCode: 50,
altKey: core.getLocalStorage('altKey')
});
2022-11-13 18:02:05 +08:00
};
main.statusBar.image.btn3.onclick = function (e) {
e.stopPropagation();
2022-11-14 17:11:23 +08:00
main.core.onkeyUp({
keyCode: 51,
altKey: core.getLocalStorage('altKey')
});
2022-11-13 18:02:05 +08:00
};
main.statusBar.image.btn4.onclick = function (e) {
e.stopPropagation();
2022-11-14 17:11:23 +08:00
main.core.onkeyUp({
keyCode: 52,
altKey: core.getLocalStorage('altKey')
});
2022-11-13 18:02:05 +08:00
};
main.statusBar.image.btn5.onclick = function (e) {
e.stopPropagation();
2022-11-14 17:11:23 +08:00
main.core.onkeyUp({
keyCode: 53,
altKey: core.getLocalStorage('altKey')
});
2022-11-13 18:02:05 +08:00
};
main.statusBar.image.btn6.onclick = function (e) {
e.stopPropagation();
2022-11-14 17:11:23 +08:00
main.core.onkeyUp({
keyCode: 54,
altKey: core.getLocalStorage('altKey')
});
2022-11-13 18:02:05 +08:00
};
main.statusBar.image.btn7.onclick = function (e) {
e.stopPropagation();
2022-11-14 17:11:23 +08:00
main.core.onkeyUp({
keyCode: 55,
altKey: core.getLocalStorage('altKey')
});
2022-11-13 18:02:05 +08:00
};
main.statusBar.image.btn8.onclick = function (e) {
e.stopPropagation();
if (core.getLocalStorage('altKey')) {
core.removeLocalStorage('altKey');
2022-11-14 17:11:23 +08:00
core.drawTip('Alt模式已关闭。');
2022-11-13 18:02:05 +08:00
main.statusBar.image.btn8.style.filter = '';
2022-11-14 17:11:23 +08:00
} else {
2022-11-13 18:02:05 +08:00
core.setLocalStorage('altKey', true);
2022-11-14 17:11:23 +08:00
core.drawTip('Alt模式已开启此模式下1~7按钮视为Alt+1~7。');
2022-11-13 18:02:05 +08:00
main.statusBar.image.btn8.style.filter = 'sepia(1) contrast(1.5)';
}
};
////// 点击“开始游戏”时 //////
2023-02-20 20:34:42 +08:00
// main.dom.playGame.onclick = function () {
// main.dom.startButtons.style.display = 'none';
// main.core.control.checkBgm();
// if (main.levelChoose.length == 0) {
// core.events.startGame('');
// } else {
// main.dom.levelChooseButtons.style.display = 'block';
// main.selectedButton = null;
// main.selectButton(0);
// }
// };
// ////// 点击“载入游戏”时 //////
// main.dom.loadGame.onclick = function () {
// main.core.control.checkBgm();
// main.core.load();
// };
// ////// 点击“录像回放”时 //////
// main.dom.replayGame.onclick = function () {
// main.core.control.checkBgm();
// main.core.chooseReplayFile();
// };
// main.dom.musicBtn.onclick = function () {
// try {
// if (main.core) main.core.triggerBgm();
// } catch (ee) {
// console.error(ee);
// }
// };
2022-11-13 18:02:05 +08:00
window.onblur = function () {
if (main.core && main.core.control) {
try {
main.core.control.checkAutosave();
2022-11-14 17:11:23 +08:00
} catch (e) {}
2022-11-13 18:02:05 +08:00
}
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
main.dom.inputYes.onclick = function () {
main.dom.inputDiv.style.display = 'none';
var func = core.platform.successCallback;
core.platform.successCallback = core.platform.errorCallback = null;
if (func) func(main.dom.inputBox.value);
2022-11-14 17:11:23 +08:00
};
2022-11-13 18:02:05 +08:00
main.dom.inputNo.onclick = function () {
main.dom.inputDiv.style.display = 'none';
var func = core.platform.errorCallback;
core.platform.successCallback = core.platform.errorCallback = null;
if (func) func(null);
2022-11-14 17:11:23 +08:00
};
}; //listen end
2022-11-13 18:02:05 +08:00
2022-11-14 17:11:23 +08:00
var main = new main();