内容简介:同步的方式读取样式表文件,如果样式表不存在,那么创建一个style元素,设置样式表内容,并添加到head的尾部我们用它来管理图片和html模板素材;转化为base64字符串后,赋值给
同步的方式读取样式表文件,如果样式表不存在,那么创建一个style元素,设置样式表内容,并添加到head的尾部
!function() { let styleStr = fs.readFileSync(__dirname + '/assets/css/style.css', 'utf8') const styleEl = document.getElementById('gameStylesheet') if (styleEl) return const newStyleEl = document.createElement('style') newStyleEl.type = 'text/css' newStyleEl.id = 'gameStylesheet' newStyleEl.innerHTML = styleStr document.head.appendChild(newStyleEl) }() 复制代码
创建资源对象
我们用它来管理图片和html模板素材; icons 属性存储图片对象, isIconsLoaded 标识图片资源是否已加载完成;
const source = { icons: {}, isIconsLoaded: false } 复制代码
加载图片资源
转化为base64字符串后,赋值给 source.base64Strs ,这里采用立即执行的匿名函数来一次性转化buffer为base64字符串
source.base64Strs = (() => { const bufIcons = { blockEnd: fs.readFileSync(__dirname + '/assets/img/back.png'), blockFront: fs.readFileSync(__dirname + '/assets/img/front.png'), bomb: fs.readFileSync(__dirname + '/assets/img/bomb.png'), flag: fs.readFileSync(__dirname + '/assets/img/flag-color.png') }, rtnObj = {} Object.keys(bufIcons).forEach(_ => rtnObj[_] = `data:image/png;base64,${bufIcons[_].toString('base64')}` ) return rtnObj })() 复制代码
加载单个图标文件
这将返回一个承诺对象
source.loadSingleIcon = function (key) { return new Promise(resolve => { const image = new Image() image.onload = () => { image.onload = null resolve({ [key]: image }) } image.src = this.base64Strs[key] }) } 复制代码
加载所有的图标文件
如果图标已经被加载,那么返回一个resolve的承诺,否则加载所有图标资源并赋值给资源对象的icons属性
source.loadIcons = function () { if (this.isIconsLoaded) return Promise.resolve() return Promise.all(Object.keys(this.base64Strs).map(_ => this.loadSingleIcon(_) )).then(values => { this.isIconsLoaded = true values.forEach(item => this.icons = { ...this.icons, ...item }) }) } 复制代码
到这里我们的扫雷游戏资源对象的编写已经结束了,大家有什么不理解的地方欢迎评论交流;明天我将带大家实现方块类的编写;第一次写技术文章,有什么不到之处还请见谅;
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
勇敢新世界‧互聯網罪與罰
許煜、劉細良 / CUP / 2005 / $48
我天天上網數小時,為的是要在節目裡面介紹世界的最新動態,尤其是網絡這個世界本身日新月異的變化。所以我不可能不注意到BT、共享軟件、 Wikipedia、網絡監管等各種影響政治、社會、經濟及文化的重要網絡現象。但是我發現市面上一直沒有一本內容充實全面,資料切時的中文參考書,直到這本《互聯網罪與罰》。而且,最大的驚喜是它易讀好看,簡直就像故事書。 梁文道 鳳凰衛視 《網羅天下......一起来看看 《勇敢新世界‧互聯網罪與罰》 这本书的介绍吧!