设为首页收藏本站|繁體中文

Project1

 找回密码
 注册会员
搜索
查看: 3460|回复: 2
打印 上一主题 下一主题

[交流讨论] RPG Maker MV 的源码研究 其二

[复制链接]

Lv3.寻梦者

梦石
0
星屑
1912
在线时间
1554 小时
注册时间
2013-4-13
帖子
917
跳转到指定楼层
1
发表于 2019-8-11 07:59:25 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

加入我们,或者,欢迎回来。

您需要 登录 才可以下载或查看,没有帐号?注册会员

x
研究源码需要一些额外的辅助手段
因为代码并不是从上一直写到下的
而是跳跃的, 所以必须要有一个工具帮你做一些全局搜索
推荐使用Visual Studio Code来作为你的编辑器
它强大, 颜值高, 易拓展, 你值得拥有.
==================================
第一章 插件管理者: 就算突破常规, 尔等仍为我掌控

在入口文件真正执行SceneManager.run(Scene_Boot)开启我们的游戏循环之前
还执行了PluginManager.setup($plugins)

先说说PluginManager
PluginManager和其他Manager一样是一个静态类
说白了就是个全局变量
不过在MV里面, 全部都是以 function xxxManager() {} 的方法声明的
实际上这些PluginManager完全没有用到function的功能,
所以只需要写const PluginManager = {} 就可以了
接下来PluginManager定义了四个内部变量
  1. PluginManager._path = 'js/plugins/';
  2. PluginManager._scripts = [];
  3. PluginManager._errorUrls = [];
  4. PluginManager._parameters = {};
复制代码

先不去管他, 等到具体使用时候再分析
这里可以直接初始化为 const PluginManager = {_path: 'js/plugins/'...}就可以了

接下来我们看下它的方法:

  1. PluginManager.setup
  2. PluginManager.checkErrors
  3. PluginManager.parameters
  4. PluginManager.setParameters
  5. PluginManager.loadScript
  6. PluginManager.onError
复制代码

首先setup方法用来加载插件配置
插件配$plugins是在plugin.js里定义的
我们通过工具内的插件管理器可以对这个文件进行修改

然后我们来看这个方法内部

  1. PluginManager.setup = function (plugins) {
  2.     plugins.forEach(function (plugin) {
  3.         if (plugin.status && !this._scripts.contains(plugin.name)) {
  4.             this.setParameters(plugin.name, plugin.parameters);
  5.             this.loadScript(plugin.name + '.js');
  6.             this._scripts.push(plugin.name);
  7.         }
  8.     }, this);
  9. };
复制代码

forEach是一个高阶函数, 它的作用类似for循环
具体使用方法参考: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/forEach
这段代码翻译为自然语言就是:
  1. 对于plugins里的每一个plugin:
  2.     我们判断它是否是开启状态并且还未被加载过, 如果是则继续, 否则跳过这个plugin
  3.      我们调用setParameters来记录plugin的参数
  4.      我们将plugin指向的脚本加载到网页中
  5.      我们标记这个plugin已经被加载过了
复制代码

下面我们将继续研究setParameters和loadScript方法

  1. PluginManager.parameters = function (name) {
  2.     return this._parameters[name.toLowerCase()] || {};
  3. };

  4. PluginManager.setParameters = function (name, parameters) {
  5.     this._parameters[name.toLowerCase()] = parameters;
  6. };
复制代码



这两个方法可以放到一起说, 其实不难看出这两个方法只是_parameters的setter和getter了
由于PluginManager是一个全局对象, 所以插件里的配置其实是可以动态读取甚至修改的
我们也是通过这种方法读取插件里parameters的配置的

继续看加载放啊loadScript

  1. PluginManager.loadScript = function (name) {
  2.     var url = this._path + name;
  3.     var script = document.createElement('script');
  4.     script.type = 'text/javascript';
  5.     script.src = url;
  6.     script.async = false;
  7.     script.onerror = this.onError.bind(this);
  8.     script._url = url;
  9.     document.body.appendChild(script);
  10. };
复制代码

这句话是做什么的呢?
我们知道网页加载js文件是通过js标签来实现的
例如
  1. <script type='text/javascript' src='./app.js'>
复制代码

而js代码又可以通过appendChild为html代码添加标签于是这段代码的本质就是在网页的body里的最下面添加一个新的script标签
比如初始工程运行时, 你打开F12, 会在element里面看到当前的网页结构
你会发现和我们的index.html并不完全一样
比如在
  1. <script type="text/javascript" src="js/main.js"></script>
复制代码
下面就会多出来
  1. <script type="text/javascript" src="js/plugins/Community_Basic.js"></script>
  2. <script type="text/javascript" src="js/plugins/MadeWithMv.js"></script>
复制代码

实际上这两个标签就是loadScript方法添加的
但这里面还有两个需要说明的
    script.async = false;
这个代表脚本不是异步加载的, 这样只有这个脚本加载完毕后面的代码才会继续执行
同步/异步在js世界里是一个很需要关注的地方
尤其是加载外部资源的时候
    script.onerror = this.onError.bind(this);

这个是添加了一个错误handler
如plugin的脚本出错了, 就会将这个错误记录下去
在SceneManager执行初始化检查的时候
如果有错误就会展示一个错误界面给大家看
如果经常使用plugin的制作者肯定很熟悉那个画面啦

这样最简单的manager, PluginManager我就水完了~




评分

参与人数 1+1 收起 理由
cheese401 + 1 塞糖

查看全部评分

夏普的道具店

塞露提亚-道具屋的经营妙方同人作品
发布帖:点击这里

Lv2.观梦者

梦石
0
星屑
900
在线时间
75 小时
注册时间
2017-7-10
帖子
27
2
发表于 2019-8-11 09:05:26 | 只看该作者
你尝试去把里面的生命周期整理一下,会很有帮助
回复 支持 反对

使用道具 举报

Lv4.逐梦者

梦石
0
星屑
14696
在线时间
718 小时
注册时间
2011-7-16
帖子
1428

开拓者

3
发表于 2019-8-12 11:46:36 | 只看该作者
不错,学习到了很多的知识
RMMV网络插件,开源免费,内含服务器端,无需强制登录,云数据,弹幕,云存档,排名,兑换码,版本检测,可自由上架下架删除。q群399090587
免打包运行MV游戏,云游戏,安卓App雷神游戏厅,在线玩游戏,上传下载游戏
开源游戏:重装机兵之重装归来【RMMV制作】全球首款按照美剧分季分集的方式发布的游戏
体素画 -- MV画3D像素图的画板
RMMV显示3D模型和场景的插件
RMMV显示spine骨骼动画的插件
RMMV秘密通道插件
突破敌群数量上限8个的插件
在rmmv中显示gif动态图片的插件
一款可以在mv游戏界面的任意位置显示任意文字的插件
RMMV Toast 插件 带物品得失提示,可以设置开启关闭 兼容yep itemcore
制作一个改名卡道具插件、调整标题页面菜单的插件、在标题页面之前显示大段文字的插件、标题页面显示版本号的插件
物品得失自动提示自动上色自动换行插件
我的Q群 663889472
另外,我的插件、范例、游戏都在这里
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

拿上你的纸笔,建造一个属于你的梦想世界,加入吧。
 注册会员
找回密码

站长信箱:[email protected]|手机版|小黑屋|无图版|Project1游戏制作

GMT+8, 2025-1-27 07:02

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表