扫描二维码关注官方公众号
返回列表
+ 发新帖
查看: 163|回复: 0

[转载发布] 【7.20更新】仅用一个状态就能制作数十层的状态层数脚本

[复制链接]
累计送礼:
0 个
累计收礼:
0 个
  • TA的每日心情
    开心
    2024-11-27 10:08
  • 签到天数: 108 天

    连续签到: 4 天

    [LV.6]常住居民II

    2219

    主题

    376

    回帖

    1万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    VIP
    6
    卡币
    9661
    OK点
    16
    推广点
    0
    同能卷
    0
    积分
    12284

    灌水之王

    发表于 2024-4-12 16:54:42 | 显示全部楼层 |阅读模式
    其实也不能算是完全原创吧,也是自己参考了一些状态堆叠脚本写出来的脚本
    时常会觉得制作层数太累太累了,而且有些手游现在还经常能看见那种30层,100层,甚至更多层数的状态,如果真的复制粘贴那么多那真的人都要没了,那为什么不让状态拥有一个层数的值呢?
    RUBY 代码
    [Ruby] 纯文本查看 复制代码
    # =============================================================================
    # 状态层数脚本 By Akahara
    # =============================================================================
    # 是否时常因为制作层数状态需要复制粘贴好几个无法制作数十层而感到苦恼?
    # 为状态新增了max_level和state_levels的概念
    # 在状态的备注中填写,即该状态上限x层,未填写默认为1层
    # 可以通过state_levels(state_id)来制作每层增加数值的效果
    # 具体使用方法可以查阅https://rpg. blue/thread-486408-1-1.html
    # =============================================================================
    class RPG::State < RPG::BaseItem
      attr_accessor :max_level
     
      def load_level
        @max_level = 1
        note.split(/[]+/).each do |line|
          if line =~ //i
            @max_level = $1.to_i
          end
        end
      end
     
    end
     
    class << DataManager
     
      alias theo_levelstate_load_db load_database
      def load_database
        theo_levelstate_load_db
        load_levelstate_db
      end
     
      def load_levelstate_db
        $data_states.compact.each do |state|
          state.load_level
        end
      end
     
    end
     
    class Game_BattlerBase
      attr_reader   :state_levels  
      alias clear_states_levels clear_states
      def clear_states
        clear_states_levels
        @state_levels = {}
      end
     
      alias erase_state_levels erase_state
      def erase_state(state_id)
        erase_state_levels(state_id)
        reset_state_levels(state_id)
      end
     
      def reset_state_levels(state_id)
        @state_levels ||= {}
        @state_levels.delete(state_id)
      end  
     
      def set_state_levels(state_id)
        @state_levels ||= {}
        @state_levels[state_id] ||= 0    
      end
     
      def state_levels(state_id)
        @state_levels ||= {}
        d = @state_levels[state_id]
        d ? d : 0
      end
    end
     
    class Game_Battler < Game_BattlerBase
      alias akahara_r_20210719 remove_state
      def remove_state(state_id)
        akahara_r_20210719(state_id)
        reset_state_levels(state_id)
      end 
     
      alias akahara_20210719 add_state
      def add_state(state_id)
        akahara_20210719(state_id)
        set_state_levels(state_id)
        if state_addable?(state_id)
          return if $data_states[state_id].max_level <= 1
          if @state_levels[state_id] < 1
            @state_levels[state_id] = 1 
            return ;
          end
          if state?(state_id)
            @state_levels[state_id] += 1 if @state_levels[state_id] != $data_states[state_id].max_level
          end
        end
      end
    end


    7月19日11:30更新:修复解除状态时层数不重置的问题
    7月20日7:36更新:新增使用方法的例子(未更改脚本)

    具体使用方法:

    在Game_BattlerBase中的def param(param_id)里可以使用state_levels(状态ID)来实现每层+1%最大生命的效果(红框标注),可以参考这种写法实现自己想要的效果,具体param_id填写几请参考57行

    注:有的脚本(例如难易度脚本)给Game_Enemy重新定义了param(param_id),或者本身就重定义了Game_BattlerBase的def param(param_id),请注意查阅自己使用的脚本也照例填写层数效果


    在Game_Battler中的def make_damage_value(user, item)中可以追加value的计算(要放在@result.make_damage(value.to_i, item)之前),来实现每层使受到2号角色的伤害提升10%,可以参考这种写法实现自己想要的效果


    评分

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?立即注册

    x
    天天去同能,天天有童年!
    回复 送礼论坛版权

    使用道具 举报

    文明发言,和谐互动
    文明发言,和谐互动
    高级模式
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    关闭

    幸运抽奖

    社区每日抽奖来袭,快来试试你是欧皇还是非酋~

    立即查看

    聊天机器人
    Loading...

    QQ|Archiver|手机版|小黑屋|同能RPG制作大师 ( 沪ICP备12027754号-3 )

    GMT+8, 2025-1-16 00:55 , Processed in 0.069658 second(s), 60 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2020, Tencent Cloud.

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