// 这里包含所有插件导出的函数及变量声明,声明的函数会在类型标注中标注到core上 type Ref = { value: T; }; type DragFn = (x: number, y: number, e: MouseEvent | TouchEvent) => void; type CanParseCss = keyof { [P in keyof CSSStyleDeclaration as CSSStyleDeclaration[P] extends string ? P extends string ? P : never : never]: CSSStyleDeclaration[P]; }; interface PluginDeclaration extends PluginUtils, PluginUis, PluginUse, SkillTree, MiniMap { /** * 添加函数 例:添加弹出文字,像这个就可以使用core.addPop或core.plugin.addPop调用 * @param px 弹出的横坐标 * @param py 弹出的纵坐标 * @param value 弹出的文字 */ addPop(px: number, py: number, value: string): void; /** 添加变量 例:所有的正在弹出的文字,像这个就可以使用core.plugin.pop获取 */ pop: any[]; /** 状态栏信息,取反后刷新状态栏 */ readonly statusBarStatus: Ref; /** 检查标记的怪物,取反后更新显示信息 */ readonly checkMarkedStatus: Ref; /** * 添加一个动画 * @param fn 要添加的函数 */ addAnimate(fn: (time: number) => void); /** * 移除一个动画 * @param fn 要移除的函数 */ removeAnimate(fn: (time: number) => void); /** * 检查被标记怪物的状态 */ checkMarkedEnemy(): void; /** * 标记怪物 * @param id 怪物id */ markEnemy(id: EnemyIds): void; /** * 是否标记过某个怪物 */ hasMarkedEnemy(id: EnemyIds): void; /** * 取消标记过某个怪物 */ unmarkEnemy(id: EnemyIds): void; /** * 重置设置信息 */ resetSettings(): void; /** * 重置变量的设置信息 */ resetFlagSettings(): void; } interface PluginUtils { /** * 判定一个值是否不是undefined或null * @param value 要判断的值 */ has(value: T): value is NonNullable; /** * 根据伤害大小获取颜色 * @param damage 伤害大小 */ getDamageColor(damage: number): string; /** * 解析css字符串为CSSStyleDeclaration对象 * @param css 要解析的css字符串 */ parseCss(css: string): Partial>; /** * 弹出一段提示 * @param text 提示信息 */ tip( type: 'warn' | 'info' | 'success' | 'error' | 'warning' | 'loading', text: string ): void; /** * 开始一个追逐战 * @param index 追逐战索引 */ startChase(index: number): Promise; /** * 自动修复特殊boss战的录像 * @param isStart 是否要开始修剪录像 */ autoFixRouteBoss(isStart?: boolean); /** * 滑动数组 * @param arr 数组 * @param delta 偏移量,正数表示向右滑动,负数表示向左滑动 */ slide(arr: T[], delta: number): T[]; } interface PluginUis { /** 怪物手册的怪物详细信息的初始位置 */ bookDetailPos: number; /** 怪物手册详细信息展示的怪物 */ bookDetailEnemy: DetailedEnemy; /** ui是否使用渐变 */ readonly transition: Ref; /** 手册是否打开 */ readonly bookOpened: Ref; /** 道具栏是否打开 */ readonly toolOpened: Ref; /** 装备栏是否打开 */ readonly equipOpened: Ref; /** 是否显示状态栏 */ readonly showStatusBar: Ref; /** 设置界面是否打开 */ readonly settingsOpened: Ref; /** 是否正在进行章节显示 */ readonly chapterShowed: Ref; /** 章节显示的内容 */ readonly chapterContent: Ref; /** 百科全书是否打开了 */ readonly descOpened: Ref; /** 技能查看界面是否打开 */ readonly skillOpened: Ref; /** 技能树界面是否打开 */ readonly skillTreeOpened: Ref; /** 楼传界面是否打开 */ readonly flyOpened: Ref; /** 是否展示标记的怪物 */ readonly showMarkedEnemy: Ref; /** ui栈 */ readonly uiStack: Ref; /** * 显示章节 * @param chapter 显示的文字 */ showChapter(chapter: string): void; /** * 打开技能查看界面 */ openSkill(): void; } interface PluginUse { /** 是否是移动设备 */ readonly isMobile: boolean; /** * 向一个元素添加拖拽事件 * @param ele 目标元素 * @param fn 推拽时触发的函数,传入x y和鼠标事件或点击事件 * @param ondown 鼠标按下时执行的函数 * @param global 是否全局拖拽,即拖拽后鼠标或手指离开元素后是否依然视为正在拖拽 */ useDrag( ele: HTMLElement, fn: DragFn, ondown?: DragFn, onUp?: (e: MouseEvent | TouchEvent) => void, global: boolean = false ): void; /** * 去除一个全局拖拽函数 * @param fn 要去除的函数 */ cancelGlobalDrag(fn: DragFn): void; /** * 当触发滚轮时执行函数 * @param ele 目标元素 * @param fn 当滚轮触发时执行的函数 */ useWheel( ele: HTMLElement, fn: (x: number, y: number, z: number, e: WheelEvent) => void ): void; /** * 当鼠标或手指松开时执行函数 * @param ele 目标元素 * @param fn 当鼠标或手指松开时执行的函数 */ useUp(ele: HTMLElement, fn: DragFn): void; } interface SkillTree { skills: Record; /** * 获取技能等级 * @param skill 技能索引 */ getSkillLevel(skill: number): number; /** * 根据索引获取技能 * @param index 索引 */ getSkillFromIndex(index: number): Skill; /** * 获取技能的消耗 * @param skill 技能 */ getSkillConsume(skill: number): number; /** * 升级技能 * @param skill 技能索引 */ upgradeSkill(skill: number): boolean; /** * 保存技能树等级 */ saveSkillTree(): number[]; /** * 加载技能树等级 * @param data 等级信息 */ loadSkillTree(data: number[]): void; } interface MiniMap { /** * 切分区域 */ splitArea(): void; } interface Study { /** * 学习一个怪物技能 * @param enemy 被学习的怪物 * @param num 技能的索引 */ studySkill(enemy: Enemy, num: number): void; } type Chapter = 'chapter1' | 'chapter2'; interface Skill { index: number; title: string; desc: string[]; consume: string; front: LocArr[]; loc: LocArr; max: number; effect: string[]; } type Forward = { [K in keyof T as T[K] extends Function ? K extends `_${string}` ? never : K : never]: T[K]; }; type ForwardKeys = keyof Forward;