完善资源分离,生成可发布结构

This commit is contained in:
unanmed 2023-06-09 11:07:31 +08:00
parent b5649c996b
commit 820dc5bf4c
9 changed files with 139 additions and 45 deletions

View File

@ -5,3 +5,4 @@ public/project/floors/*.js
public/project/items.js
public/project/floors/*.js
public/project/maps.js
script/**/*.js

View File

@ -2,6 +2,7 @@ interface MotaConfig {
name: string;
/** 资源分组打包信息 */
resourceZip?: string[][];
resourceName?: string;
}
function defineConfig(config: MotaConfig): MotaConfig {
@ -10,5 +11,6 @@ function defineConfig(config: MotaConfig): MotaConfig {
export default defineConfig({
// 这里修改塔的name请保持与全塔属性的完全相同否则发布之后可能无法进行游玩
name: 'HumanBreak'
name: 'HumanBreak',
resourceName: 'HumanBreakRes'
});

View File

@ -2,6 +2,7 @@ import fs from 'fs-extra';
import { uniqueSymbol } from './utils.js';
import { basename, extname, resolve } from 'path';
import { dirname } from 'path';
import motaConfig from '../mota.config.js';
type ResorceType =
| 'bgms'
@ -13,17 +14,8 @@ type ResorceType =
| 'animates'
| 'fonts';
const compress: ResorceType[] = [
'sounds',
'animates',
'autotiles',
'images',
'materials',
'tilesets'
];
const SYMBOL = uniqueSymbol();
const MAX_SIZE = 100 * (1 << 20);
const MAX_SIZE = 100 * (1 << 20) - 20 * (1 << 10);
const baseDir = './dist';
let totalSize = 0;
@ -160,6 +152,9 @@ async function doSplit(compress: boolean) {
)
);
// 生成可发布结构
await generatePublishStructure(dir, index);
if (Object.values(dirInfo).every(v => v.length === 0)) return;
else return split(index + 1);
};
@ -175,7 +170,7 @@ async function rewriteMain(sourceIndex: Record<string, number>) {
.replace(/this\.USE_RESOURCE\s*\=\s*false/, 'this.USE_RESOURCE = true')
.replace(
/this\.RESOURCE_URL\s*\=\s*'.*'/,
"this.RESOURCE_URL = '/games/HumanBreakRes'"
`this.RESOURCE_URL = '/games/${motaConfig.resourceName}'`
)
.replace(
/this\.RESOURCE_SYMBOL\s*\=\s*'.*'/,
@ -187,3 +182,63 @@ async function rewriteMain(sourceIndex: Record<string, number>) {
);
await fs.writeFile('./dist/main.js', res, 'utf-8');
}
async function generatePublishStructure(dir: string, index: number) {
await fs.mkdir(resolve(dir, 'libs'));
await fs.mkdir(resolve(dir, 'libs/thirdparty'));
await fs.mkdir(resolve(dir, 'project'));
await Promise.all(
[
'autotiles',
'images',
'materials',
'animates',
'fonts',
'floors',
'tilesets',
'sounds',
'bgms'
].map(v => fs.mkdir(resolve(dir, 'project', v)))
);
await fs.writeFile(
resolve(dir, 'project/icons.js'),
`var icons_4665ee12_3a1f_44a4_bea3_0fccba634dc1 =
{
"autotile": {
}
}`,
'utf-8'
);
await fs.writeFile(
resolve(dir, 'project/floors/none.js'),
'"none"',
'utf-8'
);
await fs.writeFile(resolve(dir, 'libs/none.js'), '"none"', 'utf-8');
await fs.copyFile(
'./script/template/main.js',
resolve(dir, 'project/main.js')
);
const data = await fs.readFile('./script/template/data.js', 'utf-8');
await fs.writeFile(
resolve(dir, 'project/data.js'),
data.replace('@name', `${motaConfig.resourceName}${index}`)
);
await fs.copyFile(
'./script/template/lz-string.min.js',
resolve(dir, 'libs/thirdparty/lz-string.min.js')
);
await Promise.all(
['animates', 'images', 'materials', 'sounds', 'tilesets'].map(v => {
fs.copyFile(
'./script/template/.h5data',
resolve(dir, `project/${v}/${v}.h5data`)
);
})
);
}

BIN
script/template/.h5data Normal file

Binary file not shown.

26
script/template/data.js Normal file
View File

@ -0,0 +1,26 @@
var data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d =
{
"main": {
"floorIds": ["none"],
"floorPartitions": [],
"images": [],
"tilesets": [],
"animates": [],
"bgms": [],
"sounds": [],
"fonts": [],
"nameMap": {},
"levelChoose": [],
"equipName": [],
"styles": {},
"splitImages": []
},
"firstData": {
"title": "@name",
"name": "@name",
"version": "v0.1",
"hero": {}
},
"values": {},
"flags": {}
}

1
script/template/lz-string.min.js vendored Normal file
View File

@ -0,0 +1 @@
var LZString=function(){function o(o,r){if(!t[o]){t[o]={};for(var n=0;n<o.length;n++)t[o][o.charAt(n)]=n}return t[o][r]}var r=String.fromCharCode,n="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",e="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+-$",t={},i={compressToBase64:function(o){if(null==o)return"";var r=i._compress(o,6,function(o){return n.charAt(o)});switch(r.length%4){default:case 0:return r;case 1:return r+"===";case 2:return r+"==";case 3:return r+"="}},decompressFromBase64:function(r){return null==r?"":""==r?null:i._decompress(r.length,32,function(e){return o(n,r.charAt(e))})},compressToUTF16:function(o){return null==o?"":i._compress(o,15,function(o){return r(o+32)})+" "},decompressFromUTF16:function(o){return null==o?"":""==o?null:i._decompress(o.length,16384,function(r){return o.charCodeAt(r)-32})},compressToUint8Array:function(o){for(var r=i.compress(o),n=new Uint8Array(2*r.length),e=0,t=r.length;t>e;e++){var s=r.charCodeAt(e);n[2*e]=s>>>8,n[2*e+1]=s%256}return n},decompressFromUint8Array:function(o){if(null===o||void 0===o)return i.decompress(o);for(var n=new Array(o.length/2),e=0,t=n.length;t>e;e++)n[e]=256*o[2*e]+o[2*e+1];var s=[];return n.forEach(function(o){s.push(r(o))}),i.decompress(s.join(""))},compressToEncodedURIComponent:function(o){return null==o?"":i._compress(o,6,function(o){return e.charAt(o)})},decompressFromEncodedURIComponent:function(r){return null==r?"":""==r?null:(r=r.replace(/ /g,"+"),i._decompress(r.length,32,function(n){return o(e,r.charAt(n))}))},compress:function(o){return i._compress(o,16,function(o){return r(o)})},_compress:function(o,r,n){if(null==o)return"";var e,t,i,s={},p={},u="",c="",a="",l=2,f=3,h=2,d=[],m=0,v=0;for(i=0;i<o.length;i+=1)if(u=o.charAt(i),Object.prototype.hasOwnProperty.call(s,u)||(s[u]=f++,p[u]=!0),c=a+u,Object.prototype.hasOwnProperty.call(s,c))a=c;else{if(Object.prototype.hasOwnProperty.call(p,a)){if(a.charCodeAt(0)<256){for(e=0;h>e;e++)m<<=1,v==r-1?(v=0,d.push(n(m)),m=0):v++;for(t=a.charCodeAt(0),e=0;8>e;e++)m=m<<1|1&t,v==r-1?(v=0,d.push(n(m)),m=0):v++,t>>=1}else{for(t=1,e=0;h>e;e++)m=m<<1|t,v==r-1?(v=0,d.push(n(m)),m=0):v++,t=0;for(t=a.charCodeAt(0),e=0;16>e;e++)m=m<<1|1&t,v==r-1?(v=0,d.push(n(m)),m=0):v++,t>>=1}l--,0==l&&(l=Math.pow(2,h),h++),delete p[a]}else for(t=s[a],e=0;h>e;e++)m=m<<1|1&t,v==r-1?(v=0,d.push(n(m)),m=0):v++,t>>=1;l--,0==l&&(l=Math.pow(2,h),h++),s[c]=f++,a=String(u)}if(""!==a){if(Object.prototype.hasOwnProperty.call(p,a)){if(a.charCodeAt(0)<256){for(e=0;h>e;e++)m<<=1,v==r-1?(v=0,d.push(n(m)),m=0):v++;for(t=a.charCodeAt(0),e=0;8>e;e++)m=m<<1|1&t,v==r-1?(v=0,d.push(n(m)),m=0):v++,t>>=1}else{for(t=1,e=0;h>e;e++)m=m<<1|t,v==r-1?(v=0,d.push(n(m)),m=0):v++,t=0;for(t=a.charCodeAt(0),e=0;16>e;e++)m=m<<1|1&t,v==r-1?(v=0,d.push(n(m)),m=0):v++,t>>=1}l--,0==l&&(l=Math.pow(2,h),h++),delete p[a]}else for(t=s[a],e=0;h>e;e++)m=m<<1|1&t,v==r-1?(v=0,d.push(n(m)),m=0):v++,t>>=1;l--,0==l&&(l=Math.pow(2,h),h++)}for(t=2,e=0;h>e;e++)m=m<<1|1&t,v==r-1?(v=0,d.push(n(m)),m=0):v++,t>>=1;for(;;){if(m<<=1,v==r-1){d.push(n(m));break}v++}return d.join("")},decompress:function(o){return null==o?"":""==o?null:i._decompress(o.length,32768,function(r){return o.charCodeAt(r)})},_decompress:function(o,n,e){var t,i,s,p,u,c,a,l,f=[],h=4,d=4,m=3,v="",w=[],A={val:e(0),position:n,index:1};for(i=0;3>i;i+=1)f[i]=i;for(p=0,c=Math.pow(2,2),a=1;a!=c;)u=A.val&A.position,A.position>>=1,0==A.position&&(A.position=n,A.val=e(A.index++)),p|=(u>0?1:0)*a,a<<=1;switch(t=p){case 0:for(p=0,c=Math.pow(2,8),a=1;a!=c;)u=A.val&A.position,A.position>>=1,0==A.position&&(A.position=n,A.val=e(A.index++)),p|=(u>0?1:0)*a,a<<=1;l=r(p);break;case 1:for(p=0,c=Math.pow(2,16),a=1;a!=c;)u=A.val&A.position,A.position>>=1,0==A.position&&(A.position=n,A.val=e(A.index++)),p|=(u>0?1:0)*a,a<<=1;l=r(p);break;case 2:return""}for(f[3]=l,s=l,w.push(l);;){if(A.index>o)return"";for(p=0,c=Math.pow(2,m),a=1;a!=c;)u=A.val&A.position,A.position>>=1,0==A.position&&(A.position=n,A.val=e(A.index++)),p|=(u>0?1:0)*a,a<<=1;switch(l=p){case 0:for(p=0,c=Math.pow(2,8),a=1;a!=c;)u=A.val&A.position,A.position>>=1,0==A.position&&(A.position=n,A.val=e(A.index++)),p|=(u>0?1:0)*a,a<<=1;f[d++]=r(p),l=d-1,h--;break;case 1:for(p=0,c=Math.pow(2,16),a=1;a!=c;)u=A.val&A.position,A.position>>=1,0==A.position&&(A.position=n,A.val=e(A.index++)),p|=(u>0?1:0)*a,a<<=1;f[d++]=r(p),l=d-1,h--;break;case 2:return w.join("")}if(0==h&&(h=Math.pow(2,m),m++),f[l])v=f[l];else{if(l!==d)return null;v=s+s.charAt(0)}w.push(v),f[d++]=s+v.charAt(0),h--,s=v,0==h&&(h=Math.pow(2,m),m++)}}};return i}();"function"==typeof define&&define.amd?define(function(){return LZString}):"undefined"!=typeof module&&null!=module&&(module.exports=LZString);

40
script/template/main.js Normal file
View File

@ -0,0 +1,40 @@
function main() {
//------------------------ 用户修改内容 ------------------------//
this.version = 'v0.1'; // 游戏版本号如果更改了游戏内容建议修改此version以免造成缓存问题。
this.useCompress = false; // 是否使用压缩文件
// 当你即将发布你的塔时请使用“JS代码压缩工具”将所有js代码进行压缩然后将这里的useCompress改为true。
// 请注意只有useCompress是false时才会读取floors目录下的文件为true时会直接读取libs目录下的floors.min.js文件。
// 如果要进行剧本的修改请务必将其改成false
this.bgmRemote = false; // 是否采用远程BGM
this.bgmRemoteRoot = 'https://h5mota.com/music/'; // 远程BGM的根目录
this.isCompetition = false; // 是否是比赛模式
this.savePages = 1000; // 存档页数每页可存5个默认为1000页5000个存档
this.criticalUseLoop = 1; // 循环临界的分界
//------------------------ 用户修改内容 END ------------------------//
this.dom = {};
this.mode = 'play';
this.loadList = ['none'];
this.pureData = ['data'];
this.materials = [];
this.statusBar = {
image: {},
icons: {}
};
this.floors = {};
this.canvas = {};
this.__VERSION__ = 'v0.1';
this.__VERSION_CODE__ = 1000;
}
main.prototype.loadMod = function () {};
main.prototype.init = function () {};

View File

@ -1,30 +1 @@
import axios, { AxiosRequestConfig } from 'axios';
class LoadTask<T> {
loaded: boolean = false;
promise?: Promise<T>;
url: string;
config?: AxiosRequestConfig<T>;
constructor(url: string, config?: AxiosRequestConfig<T>) {
this.url = url;
this.config = config;
}
load() {
if (this.promise) return this.promise;
return (this.promise = axios.get(this.url, this.config));
}
static list: Promise<any>[] = [];
static push(...tasks: LoadTask<any>[]) {
this.list.push(...tasks.map(v => v.load()));
}
static onEnd<T extends any[] = any[]>(): Promise<T> {
return Promise.all(LoadTask.list) as Promise<T>;
}
}
export default function load() {}
export function readyAllResource() {}

View File

@ -18,7 +18,6 @@ import completion, { floors } from './plugin/completion';
import path from './plugin/fx/path';
import gameCanvas from './plugin/fx/gameCanvas';
import noise from './plugin/fx/noise';
import load from './core/loader/load';
function forward() {
const toForward: any[] = [
@ -61,7 +60,6 @@ function forward() {
}
console.log('插件转发完成!');
load();
Object.values(floors).forEach((v, i) => {
const from = core.floorIds.indexOf(v[0]);