Screeps 轻量化的模块框架

Screeps 轻量化的模块框架

该设计下,每个模块(API),需要实现三个方法:mount(), work(), lateWork()

// src/api/sample.ts
export const sampleAPI: APIBase = {
    mount() {
        // 初次载入时,初始化这个模块用到的存储空间,以及在原型上挂载扩展,或者在global上挂载一些公共的方法,属性
    },
    work() {
        // 日常工作的入口,管理归属于这个模块的所有对象,如果涉及creep,一般分为creep数量控制和creep运行两个方法
        // 每个模块之间相互独立,不依赖先后顺序
    },
    lateWork() {
        // 收尾工作的入口,运行建筑,通用服务模块,比如spawn模块,在收尾时能够处理本tick新添加的任务
    }
}

例如spawn任务处理模块:这个模块会处理其他模块添加进来的孵化任务,安排spawn进行工作,同时也会管理一些creep来填充spawn以及extension

export const spawnManagerAPI: APIBase = {
    // 这是个通用的服务模块,对外提供接口,因此挂载在global上
    mount() {
        global.spawnManager = {
            // 任务相关
            clearSpawnTasks: clearSpawnTasks,
            addSpawnTask: addSpawnTask,
            popSpawnTask: popSpawnTask,
            peekSpawnTask: peekSpawnTask,
            creepNameQueueCache: {} // 初始化这个模块本身的存储空间
        }
    },
    work() {
        distributerNumberControl() // 控制填充creep的数量(包括添加孵化任务)
        runDistributeCreeps() // 运行所有该模块管辖的填充creep
    },
    lateWork() {
        handleSpawnTasks() // 处理孵化任务
    }
}

这种模式下,每个模块自行查找自己管辖的房间,建筑,creep,任务等对象,并做对应的操作,针对频繁使用的对象集合(比如:我控制的房间的集合),可以挂载在global上。

比如 runDistributeCreeps() 这个方法

function runDistributeCreeps() {
    // 最简便的写法
    const creeps = Object.values(Game.creeps).filter((creep) => (creep.memory.role === 'distributer'))
    // 避免重复查找的方法 —— 第一次查找creep的时候,遍历creep,按照role挂载到global上,之后取global.[role]即可
    // const creeps = global.distributers
    
    creeps.forEach((creep) => {
        // 处理每个creep具体的逻辑
    })
}

其他封装用的文件

// src/api/index.ts
import { sampleAPI } from './sample'
const APIs: APIBase[] = []
APIs.push(sampleAPI)

export default APIs
// src/apiHandler.ts
import APIs from './api'

export const apiHandler = {
    mount: () => {
        if (!global.mounted) {
            console.log(`重新挂载扩展 ${Game.time}`)
            APIs.forEach((api) => {
                api.mount()
            })
            global.mounted = true
        }
    },
    work: () => {
        APIs.forEach((api) => {
            api.work()
        })
    },
    lateWork: () => {
        APIs.forEach((api) => {
            api.lateWork()
        })
    }
}
// src/main.ts
import { apiHandler } from './apiHandler'
console.log("script reload on " + Game.time)
export const loop = () => {
    apiHandler.mount()
    apiHandler.work()
    apiHandler.lateWork()
}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,383评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,522评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,852评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,621评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,741评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,929评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,076评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,803评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,265评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,582评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,716评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,395评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,039评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,027评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,488评论 2 361
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,612评论 2 350

推荐阅读更多精彩内容