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

Project1

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

[RMVA发布] 事件在人物前后时的遮挡……

[复制链接]

Lv4.逐梦者

梦石
2
星屑
5520
在线时间
2564 小时
注册时间
2012-2-9
帖子
990

开拓者

跳转到指定楼层
1
发表于 2016-8-18 22:01:05 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

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

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

x
本帖最后由 garfeng 于 2016-8-18 23:24 编辑

当人物坐标y比事件大时,即人物更靠近屏幕,应该遮挡住事件,而人物y比事件小,也就是距离屏幕更远时,人物被事件遮挡。32x32的二头身有微弱的这个问题,32x48的三头身,这个问题则非常严重。
上次做 拐跑魔王被这个问题搞跪了,只能在事件周围设置一圈不可通行来偷偷避过去。

可能讲不清楚,就是如下图红框部分的效果:





红框右侧为普通事件,在人物下方就一直在人物下方。

用事件绕过去。

代码:

RUBY 代码复制
  1. # 使用方法,添加事件,在事件名里添加 ol
  2. # y相同时,由事件页那里的高度来决定遮挡。
  3.  
  4. class Game_Event < Game_Character
  5.  
  6.   def check_pos_of_player
  7.     if @page
  8.       origin_priority = @page.priority_type
  9.     else
  10.       origin_priority = 1
  11.     end
  12.     if !@overlay_set
  13.       return origin_priority
  14.     end   
  15.     dy = $game_player.real_y - self.real_y
  16.     if  dy > 0 # 人挡住了事件
  17.       return 0
  18.     elsif dy < 0 # 事件挡住了人
  19.       return 2
  20.     end
  21.     return origin_priority
  22.   end
  23.  
  24.   alias overlay_back_setup_page_settings setup_page_settings
  25.   def setup_page_settings
  26.     overlay_back_setup_page_settings
  27.     if self.instance_variable_get(:@event).name =~ /ol/
  28.       #p self.instance_variable_get(:@event).name
  29.       @overlay_set = true
  30.     else
  31.       @overlay_set = false
  32.     end
  33.   end
  34.  
  35.   #--------------------------------------------------------------------------
  36.   # ● 更新画面
  37.   #--------------------------------------------------------------------------
  38.   alias overlay_back_update update
  39.   def update
  40.     @priority_type = check_pos_of_player
  41.     overlay_back_update
  42.   end
  43. end

评分

参与人数 1星屑 +10 收起 理由
phunmung5173 + 10 精品文章

查看全部评分

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

本版积分规则

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

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

GMT+8, 2024-5-4 19:52

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

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