diff --git a/package.json b/package.json index 3266d5d..82df949 100644 --- a/package.json +++ b/package.json @@ -29,6 +29,9 @@ "@babel/cli": "^7.21.0", "@babel/core": "^7.21.4", "@babel/preset-env": "^7.21.4", + "@rollup/plugin-babel": "^6.0.3", + "@rollup/plugin-terser": "^0.4.1", + "@rollup/plugin-typescript": "^11.1.0", "@types/babel__core": "^7.20.0", "@types/fontmin": "^0.9.0", "@types/fs-extra": "^9.0.13", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 0801be2..1284b82 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -5,6 +5,9 @@ specifiers: '@babel/cli': ^7.21.0 '@babel/core': ^7.21.4 '@babel/preset-env': ^7.21.4 + '@rollup/plugin-babel': ^6.0.3 + '@rollup/plugin-terser': ^0.4.1 + '@rollup/plugin-typescript': ^11.1.0 '@types/babel__core': ^7.20.0 '@types/fontmin': ^0.9.0 '@types/fs-extra': ^9.0.13 @@ -49,6 +52,9 @@ devDependencies: '@babel/cli': 7.21.0_@babel+core@7.21.4 '@babel/core': 7.21.4 '@babel/preset-env': 7.21.4_@babel+core@7.21.4 + '@rollup/plugin-babel': 6.0.3_mthsuwq2qd2jauekjxjmmazyii + '@rollup/plugin-terser': 0.4.1_rollup@3.20.2 + '@rollup/plugin-typescript': 11.1.0_e7tciabaay7z2i5ycjdzz3zl6i '@types/babel__core': 7.20.0 '@types/fontmin': 0.9.0 '@types/fs-extra': 9.0.13 @@ -1622,6 +1628,60 @@ packages: rimraf: 3.0.2 dev: true + /@rollup/plugin-babel/6.0.3_mthsuwq2qd2jauekjxjmmazyii: + resolution: {integrity: sha512-fKImZKppa1A/gX73eg4JGo+8kQr/q1HBQaCGKECZ0v4YBBv3lFqi14+7xyApECzvkLTHCifx+7ntcrvtBIRcpg==} + engines: {node: '>=14.0.0'} + peerDependencies: + '@babel/core': ^7.0.0 + '@types/babel__core': ^7.1.9 + rollup: ^1.20.0||^2.0.0||^3.0.0 + peerDependenciesMeta: + '@types/babel__core': + optional: true + rollup: + optional: true + dependencies: + '@babel/core': 7.21.4 + '@babel/helper-module-imports': 7.21.4 + '@rollup/pluginutils': 5.0.2_rollup@3.20.2 + '@types/babel__core': 7.20.0 + rollup: 3.20.2 + dev: true + + /@rollup/plugin-terser/0.4.1_rollup@3.20.2: + resolution: {integrity: sha512-aKS32sw5a7hy+fEXVy+5T95aDIwjpGHCTv833HXVtyKMDoVS7pBr5K3L9hEQoNqbJFjfANPrNpIXlTQ7is00eA==} + engines: {node: '>=14.0.0'} + peerDependencies: + rollup: ^2.x || ^3.x + peerDependenciesMeta: + rollup: + optional: true + dependencies: + rollup: 3.20.2 + serialize-javascript: 6.0.1 + smob: 0.0.6 + terser: 5.16.9 + dev: true + + /@rollup/plugin-typescript/11.1.0_e7tciabaay7z2i5ycjdzz3zl6i: + resolution: {integrity: sha512-86flrfE+bSHB69znnTV6kVjkncs2LBMhcTCyxWgRxLyfXfQrxg4UwlAqENnjrrxnSNS/XKCDJCl8EkdFJVHOxw==} + engines: {node: '>=14.0.0'} + peerDependencies: + rollup: ^2.14.0||^3.0.0 + tslib: '*' + typescript: '>=3.7.0' + peerDependenciesMeta: + rollup: + optional: true + tslib: + optional: true + dependencies: + '@rollup/pluginutils': 5.0.2_rollup@3.20.2 + resolve: 1.22.3 + rollup: 3.20.2 + typescript: 4.9.5 + dev: true + /@rollup/pluginutils/5.0.2_rollup@3.20.2: resolution: {integrity: sha512-pTd9rIsP92h+B6wWwFbW8RkZv4hiR/xKsqre4SIuAOaOEQRxi0lqLke9k2/7WegC85GgUs9pjmOjCUi3In4vwA==} engines: {node: '>=14.0.0'} @@ -3798,6 +3858,12 @@ packages: engines: {node: '>=10'} dev: true + /randombytes/2.1.0: + resolution: {integrity: sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==} + dependencies: + safe-buffer: 5.2.1 + dev: true + /read-pkg-up/8.0.0: resolution: {integrity: sha512-snVCqPczksT0HS2EC+SxUndvSzn6LRCwpfSvLrIfR5BKDQQZMaI6jPRC9dYvYFDRAuFEAnkwww8kBBNE/3VvzQ==} engines: {node: '>=12'} @@ -4020,6 +4086,12 @@ packages: lru-cache: 6.0.0 dev: true + /serialize-javascript/6.0.1: + resolution: {integrity: sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w==} + dependencies: + randombytes: 2.1.0 + dev: true + /set-blocking/2.0.0: resolution: {integrity: sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==} dev: true @@ -4042,6 +4114,10 @@ packages: engines: {node: '>= 6.0.0', npm: '>= 3.0.0'} dev: true + /smob/0.0.6: + resolution: {integrity: sha512-V21+XeNni+tTyiST1MHsa84AQhT1aFZipzPpOFAVB8DkHzwJyjjAmt9bgwnuZiZWnIbMo2duE29wybxv/7HWUw==} + dev: true + /socks-proxy-agent/7.0.0: resolution: {integrity: sha512-Fgl0YPZ902wEsAyiQ+idGd1A7rSFx/ayC1CQVMw5P+EQx2V0SgpGtf6OKFhVjPflPUl9YMmEOnmfjCdMUsygww==} engines: {node: '>= 10'} diff --git a/public/libs/control.js b/public/libs/control.js index acc63b3..19d07df 100644 --- a/public/libs/control.js +++ b/public/libs/control.js @@ -44,11 +44,6 @@ control.prototype._init = function () { ); this.registerAnimationFrame('weather', true, this._animationFrame_weather); this.registerAnimationFrame('tip', true, this._animateFrame_tip); - this.registerAnimationFrame( - 'parallelDo', - false, - this._animationFrame_parallelDo - ); // --- 注册系统的天气 this.registerWeather( 'rain', @@ -479,10 +474,6 @@ control.prototype._animateFrame_tip = function (timestamp) { } }; -control.prototype._animationFrame_parallelDo = function (timestamp) { - core.control.controldata.parallelDo(timestamp); -}; - // ------ 标题界面的处理 ------ // ////// 显示游戏开始界面 ////// diff --git a/public/libs/core.js b/public/libs/core.js index 4ea0919..6e068c8 100644 --- a/public/libs/core.js +++ b/public/libs/core.js @@ -343,10 +343,7 @@ core.prototype._loadPlugin = async function () { if (main.pluginUseCompress) { await main.loadScript(`project/plugin.min.js?v=${main.version}`); } else { - await main.loadScript( - `project/plugin/index.js?v=${main.version}`, - true - ); + await main.loadScript(`src/plugin/game/index.js`, true); } }; diff --git a/public/libs/events.js b/public/libs/events.js index c2ad12e..d2c0d0c 100644 --- a/public/libs/events.js +++ b/public/libs/events.js @@ -1018,15 +1018,6 @@ events.prototype.pushBox = function (data) { if (data.event.id == 'box') core.removeBlock(data.x, data.y); else core.setBlock('flower', data.x, data.y); // 勇士前进一格,然后触发推箱子后事件 - core.insertAction([ - { type: 'moveAction' }, - { type: 'function', function: 'function() { core.afterPushBox(); }' } - ]); -}; - -////// 推箱子后的事件 ////// -events.prototype.afterPushBox = function () { - return this.eventdata.afterPushBox(); }; events.prototype._sys_ski = function (data, callback) { diff --git a/public/project/functions.js b/public/project/functions.js index ef1cbfd..17e30ca 100644 --- a/public/project/functions.js +++ b/public/project/functions.js @@ -484,19 +484,6 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a = { } if (todo.length > 0) core.insertAction(todo, x, y); - }, - afterPushBox: function () { - // 推箱子后的事件 - if (core.searchBlock('box').length == 0) { - // 可以通过if语句来进行开门操作 - /* - if (core.status.floorId=='xxx') { // 在某个楼层 - core.insertAction([ // 插入一条事件 - {"type": "openDoor", "loc": [x,y]} // 开门 - ]) - } - */ - } } }, enemys: { @@ -1906,23 +1893,6 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a = { return true; } return false; - }, - parallelDo: function (timestamp) { - // 并行事件处理,可以在这里写任何需要并行处理的脚本或事件 - // 该函数将被系统反复执行,每次执行间隔视浏览器或设备性能而定,一般约为16.6ms一次 - // 参数timestamp为“从游戏资源加载完毕到当前函数执行时”的时间差,以毫秒为单位 - - // 检查当前是否处于游戏开始状态 - if (!core.isPlaying()) return; - - // 执行当前楼层的并行事件处理 - if (core.status.floorId) { - try { - eval(core.floors[core.status.floorId].parallelDo); - } catch (e) { - console.error(e); - } - } } }, ui: { diff --git a/public/project/plugin/damage.js b/public/project/plugin/damage.js deleted file mode 100644 index 0a471a9..0000000 --- a/public/project/plugin/damage.js +++ /dev/null @@ -1,35 +0,0 @@ -/// - -/** - * 计算需要计算伤害的方向 - * @param {number} x - * @param {number} y - * @param {FloorIds} floorId - */ -export function getNeedCalculateDir(x, y, floorId) {} - -/** - * 获得怪物属性 - * @param {EnemyIds | Partial} enemy - * @param {Partial?} hero - * @param {number?} x - * @param {number?} y - * @param {FloorIds?} floorId - */ -export function getEnemyInfo(enemy, hero, x, y, floorId) {} - -/** - * 获得怪物伤害 - * @param {EnemyIds | Partial} enemy - * @param {Partial?} hero - * @param {number?} x - * @param {number?} y - * @param {FloorIds?} floorId - */ -export function getDamageInfo(enemy, hero, x, y, floorId) {} - -/** - * 计算地图伤害与光环效果 - * @param {FloorIds} floorId - */ -export function checkBlock(floorId) {} diff --git a/public/server.cjs b/public/server.cjs index f0dc4dd..7083499 100644 --- a/public/server.cjs +++ b/public/server.cjs @@ -41,9 +41,11 @@ next(); const listenedFloors = []; const listenedPlugins = []; +const pluginBase = 'public/plugin/game'; + const hasPlugin = (function () { try { - fss.readdirSync('./project/plugin'); + fss.readdirSync(pluginBase); return true; } catch { return false; @@ -339,7 +341,7 @@ async function watch() { }); // 脚本编辑 热重载 - const scripts = await extract('project/functions.js', 'project/plugins.js'); + const scripts = await extract('project/functions.js'); scripts.forEach(v => { const dir = path.resolve(__dirname, v); const type = v.split('/').at(-1).slice(0, -3); @@ -351,9 +353,11 @@ async function watch() { // 插件热重载 if (hasPlugin) { - const plugins = await extract('project/plugin/*.js'); + const plugins = (await extract('../src/plugin/game/*.js')).concat( + await extract('../src/plugin/game/*.ts') + ); plugins.forEach(v => { - watchOnePlugin(v.slice(15)); + watchOnePlugin(v.slice(19)); }); } @@ -390,9 +394,9 @@ function testWatchFloor(url) { */ function testWatchPlugin(url) { if (!hasPlugin) return; - if (/project(\/|\\)plugin(\/|\\).*\.js/.test(url)) { - const f = url.slice(15); - if (!listenedFloors.includes(f.slice(0, -3))) { + if (/src(\/|\\)plugin(\/|\\)game(\/|\\).*\.(js|ts)/.test(url)) { + const f = url.slice(19); + if (!listenedPlugins.includes(f.slice(0, -3))) { watchOnePlugin(f); } } @@ -419,15 +423,19 @@ function watchOneFloor(file) { * @param {string} file 要监听的文件 */ function watchOnePlugin(file) { - if (!/.*\.js/.test(file)) return; + if (!/.*\.(js|ts)/.test(file)) return; const f = file.slice(0, -3); listenedPlugins.push(file.slice(0, -3)); - fss.watchFile(`project/plugin/${file}`, { interval: 500 }, () => { - const plugin = f; - if (hotReloadData.includes(`@@plugin:${plugin}`)) return; - hotReloadData += `@@plugin:${plugin}`; - console.log(`plugin hot reload: ${plugin}`); - }); + fss.watchFile( + path.resolve(__dirname, `../src/plugin/game/${file}`), + { interval: 500 }, + () => { + const plugin = f; + if (hotReloadData.includes(`@@plugin:${plugin}`)) return; + hotReloadData += `@@plugin:${plugin}`; + console.log(`plugin hot reload: ${plugin}`); + } + ); } /** diff --git a/script/build.ts b/script/build.ts index e5bd6f5..53f908a 100644 --- a/script/build.ts +++ b/script/build.ts @@ -4,6 +4,9 @@ import fse from 'fs-extra'; import Fontmin from 'fontmin'; import * as babel from '@babel/core'; import * as rollup from 'rollup'; +import typescript from '@rollup/plugin-typescript'; +import rollupBabel from '@rollup/plugin-babel'; +import terser from '@rollup/plugin-terser'; (async function () { const timestamp = Date.now(); @@ -113,18 +116,31 @@ import * as rollup from 'rollup'; // 3. 压缩js插件 try { + await fse.remove('./dist/project/plugin.min.js'); + const build = await rollup.rollup({ - input: 'public/project/plugin/index.js' + input: 'src/plugin/game/index.js', + plugins: [ + typescript({ + sourceMap: false + }), + rollupBabel({ + babelHelpers: 'bundled', + sourceType: 'module' + }), + terser() + ] }); - const code = await build.generate({ + await build.write({ format: 'iife', - name: 'CorePlugin' + name: 'CorePlugin', + file: './dist/project/plugin.min.js' }); - const compressed = babel.transformSync(code.output[0].code)?.code!; - await fs.writeFile('./dist/project/plugin.min.js', compressed, 'utf-8'); await fse.remove('./dist/project/plugin/'); } catch (e) { + console.log(e); + console.log('压缩插件失败'); } diff --git a/public/project/plugin/chase.js b/src/plugin/game/chase.js similarity index 100% rename from public/project/plugin/chase.js rename to src/plugin/game/chase.js diff --git a/src/plugin/game/damage.ts b/src/plugin/game/damage.ts new file mode 100644 index 0000000..70ad5d3 --- /dev/null +++ b/src/plugin/game/damage.ts @@ -0,0 +1,9 @@ +/// + +export class EnemyCollection {} + +export class Enemy {} + +core.plugin.damage = { + Enemy +}; diff --git a/public/project/plugin/fiveLayer.js b/src/plugin/game/fiveLayer.js similarity index 100% rename from public/project/plugin/fiveLayer.js rename to src/plugin/game/fiveLayer.js diff --git a/public/project/plugin/halo.js b/src/plugin/game/halo.js similarity index 100% rename from public/project/plugin/halo.js rename to src/plugin/game/halo.js diff --git a/public/project/plugin/hero.js b/src/plugin/game/hero.js similarity index 100% rename from public/project/plugin/hero.js rename to src/plugin/game/hero.js diff --git a/public/project/plugin/heroFourFrames.js b/src/plugin/game/heroFourFrames.js similarity index 100% rename from public/project/plugin/heroFourFrames.js rename to src/plugin/game/heroFourFrames.js diff --git a/public/project/plugin/hotReload.js b/src/plugin/game/hotReload.js similarity index 97% rename from public/project/plugin/hotReload.js rename to src/plugin/game/hotReload.js index bd6a919..5368eaf 100644 --- a/public/project/plugin/hotReload.js +++ b/src/plugin/game/hotReload.js @@ -59,7 +59,9 @@ export {}; ) return; // 首先重新加载main.floors对应的楼层 - await import(`/project/floors/${data}.js?v=${Date.now()}`); + await import( + /* @vite-ignore */ `./project/floors/${data}.js?v=${Date.now()}` + ); // 然后写入core.floors并解析 core.floors[data] = main.floors[data]; const floor = core.loadFloor(data); @@ -127,7 +129,7 @@ export {}; async function reloadPlugin(data) { // 直接import就完事了 - await import(`/project/plugin/${data}.js?v=${Date.now()}`); + await import(/* @vite-ignore */ `./src/plugin/game/${data}.js`); console.log(`plugin hot reload: ${data}.js`); } diff --git a/public/project/plugin/index.js b/src/plugin/game/index.js similarity index 93% rename from public/project/plugin/index.js rename to src/plugin/game/index.js index a71f457..85507c6 100644 --- a/public/project/plugin/index.js +++ b/src/plugin/game/index.js @@ -17,6 +17,7 @@ import * as study from './study.js'; import * as towerBoss from './towerBoss.js'; import * as utils from './utils.js'; import * as chase from './chase.js'; +import * as damage from './damage'; export { halo, @@ -30,5 +31,6 @@ export { study, towerBoss, utils, - chase + chase, + damage }; diff --git a/public/project/plugin/itemDetail.js b/src/plugin/game/itemDetail.js similarity index 100% rename from public/project/plugin/itemDetail.js rename to src/plugin/game/itemDetail.js diff --git a/public/project/plugin/loopMap.js b/src/plugin/game/loopMap.js similarity index 100% rename from public/project/plugin/loopMap.js rename to src/plugin/game/loopMap.js diff --git a/public/project/plugin/popup.js b/src/plugin/game/popup.js similarity index 100% rename from public/project/plugin/popup.js rename to src/plugin/game/popup.js diff --git a/public/project/plugin/remainEnemy.js b/src/plugin/game/remainEnemy.js similarity index 100% rename from public/project/plugin/remainEnemy.js rename to src/plugin/game/remainEnemy.js diff --git a/public/project/plugin/removeMap.js b/src/plugin/game/removeMap.js similarity index 100% rename from public/project/plugin/removeMap.js rename to src/plugin/game/removeMap.js diff --git a/public/project/plugin/replay.js b/src/plugin/game/replay.js similarity index 100% rename from public/project/plugin/replay.js rename to src/plugin/game/replay.js diff --git a/public/project/plugin/shop.js b/src/plugin/game/shop.js similarity index 100% rename from public/project/plugin/shop.js rename to src/plugin/game/shop.js diff --git a/public/project/plugin/skillTree.js b/src/plugin/game/skillTree.js similarity index 100% rename from public/project/plugin/skillTree.js rename to src/plugin/game/skillTree.js diff --git a/public/project/plugin/skills.js b/src/plugin/game/skills.js similarity index 100% rename from public/project/plugin/skills.js rename to src/plugin/game/skills.js diff --git a/public/project/plugin/study.js b/src/plugin/game/study.js similarity index 100% rename from public/project/plugin/study.js rename to src/plugin/game/study.js diff --git a/public/project/plugin/towerBoss.js b/src/plugin/game/towerBoss.js similarity index 100% rename from public/project/plugin/towerBoss.js rename to src/plugin/game/towerBoss.js diff --git a/public/project/plugin/ui.js b/src/plugin/game/ui.js similarity index 100% rename from public/project/plugin/ui.js rename to src/plugin/game/ui.js diff --git a/public/project/plugin/utils.js b/src/plugin/game/utils.js similarity index 100% rename from public/project/plugin/utils.js rename to src/plugin/game/utils.js diff --git a/src/plugin/use.ts b/src/plugin/use.ts index 55e5c84..5f8887a 100644 --- a/src/plugin/use.ts +++ b/src/plugin/use.ts @@ -92,7 +92,7 @@ export function useDrag( target.addEventListener('mouseup', mouseUp as EventListener); target.addEventListener('touchend', touchUp as EventListener); } - dragFnMap.set(fn, [mouseFn, touchFn, mouseUp, touchUp]); + dragFnMap.set(fn, [mouseUp, touchUp]); } /** @@ -103,8 +103,6 @@ export function cancelGlobalDrag(fn: DragFn): void { const fns = dragFnMap.get(fn); dragFnMap.delete(fn); if (!fns) return; - document.removeEventListener('mousemove', fns[0]); - document.removeEventListener('touchmove', fns[1]); document.removeEventListener('mouseup', fns[0]); document.removeEventListener('touchend', fns[1]); } diff --git a/src/types/plugin.d.ts b/src/types/plugin.d.ts index 5229d3b..e81ca88 100644 --- a/src/types/plugin.d.ts +++ b/src/types/plugin.d.ts @@ -30,6 +30,7 @@ interface PluginDeclaration hero: GamePluginHeroRealStatus; replay: PluginReplay; chase: PluginChase; + damage: PluginDamage; skills: Record; skillEffects: SkillEffects; @@ -456,6 +457,12 @@ interface Skill { effect: string[]; } +interface PluginDamage { + Enemy: new () => DamageEnemy; +} + +interface DamageEnemy {} + type Forward = { [K in keyof T as T[K] extends Function ? K extends `_${string}`