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}`