mirror of
https://github.com/unanmed/HumanBreak.git
synced 2025-01-19 12:49:25 +08:00
feat: 小地图缩放
This commit is contained in:
parent
793394335d
commit
d7ee49dd23
12
src/App.vue
12
src/App.vue
@ -94,16 +94,4 @@ function show(index: number) {
|
|||||||
display: none;
|
display: none;
|
||||||
z-index: 0;
|
z-index: 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media screen and (max-width: 600px) {
|
|
||||||
#ui {
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ui-list {
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
||||||
|
@ -5,6 +5,8 @@ import { has, triggerFullscreen } from '@/plugin/utils';
|
|||||||
import { createSettingComponents } from './init/settings';
|
import { createSettingComponents } from './init/settings';
|
||||||
import { bgm } from '../audio/bgm';
|
import { bgm } from '../audio/bgm';
|
||||||
import { SoundEffect } from '../audio/sound';
|
import { SoundEffect } from '../audio/sound';
|
||||||
|
import settingsText from '@/data/settings.json';
|
||||||
|
import { isMobile } from '@/plugin/use';
|
||||||
|
|
||||||
export interface SettingComponentProps {
|
export interface SettingComponentProps {
|
||||||
item: MotaSettingItem;
|
item: MotaSettingItem;
|
||||||
@ -20,6 +22,7 @@ export interface MotaSettingItem<T extends MotaSettingType = MotaSettingType> {
|
|||||||
key: string;
|
key: string;
|
||||||
value: T;
|
value: T;
|
||||||
controller: SettingComponent;
|
controller: SettingComponent;
|
||||||
|
description?: string;
|
||||||
defaults?: boolean | number;
|
defaults?: boolean | number;
|
||||||
step?: [number, number, number];
|
step?: [number, number, number];
|
||||||
display?: (value: T) => string;
|
display?: (value: T) => string;
|
||||||
@ -195,6 +198,17 @@ export class MotaSetting extends EventEmitter<SettingEvent> {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 设置一个设置的说明
|
||||||
|
* @param key 要设置的设置的id
|
||||||
|
* @param desc 设置的说明
|
||||||
|
*/
|
||||||
|
setDescription(key: string, desc: string) {
|
||||||
|
const setting = this.getSettingBy(key.split('.'));
|
||||||
|
setting.description = desc;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
private getSettingBy(list: string[]) {
|
private getSettingBy(list: string[]) {
|
||||||
let now: MotaSetting = this;
|
let now: MotaSetting = this;
|
||||||
|
|
||||||
@ -219,15 +233,13 @@ interface SettingDisplayerEvent extends EmitableEvent {
|
|||||||
|
|
||||||
export class SettingDisplayer extends EventEmitter<SettingDisplayerEvent> {
|
export class SettingDisplayer extends EventEmitter<SettingDisplayerEvent> {
|
||||||
setting: MotaSetting;
|
setting: MotaSetting;
|
||||||
textInfo: SettingText;
|
|
||||||
/** 选项选中栈 */
|
/** 选项选中栈 */
|
||||||
selectStack: string[] = [];
|
selectStack: string[] = [];
|
||||||
displayInfo: SettingDisplayInfo[] = reactive([]);
|
displayInfo: SettingDisplayInfo[] = reactive([]);
|
||||||
|
|
||||||
constructor(setting: MotaSetting, textInfo: SettingText) {
|
constructor(setting: MotaSetting) {
|
||||||
super();
|
super();
|
||||||
this.setting = setting;
|
this.setting = setting;
|
||||||
this.textInfo = textInfo;
|
|
||||||
this.update();
|
this.update();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -252,7 +264,6 @@ export class SettingDisplayer extends EventEmitter<SettingDisplayerEvent> {
|
|||||||
update() {
|
update() {
|
||||||
const list = this.selectStack;
|
const list = this.selectStack;
|
||||||
let now = this.setting;
|
let now = this.setting;
|
||||||
let nowText: string[] | SettingText = this.textInfo;
|
|
||||||
this.displayInfo = [];
|
this.displayInfo = [];
|
||||||
|
|
||||||
for (let i = 0; i < list.length - 1; i++) {
|
for (let i = 0; i < list.length - 1; i++) {
|
||||||
@ -271,17 +282,16 @@ export class SettingDisplayer extends EventEmitter<SettingDisplayerEvent> {
|
|||||||
});
|
});
|
||||||
|
|
||||||
now = item;
|
now = item;
|
||||||
if (nowText && !(nowText instanceof Array))
|
|
||||||
nowText = nowText[list[i]];
|
|
||||||
}
|
}
|
||||||
if (nowText && !(nowText instanceof Array))
|
|
||||||
nowText = nowText[list.at(-1)!];
|
|
||||||
|
|
||||||
const last = now.list[list.at(-1)!];
|
const last = now.list[list.at(-1)!];
|
||||||
if (last) {
|
if (last) {
|
||||||
|
const desc = last.description;
|
||||||
|
const text = desc ? desc.split('\n') : ['请选择设置'];
|
||||||
|
|
||||||
this.displayInfo.push({
|
this.displayInfo.push({
|
||||||
item: last,
|
item: last,
|
||||||
text: nowText instanceof Array ? nowText : ['请选择设置'],
|
text,
|
||||||
list: now.list
|
list: now.list
|
||||||
});
|
});
|
||||||
if (last.value instanceof MotaSetting) {
|
if (last.value instanceof MotaSetting) {
|
||||||
@ -445,7 +455,7 @@ mainSetting
|
|||||||
new MotaSetting().register(
|
new MotaSetting().register(
|
||||||
'mapScale',
|
'mapScale',
|
||||||
'小地图楼传缩放',
|
'小地图楼传缩放',
|
||||||
300,
|
100,
|
||||||
COM.Number,
|
COM.Number,
|
||||||
[50, 1000, 50]
|
[50, 1000, 50]
|
||||||
)
|
)
|
||||||
@ -471,7 +481,11 @@ loading.once('coreInit', () => {
|
|||||||
'utils.betterLoad': !!storage.getValue('utils.betterLoad', true),
|
'utils.betterLoad': !!storage.getValue('utils.betterLoad', true),
|
||||||
'utils.autoScale': !!storage.getValue('utils.autoScale', true),
|
'utils.autoScale': !!storage.getValue('utils.autoScale', true),
|
||||||
'fx.paraLight': !!storage.getValue('fx.paraLight', true),
|
'fx.paraLight': !!storage.getValue('fx.paraLight', true),
|
||||||
'fx.frag': !!storage.getValue('fx.frag', true)
|
'fx.frag': !!storage.getValue('fx.frag', true),
|
||||||
|
'ui.mapScale': storage.getValue(
|
||||||
|
'ui.mapScale',
|
||||||
|
isMobile ? 300 : Math.floor(window.innerWidth / 600) * 50
|
||||||
|
)
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
@ -481,3 +495,25 @@ hook.on('reset', () => {
|
|||||||
'action.autoSkill': flags.autoSkill ?? true
|
'action.autoSkill': flags.autoSkill ?? true
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
interface SettingTextData {
|
||||||
|
[x: string]: string[] | SettingTextData;
|
||||||
|
}
|
||||||
|
|
||||||
|
function getSettingText(obj: SettingTextData, key?: string) {
|
||||||
|
for (const [k, value] of Object.entries(obj)) {
|
||||||
|
const setKey = key ? key + '.' + k : k;
|
||||||
|
if (value instanceof Array) {
|
||||||
|
mainSetting.setDescription(setKey, value.join('\n'));
|
||||||
|
} else {
|
||||||
|
getSettingText(value, setKey);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
getSettingText(settingsText);
|
||||||
|
|
||||||
|
mainSetting
|
||||||
|
.setDescription('audio.bgmEnabled', `是否开启背景音乐`)
|
||||||
|
.setDescription('audio.bgmVolume', `背景音乐的音量`)
|
||||||
|
.setDescription('audio.soundEnabled', `是否开启音效`)
|
||||||
|
.setDescription('audio.soundVolume', `音效的音量`);
|
||||||
|
@ -103,6 +103,7 @@ import { GameUi } from '@/core/main/custom/ui';
|
|||||||
import { gameKey } from '@/core/main/init/hotkey';
|
import { gameKey } from '@/core/main/init/hotkey';
|
||||||
import { createChangable } from '@/plugin/ui/common';
|
import { createChangable } from '@/plugin/ui/common';
|
||||||
import { mainUi } from '@/core/main/init/ui';
|
import { mainUi } from '@/core/main/init/ui';
|
||||||
|
import { mainSetting } from '@/core/main/setting';
|
||||||
|
|
||||||
const props = defineProps<{
|
const props = defineProps<{
|
||||||
num: number;
|
num: number;
|
||||||
@ -118,7 +119,8 @@ const nowArea = ref(
|
|||||||
const nowFloor = ref(core.status.floorId);
|
const nowFloor = ref(core.status.floorId);
|
||||||
const noBorder = ref(true);
|
const noBorder = ref(true);
|
||||||
const tradition = ref(false);
|
const tradition = ref(false);
|
||||||
let scale = isMobile ? 1.5 : 3;
|
let scale =
|
||||||
|
((isMobile ? 1.5 : 3) * mainSetting.getValue('ui.mapScale', 100)) / 100;
|
||||||
let ox = 0;
|
let ox = 0;
|
||||||
let oy = 0;
|
let oy = 0;
|
||||||
let drawedThumbnail: Partial<Record<FloorIds, boolean>> = {};
|
let drawedThumbnail: Partial<Record<FloorIds, boolean>> = {};
|
||||||
|
@ -99,7 +99,7 @@ const display = shallowRef<SettingDisplayInfo[]>([]);
|
|||||||
const selectedItem = computed(() => display.value.at(-1)?.item);
|
const selectedItem = computed(() => display.value.at(-1)?.item);
|
||||||
const update = ref(false);
|
const update = ref(false);
|
||||||
|
|
||||||
const displayer = new SettingDisplayer(setting, text);
|
const displayer = new SettingDisplayer(setting);
|
||||||
displayer.on('update', (stack, dis) => {
|
displayer.on('update', (stack, dis) => {
|
||||||
display.value = dis;
|
display.value = dis;
|
||||||
update.value = !update.value;
|
update.value = !update.value;
|
||||||
|
Loading…
Reference in New Issue
Block a user