区域作为图层使用
使用区域id作为额外的图片展示,具体代码如下JAVASCRIPT 代码
/*:
* @plugindesc 区域图层插件
* @author 雪在燃
* v:1.2
* @help
*区域图层插件
* 使用地图备注编写打开该功能(注,设置为任意都将打开功能,只有删除该行才会关闭功能)
* 以下是一个事例
*
* 代表区域1会将img/system/pictures/light展示出来,并且不透明度为234(0~255,数字越低越不透明),z坐标为5(0~10,越高则越高,降低则会被主角或npc遮盖)
*/
(function(){
var old = Spriteset_Map.prototype.createLowerLayer;
Spriteset_Map.prototype.createLowerLayer = function(){
old.call(this);
if($dataMap.meta.xzr_region){
this.createShadowEx();
}
};
Spriteset_Map.prototype.createShadowEx = function(){
var data = null;//JSON.parse($dataMap.mate.set_region);
for(var x = 0; x < $gameMap.width() ; x++){
for(var y = 0; y < $gameMap.height() ; y++){
var id = $gameMap.regionId(x, y);
if(id != 0){
if($dataMap.meta["set_regionID_" + id]){
data = JSON.parse($dataMap.meta["set_regionID_" + id]);
var _sprite = new Sprite_Shadow(x, y, id, data);
this._tilemap.addChild(_sprite);
}
}
}
}
}
function Sprite_Shadow(x, y, id){
this.initialize.apply(this, arguments);
}
Sprite_Shadow.prototype = Object.create(Sprite.prototype);
Sprite_Shadow.prototype.constructor = Sprite_Shadow;
Sprite_Shadow.prototype.initialize = function(x, y, id,data){
Sprite.prototype.initialize.call(this);
this.bitmap = (ImageManager.loadPicture(data));
this.opacity = data;
this._dataZ = data;
this._cWidth = 0;
this._cHeight = 0;
this._realX = x;
this._realY = y;
this._isReady = false;
this.z = parseInt(id);
}
Sprite_Shadow.prototype.update = function(){
Sprite.prototype.update.call(this);
if(!this._isReady && ImageManager.isReady()){
this._cWidth = (this.bitmap.width - 48) / 2;
this._cHeight = (this.bitmap.height - 48) / 2;
this._isReady = true;
}
this.updatePosition();
}
Sprite_Shadow.prototype.updatePosition = function()
{
this.z = this._dataZ;
this.x = this.screenX();
this.y = this.screenY();
}
Sprite_Shadow.prototype.scrolledX = function(){
return $gameMap.adjustX(this._realX - 0.5);
};
Sprite_Shadow.prototype.scrolledY = function(){
return $gameMap.adjustY(this._realY - 1);
};
Sprite_Shadow.prototype.screenX = function(){
var tw = $gameMap.tileWidth();
return Math.round((this.scrolledX() * tw + tw / 2)-this._cWidth);
};
Sprite_Shadow.prototype.screenY = function(){
var th = $gameMap.tileHeight();
return Math.round((this.scrolledY() * th + th)-this._cHeight);
};
})();
初衷是作为光影脚本,如今并没有素材来实现这个功能wwww
可以把图片作为图层插入到游戏里面,图片要是正方形,并且不能小于48*48,图片会以区域所在位置居中
https://rpg.blue/data/attachment/forum/201711/05/000313qunvuoueykn6nhfi.pnghttps://rpg.blue/data/attachment/forum/201711/05/000314g0dkkk0kksrvt3zo.png
用它来实现影子是个不错的选择!光效勉勉强强应该也可以用它实现,不过需要一个圆形的渐变光图片作为素材,作为额外图层可以用来修饰地图!
对窗户用简单的光源修饰后~
https://rpg.blue/data/attachment/forum/201711/05/115849kk7czxs3xi7xxbwf.png
本帖来自P1论坛作者雪在燃,因Project1站服务器在国外有时候访问缓慢不方便作者交流学习,经联系P1站长fux2同意署名转载一起分享游戏制作经验,共同为国内独立游戏作者共同创造良好交流环境,原文地址:https://rpg.blue/forum.php?mod=viewthread&tid=403790若有侵权,发帖作者可联系底部站长QQ在线咨询功能删除,谢谢。
页:
[1]