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

Project1

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

[已经解决] 怎么做环条式血条

[复制链接]

Lv3.寻梦者

梦石
0
星屑
2777
在线时间
510 小时
注册时间
2012-6-17
帖子
486
跳转到指定楼层
1
发表于 2021-3-10 17:44:10 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

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

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

x
如图。本意是半环,hp和mp。站上搜索环式没有,有见过这样的血条脚本吗,或提供下思路

问渠那得清如许为有源头活水来点击这里了解《都市天师》

Lv4.逐梦者

梦石
2
星屑
13398
在线时间
2305 小时
注册时间
2011-6-4
帖子
618
2
发表于 2021-3-10 17:51:26 | 只看该作者
自己在自己的坑里实现过类似的,但是又改回长条了。和长条血条实现的方式差不多
BUG反馈请加QQ 529283039
水友群 917854767

回复 支持 反对

使用道具 举报

Lv4.逐梦者

梦石
0
星屑
7981
在线时间
1183 小时
注册时间
2007-7-29
帖子
2055
3
发表于 2021-3-10 18:24:29 | 只看该作者
老实说,这种血条在rmxp不常看到主要两个原因。
1. 曲型血条真的不好画,需要对一些几何方程+rmxp bitmap熟悉才画得出,不像线性那么明了。
2. 用rmxp画几何图那性能本就惨不忍睹,不过后来有外挂DLL解决了这个问题,我以前帮天圣写图鉴脚本时就用到了该脚本,具体什么名称我真忘记了。

在以上两大限制的情况下,只能走一种古老可是不得不说能成的方法,那就是准备左右各101张血条,分别是0到100%,然后根据hp和mp的数值%显示对应的图。

点评

cos(a)^2 + sin(a)^2 = 1,然后y/x = tan(a),就这两个公式全部解决  发表于 2021-3-11 02:14
回复 支持 反对

使用道具 举报

Lv3.寻梦者

梦石
0
星屑
2777
在线时间
510 小时
注册时间
2012-6-17
帖子
486
4
 楼主| 发表于 2021-3-10 18:45:26 | 只看该作者
真·可乐 发表于 2021-3-10 17:51
自己在自己的坑里实现过类似的,但是又改回长条了。和长条血条实现的方式差不多 ...

本身bitmap没有画圆形的方法啊。怎么差不多?能分享一下吗

问渠那得清如许为有源头活水来点击这里了解《都市天师》
回复 支持 反对

使用道具 举报

Lv3.寻梦者

梦石
0
星屑
2777
在线时间
510 小时
注册时间
2012-6-17
帖子
486
5
 楼主| 发表于 2021-3-10 18:49:01 | 只看该作者
enghao_lim 发表于 2021-3-10 18:24
老实说,这种血条在rmxp不常看到主要两个原因。
1. 曲型血条真的不好画,需要对一些几何方程+rmxp bitmap熟 ...

谢谢思路。虽然也不用图片的方法,但理解了方向。

问渠那得清如许为有源头活水来点击这里了解《都市天师》
回复 支持 反对

使用道具 举报

Lv5.捕梦者

梦石
0
星屑
22148
在线时间
1139 小时
注册时间
2016-1-6
帖子
3404
6
发表于 2021-3-10 19:17:36 | 只看该作者
我想到一个方法,就是用图片显示,假设把 0%~100% 分成11张图片(分的有点粗),当前 hp 和 mp 符合哪个比例就显示哪张图片,楼主你看这个方法行得通吗?
回复 支持 反对

使用道具 举报

Lv4.逐梦者

梦石
0
星屑
6483
在线时间
119 小时
注册时间
2020-1-8
帖子
234
7
发表于 2021-3-10 20:46:41 | 只看该作者
大概的思路

纯脚本绘制话,估计win32api,太难了;直接rgss的话,效率……

一张图片(如你给出的图)的话,看你是 简单的横截线 还是经过的圆心的线
横截线就如条形一样 算比例 直接blt

经过圆心的线的话,以角度表示血量多少
先算下圆环外员的交点,blt需要的矩形(自交点以下),这时会多出个很小的三角形的区域
clear_rect(就是填充透明色) 数学问题  清除掉多余的三角形区域

另类的方法
圆环旋转,只适用单色背景
首先大圆环 左边红 右边背景色 分成2张图片
小圆环 右边蓝 左边背景色 也是分成2张图片
红蓝blt
背景色的2张图,分别生成sprite
根据血量、蓝量旋转覆盖红环、蓝环


回复 支持 反对

使用道具 举报

Lv5.捕梦者 (版主)

遠航の猫咪

梦石
3
星屑
23191
在线时间
2387 小时
注册时间
2005-10-15
帖子
1166

开拓者

8
发表于 2021-3-11 01:59:49 | 只看该作者
本帖最后由 SailCat 于 2021-3-11 02:20 编辑

RMXP的bitmap处理效率不比RMVA差的,这个我很明确的测试过并得出结论
RMXP每帧纯做set_pixel能做8000次,你觉得你的血条里会有8000个像素点吗?就算有,能有16000个像素点吗?血不会每帧更新,刷血条时损失1帧又不是什么大不了的事。要知道不论RMXP还是RMVA,draw_text都是个奇慢的操作,你还经常一帧做几十次呢。

所以觉得RGSS直接做不了的,都是算法问题

有简易实现和完美实现两个办法
简易实现:特点是速度快,缺点是血条的水面是平的,不是正对圆心角的斜线。

首先制作2个空血条bitmap,作为底图传送成精灵,ox, oy设在圆心(也就是两个bitmap的左中点和右中点)(假设环直径100,底图都是50X100大小,例为血(50,50)和蓝(0,50)))
把它们的x, y设置在一起,显示出来就拼起来了
然后制作2个满血条bitmap,作为面图(z更高)传送成精灵,ox, oy,x,y也一起和前面的重合
然后根据你的血量蓝量百分比,改变两面图精灵的src_rect为高度的百分比,从底端算起,比如22%血,就传送(0,78,50,22)为血,40%蓝,就传送(0,60,50,40)为蓝
完毕了。

完美实现,底图一样,可简单用精灵做
面图的bitmap需要自己绘制:
血条直径100的话,需要执行至多100次bitmap#fill_rect(由于水平做比垂直做快,建议水平做)
以下改的是Window_Menustatus
总之不算难,效率也不差,水平做fill_rect一帧极限我记得是720次。垂直120次
这里有些复杂的三角函数运算,实际没那么多,反正在菜单中帧数大概36-37左右(我能说是被draw_text拖的么)

RUBY 代码复制
  1. #--------------------------------------------------------------------------
  2.   # ● 刷新
  3.   #--------------------------------------------------------------------------
  4.   def refresh
  5.     self.contents.clear
  6.     @item_max = $game_party.actors.size
  7.     for i in 0...$game_party.actors.size
  8.       x = 64
  9.       y = i * 116
  10.       actor = $game_party.actors[i]
  11.       draw_actor_graphic(actor, x - 40, y + 80)
  12.       draw_actor_name(actor, x, y)
  13.       draw_actor_class(actor, x + 144, y)
  14.       draw_actor_level(actor, x, y + 32)
  15.       draw_actor_state(actor, x + 90, y + 32)
  16.       draw_actor_exp(actor, x, y + 64)
  17.       draw_actor_hp(actor, x + 236, y + 32)
  18.       draw_actor_sp(actor, x + 236, y + 64)
  19.       outer = 50 # 外径
  20.       inner = 40 # 内径
  21.       ox = 300 # 血条ox
  22.       oy = i * 116 + 50 # 血条oy
  23.       hp_rate = actor.hp * 100.0 / actor.maxhp # HP 比例
  24.       sp_rate = actor.sp * 100.0 / actor.maxsp # SP 比例
  25.       hx_rate = hp_rate == 50 ? 0.0 :
  26.         Math.tan((0.5 + hp_rate * 0.01) * Math::PI)
  27.       sx_rate = sp_rate == 50 ? 0.0 :
  28.         Math.tan((0.5 - sp_rate * 0.01) * Math::PI)
  29.       hp_color = Color.new(232,90,90,255)
  30.       sp_color = Color.new(90,90,232,255)
  31.       outer.downto(-outer) do |by|
  32.         fy = by.to_f
  33.         x_in = (fy.abs >= inner ? 0 : inner * Math.sqrt([1 - (fy / inner) ** 2,
  34.           0].max)+0.5).to_i
  35.         x_out = (outer * Math.sqrt([1 - (fy / outer) ** 2, 0].max)+0.5).to_i
  36.         if by == 0
  37.           if hp_rate >= 50
  38.             contents.fill_rect(ox - x_out, oy, x_out - x_in, 1, hp_color)
  39.           end
  40.           if sp_rate >= 50
  41.             contents.fill_rect(ox + x_in, oy, x_out - x_in, 1, sp_color)
  42.           end
  43.           next
  44.         end
  45.         hx = hx_rate == 0.0 ? -999 * by : (fy / hx_rate).to_i
  46.         sx = sx_rate == 0.0 ? 999 * by : (fy / sx_rate).to_i
  47.         if hx.between?(-x_out, -x_in)
  48.           if hp_rate >= 50
  49.             contents.fill_rect(ox - x_out, oy + by, hx + x_out, 1,  hp_color)
  50.           else
  51.             contents.fill_rect(ox + hx, oy + by, -x_in - hx, 1, hp_color)
  52.           end
  53.         elsif (hx > -x_in) ^ (hp_rate <= 50)
  54.           contents.fill_rect(ox - x_out, oy + by, x_out - x_in, 1, hp_color)
  55.         end
  56.         if sx.between?(x_in, x_out)
  57.           if sp_rate >= 50
  58.             contents.fill_rect(ox + sx, oy + by, x_out - sx, 1,  sp_color)
  59.           else
  60.             contents.fill_rect(ox + x_in, oy + by, sx - x_in, 1, sp_color)
  61.           end
  62.         elsif (sx < x_in) ^ (sp_rate <= 50)
  63.           contents.fill_rect(ox + x_in, oy + by, x_out - x_in, 1, sp_color)
  64.         end
  65.       end
  66.     end
  67.   end



多说两句,如果真嫌慢(实际上是伪命题,卡的话查其他地方),做0% 50% 100%三个基础环图,然后根据hp的比例在上面加加减减的fill_rect打补丁,因为补丁最多需要工作1/4的区间(平均期望1/8),故此能再快1/2左右,而且我现在这个算法是HP越满绘制量越高,正常玩家没有谁会放着黄血一直长时间不管的吧……但是实话说其实没啥继续优化的必要

Project7 - 40 FPS 2021_3_11 1_58_51.png (259.21 KB, 下载次数: 36)

Project7 - 40 FPS 2021_3_11 1_58_51.png

评分

参与人数 5星屑 +150 +4 收起 理由
RyanBern + 150 认可答案
1390959782 + 1 绝对高手,直呼牛逼,大佬
阿尔卑斯 + 1 棒棒棒
enghao_lim + 1 不赞不行 XD
89444640 + 1 塞糖

查看全部评分

SailCat (小猫子·要开心一点) 共上站 24 次,发表过 11 篇文章 上 次 在: [2006年01月28日11:41:18 星期六] 从 [162.105.120.91] 到本站一游。
回复 支持 反对

使用道具 举报

Lv5.捕梦者 (版主)

梦石
1
星屑
23994
在线时间
3339 小时
注册时间
2011-7-8
帖子
3926

开拓者

9
发表于 2021-3-11 15:08:39 | 只看该作者
sprite可以旋转,然后viewport不会绘制sprite超出的部分,那是不是可以做个半圆形的素材,旋转一下,超出的部分会被viewport干掉。

点评

感觉viewport没啥性能开销吧  发表于 2021-3-11 16:20
4个人8个viewport?  发表于 2021-3-11 15:18

评分

参与人数 1星屑 +50 收起 理由
RyanBern + 50 这脑洞,可

查看全部评分

熟悉rgss和ruby,xp区版主~
正在填坑:《膜拜组传奇》讲述膜拜组和学霸们的故事。
已上steam:与TXBD合作的Reformers《变革者》
* 战斗调用公共事件 *
* RGSOS 网络脚本 *
回复 支持 反对

使用道具 举报

Lv4.逐梦者

梦石
0
星屑
14629
在线时间
2152 小时
注册时间
2016-9-20
帖子
861
10
发表于 2021-3-11 15:51:36 | 只看该作者
这么麻烦要是我就直接弄垂直血条
我发的贴子大多未经整理是草稿抱歉
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2024-11-25 16:15

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

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