小 (→Protected方法获取) |
|||
第66行: | 第66行: | ||
====== Protected方法获取 ====== | ====== Protected方法获取 ====== | ||
<pre> | <pre> | ||
// $p 指 Packages | |||
$p.rhino.NativeJavaObject( | $p.rhino.NativeJavaObject( | ||
$p.rhino.ImporterTopLevel(Vars.mods.scripts.context), // 用于刷新缓存 | $p.rhino.ImporterTopLevel(Vars.mods.scripts.context), // 用于刷新缓存 |
2024年10月2日 (三) 18:21的最新版本
Mindustry的JS
Mindustry使用: Rhino
类似于node.js,它没有window
,document
等一系列变量
Rhino并没有完全支持es6的语法
Mindustry提供了一下全局变量:global.js
一些常用的变量
scriptName
: 当前脚本的名称(这会随脚本的变化而变化,建议:const { scriptName } = this;
)modName
: 当前Mod的名称(这会随mod的变化而变化,建议:const { modName } = this;
)print
: 打印日志extend
:
关于解构赋值
cosnt { a, b } = { a: 1, b: 2 };
特殊语法
new F/* functionName */ ( /* args */ ) { /* code */ }
其实就是F/* functionName */( /* args */ , { /* code */ } )
在最后面传了一个对象
所以你可以:
new extend(Block, "a block") { setBars() { print(this.barMap) } }
Getter & Setter
Getter: 你可以使用xxx.class
等价于xxx.getClass()
- 注意:
Vars.class
获取到的是Class类(或者直接报错),如果想要获取对应类对象 可以使用Vars.__javaObject__
Setter: 你可以使用cell.element = xxx
,这等价于cell.setElement(xxx)
一些小坑
一个函数接受所有方法
extend(BulletType, { hit(b, x, y) { print(b); } }
BulletType#hit(Bullet b)
和BulletType#hit(Bullet b, float x, float y)
都会调用上面的hit方法,
所以x
,y
可能为undefined
for ... of ...
不能迭代java的Iterable
可以使用下面的代码
定义函数
function *itep(map){ let iterator = map.iterator() // 这里用try是因为hasNext在有的类中是字段 try { while (true) yield iterator.next() } catch(e) {} }
使用方法
let map = new IntMap() map.put(11, 3931) for (let entry of new iter(map)) { // new 不能省 print(entry) }
Protected方法获取
// $p 指 Packages $p.rhino.NativeJavaObject( $p.rhino.ImporterTopLevel(Vars.mods.scripts.context), // 用于刷新缓存 Core.assets, // 对象 $p.arc.assets.AssetManager, // 类对象 true // 是否包含protected ).addAsset // 获得protected