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

Project1

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

[已经过期] 新人求助 关于插入公共事件

[复制链接]

Lv1.梦旅人

梦石
0
星屑
50
在线时间
4 小时
注册时间
2015-12-24
帖子
6
跳转到指定楼层
1
发表于 2015-12-24 14:38:15 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

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

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

x
如题,我想在下面几个时机插入公共事件,脚本要怎么写,麻烦说的详细一点

1,在XXX号状态的效果结束时,插入一个公共事件

2,在X号角色的闪避后,插入一个公共事件

3,在X号角色打出暴击后,插入一个公共事件

4,在X号角色受到伤害后,插入一个公共事件

Lv3.寻梦者

梦石
0
星屑
2920
在线时间
713 小时
注册时间
2010-7-25
帖子
813

开拓者

2
发表于 2015-12-28 19:52:31 | 只看该作者
本帖最后由 jianyulei 于 2015-12-28 19:54 编辑

RUBY 代码复制
  1. #==============================================================================
  2. #
  3. # 自发技能 by Silentever(夜光云)
  4. #    (自动发动技能)
  5. #
  6. #    2015-10-28 更新:修复BUG,最终版
  7. #    2015-10-09 更新:修复BUG,写法优化,追加无视行动限制的自发技能,追加简化定义
  8. #                     删除:自发技能使用成功分歧判定
  9. #    2015-09-19 更新:追加:last_act定义,自发技能使用成功分歧判定
  10. #    2015-09-12 更新:修复BUG,支持让敌人也使用自发技能,追加地图自发技能,追加对象选择机制
  11. #    2015-08-17 发布
  12. #
  13. #==============================================================================
  14. # ▼ 设定
  15. #    填入【 Ask[ID] = { '参数名' => '算法' (用','分开) } 】
  16. #
  17. #  ID.......技能ID。对指定的技能无任何要求(可以发动任何技能)。
  18. #
  19. #  参数列表:
  20. #    几率...发动几率(0~100),不填写时为默认100。
  21. #           只要是返回数字,可以用变量计算;超出范围不会出错请安心。
  22. #    条件...发动先置条件(返回true/false),不填写时为默认true(无先置条件)。
  23. #    时机...限定发动的时机,详细在下面1。
  24. #    范围...设置方法请看下面2。
  25. #    强制...设定为true的场合,技能将会无视此脚本设置的条件与学会条件以外的,
  26. #           任何技能的常规发动条件(MP不足,行动不能等)。
  27. #
  28. #  例子:
  29. #    Ask[1] = {}                         => 使用1号技能(没有任何参数用空'{}')
  30. #    Ask[2] = { '几率' => '50' }         => 50%几率使用2号技能
  31. #    Ask[3] = { '条件' => 'luk > 50' }   => 幸运高于50(不包括等于)使用3号技能
  32. #    Ask[4] = { '条件' => 'state?(2)',
  33. #               '几率' => '100 - @state_turns[2] * 10'}
  34. #        => 持有2号状态的情况下,以(100-2号状态剩余回合数*10)的几率发动
  35. #
  36. #  填写时请把所有的参数跟其内容用 '' 或 "" 号包封。
  37. #  【注意】使用自发技能的第一个先置条件是学会(不论升级或特性添加),
  38. #  有必要让想让使用该技能的角色学会;另外敌人必须使用特性添加技能才能使用
  39. #  技能的使用会受到基础使用条件的限制(MP不足,使用场合不符,角色无法行动等)。
  40. #   
  41. #  补充:
  42. #  1) 重复添加相同的ID技能,【没办法】重复使用,写在后面的内容会覆盖先前的内容。
  43. #  2) 同一个时机中有复数自发技能行动角色时,会根据行动速度进行排列。
  44. #  3) 只能在战斗中使用,关于地图技能请看下面。
  45. #  4) 填写时注意使用全部半角的标点符号。
  46. #
  47. #
  48. #  ■【时机】(2015-10-09 更新中自发技能从发动时机分离)
  49. #  在参数中加入【 '时机' => '战斗开始, 战斗结束' 】
  50. #  可以把自发技能的使用锁定在后面填入的时机中。以上例子是把时机限定在了战斗开始跟结束。
  51. #  因为不填写时会每个时机都使用一次,因此【强烈】建议填写。
  52. #
  53. #  时机与以往不变:
  54. #    战斗开始,战斗结束  => 敌人出现时,胜利或逃跑后
  55. #    回合开始,回合结束  => 全部选择好行动后,回合正式开始的时候,以及回合结束
  56. #    行动前,行动后      => 自己进行主要行动(使用技能/道具)的前后
  57. #    受伤前,受伤后      => 自己成为技能/道具的对象,效果处理前/后
  58. #  直接把以上部分直接输入,用 , 分开。
  59. #
  60. #
  61. #  ■【范围】
  62. #  因为这部分比较复杂,慎入。注意在最后全部都用 '' 或 "" 号包封。
  63. #  不填写时,会自动选择对象(遵守原使用范围)。
  64. #  设置对象群体时,将会无视技能本身的使用范围。
  65. #
  66. #  设置时,可以放3部分,用“,”互相分开。其中1号是必须放在最前,其余可以随意排序。
  67. #  1) 范围的对象群体。用“+”追加,“-”排除。此外必须在每个运算符号前后留个空格。
  68. #     self是使用者自己。last是最后一个对象。重复加入会复数处理效果。
  69. #     最后一个对象指最后一次输入指令时选择的对象索引(每个角色独立)。
  70. #  2) 定成“max或min : 比较数值 : 采取数量”,不填写数量时当作1处理。
  71. #     会从范围中选择该数量的,持有最高/最低指定数值的单位。
  72. #  3) 用代码进行计算返回true/false,从范围选择所有符合条件的单位。
  73. #     计算代码可以使用跟伤害公式一样的变量:a=使用者,b=单独对象,v=游戏变量。
  74. #     不存在可选对象时,技能不发动。
  75. #
  76. #  例子:
  77. #  Ask[5] = { '范围' => 'self + last' }
  78. #      => 将目标对象锁定成自身与自身的最后对象
  79. #  Ask[6] = { '范围' => 'party - self, max:hp:2' }
  80. #      => 在玩家队伍成员中,除使用者以外,选择HP最高的2个角色
  81. #  Ask[7] = { '范围' => 'troop, b.state?(10)' }
  82. #      => 从敌群中选择所有持有10号状态的成员
  83. #  Ask[8] = { '范围' => 'allies, b.state?(1), max:mhp' }
  84. #      => 从持有1号状态的同伴中选择HP上限最高的1个成员(敌人使用会选择敌人)
  85. #  Ask[9] = { '范围' => 'party + self, min:hp:3, b.hp > 0' }
  86. #      => 从HP高于0的玩家队伍以及自身中选取3个HP最低的成员。
  87. #         注意角色使用的场合会把自身计算2此,因此会占有2个对象,并受到2次技能效果。
  88. #
  89. #
  90. #  ■【仅限伤害处理】
  91. #  仅在伤害处理可以使用user与item。
  92. #  User...攻击使用者的单位(敌人)。在对象组中填入“user”可以指定该单位做对象。
  93. #  Item...攻击单位所使用的技能。
  94. #  此外,受到伤害之后还能调用“dmg(:hp)”等变量获得伤害量,
  95. #
  96. #  例子2:
  97. #  Ask[10] = { '时机' => '受伤前',
  98. #              '范围' => 'user' }
  99. #      => 对攻击单位使用技能10号反击。
  100. #  Ask[11] = { '时机' => '受伤后',
  101. #              '条件' => 'dmg(:hp) >= 20' }
  102. #      => 受到20HP以上的伤害时发动(限伤害后)。
  103. #
  104. #  其他方法(限定在受伤后使用):
  105. #    dmg( )    => 获取伤害量,括号中填入种类“:hp”,“:mp”或“:tp”
  106. #    drn( )    => 获取吸收量,括号中填入“:hp”或“:mp”
  107. #    missed?   => 是否击中(输出true/false)
  108. #    evaded?   => 是否被回避(输出true/false)
  109. #    critical? => 是否暴击成功(输出true/false)
  110. #
  111. #
  112. #  ■【追加定义:party/troop/allies/oppons】
  113. #  为了方便输入简化了队伍与敌群的变量名。
  114. #
  115. #  party    => 获取玩家队伍(数组)
  116. #  party(1) => 获取队伍中首位的角色(角色)
  117. #  troop    => 获取全体敌群(数组)
  118. #  troop(1) => 获取1号敌人(敌人)
  119. #
  120. #  allies    => 获取使用者的同伴,角色的场合玩家队伍,敌人的场合敌群
  121. #  allies(1) => 获取同伴1号
  122. #  oppons    => 获取使用者的对手,角色的场合敌群,敌人的场合玩家队伍
  123. #  oppons(1) => 获取对手1号
  124. #
  125. #
  126. #  ■【追加定义:last_act】
  127. #  获取玩家输入的行动指令,玩家在游戏中输入攻击行动,可以通过此方法获取。
  128. #  注意获取的是行动而不是技能(道具的使用也是行动)。
  129. #  只有重新输入行动后才会更新,因此会保留到下次战斗。
  130. #  因为这个行动不会被执行所以没有修改的意义。
  131. #  具体参考Game_Action。
  132. #
  133. #  方法预览:
  134. #  last_act.attack?     => 是否普通攻击(true/false)
  135. #  last_act.guard?      => 是否防御(true/false)
  136. #
  137. #  last_act.skill?      => 是否技能(true/false)
  138. #  last_act.skill?(id)  => 是否为id号技能(true/false)
  139. #
  140. #  last_act.item?       => 是否道具(true/false)
  141. #  last_act.item?(id)   => 是否为id号道具(true/false)
  142. #
  143. #  last_act.valid?      => 判断角色是否可以执行该行动(true/false)
  144. #  last_act.item        => 获取行动的技能或使用道具(对象物品)
  145. #
  146. #------------------------------------------------------------------------------
  147. #
  148. # ▼ 地图发动的自发技能
  149. #    使用【 Msk[ID] = { '参数名' => '算法' (用','分开) } 】
  150. #    注意参数与战斗用的设置不一定相同。
  151. #
  152. #  频率...发动频率,玩家每行走此数值的步数使用1次。不填入不会发动。
  153. #         默认系统中20步会算作1回合(参考用)。
  154. #  条件...同战斗设置。
  155. #  范围...同战斗设置。注意在地图上不存在$game_troop。
  156. #  显示...是否显示使用消息,填入true会弹出对话框,否则无任何提示。
  157. #
  158. #==============================================================================
  159. module AutoSkill; Ask, Msk = {}, {}
  160. #==============================================================================
  161. # ● 请在这里填写技能设置;没有填写限制。
  162. #==============================================================================
  163.  
  164.  
  165.  
  166.  
  167.  
  168.  
  169.  
  170. #------------------------------------------------------------------------------
  171. end # Do not remove
  172. #==============================================================================
  173. # ▼ 脚本内容:不可编辑
  174. #==============================================================================
  175. class Game_Battler < Game_BattlerBase
  176.   #--------------------------------------------------------------------------
  177.   include AutoSkill
  178.   Ask.each_value {|s| s.default = ''}
  179.   Msk.each_value {|s| s.default = ''}
  180.  
  181.   # NewMethods: 追加简易定义
  182.   def party(n = nil)
  183.     return $game_party.members unless n
  184.     return $game_party.members[n] end
  185.   def troop(n = nil)
  186.     return $game_troop.members unless n
  187.     return $game_troop.members[n] end
  188.   def allies(n = nil)
  189.     return party(n) if actor?
  190.     return troop(n) if enemy?; end
  191.   def oppons(n = nil)
  192.     return party(n) if enemy?
  193.     return troop(n) if actor?; end
  194.  
  195.   def dmg(type = :hp); eval "@result_log.#{type.to_s}_damage" end
  196.   def drn(type = :hp); eval "@result_log.#{type.to_s}_drain" end
  197.   def missed?;   @result_log.missed end
  198.   def evaded?;   @result_log.evaded end
  199.   def critical?; @result_log.critical end
  200.  
  201.   def user; @attack_user end
  202.   def item; @attack_item end
  203.   def last
  204.     return allies(last_act.target_index) if last_act.item.for_friend?
  205.     return oppons(last_act.target_index) if last_act.item.for_opponent?
  206.   end
  207.  
  208.   # NewMethod: 最后一个主要行动
  209.   def last_act; @last_act; end
  210.   def set_last_action
  211.     @last_act = current_action if !current_action.is_a? Game_AutoAction
  212.   end
  213.   # AliasMethod: 记录战斗结果
  214.   attr_reader :result_log
  215.   def set_result_log
  216.     @result_log = @result.clone end
  217.   # AliasMethod: 初始化
  218.   alias :initialize_ask :initialize
  219.   def initialize; initialize_ask
  220.     @last_act = Game_Action.new(self)
  221.     @result_log = Game_ActionResult.new(self) end
  222.  
  223.   # NewMethod: 自发技能处理
  224.   def proc_auto_skill(timing = nil, user = nil, item = nil)
  225.     return unless SceneManager.scene_is?(Scene_Battle)
  226.     @attack_user, @attack_item = user, item
  227.     Ask.each {|i, v| skill = $data_skills[i]
  228.       next unless skills.include?(skill)
  229.       set_auto_skill(i, v, timing)}
  230.   end
  231.  
  232.   # NewMethod: 自发技能设置
  233.   def set_auto_skill(i, v, t)
  234.     return unless v['时机'].empty? or v['时机'].split(',').map{|s|s.strip}.include?(t)
  235.     return unless v['几率'].empty? or eval(v['几率']).to_i > rand(100)
  236.     return unless v['条件'].empty? or eval(v['条件'])
  237.     action = Game_AutoAction.new(self, eval(v['强制']), i)
  238.     unless make_auto_targets(action, v['范围']).empty?
  239.       @actions.insert(0, action)
  240.       BattleManager.autoskill_users.push(self)
  241.   end end
  242.  
  243.   # NewMethod: 设置行动对象
  244.   def make_auto_targets(action, scope)
  245.     if !scope.empty?; scope = scope.split(',')
  246.       unit = []; scope.shift.split(' ').each_with_index{|s, i|
  247.         @oper = '+' unless @oper; if i % 2 == 1; @oper = s; next end
  248.         unit.push(eval(s)) if @oper['+']
  249.         unit.reject!{|bat| [eval(s)].flatten.include?(bat)} if @oper['-']
  250.         unit.flatten!}; remove_instance_variable :@oper
  251.       if requir = scope.reject{|s| s[/max|min/]}[0]; unit.select!{|member|
  252.         a, b, v = self, member, $game_variables; eval requir}; end
  253.       if prior = scope.find{|s| s[/max|min/]}; prior = prior.split(':').map{|s|s.strip}
  254.         unit = unit.sort_by(&prior[1].to_sym); n = eval(prior[2]) rescue n = 1
  255.         unit = unit.first(n) if prior[0]['min']
  256.         unit = unit.last(n)  if prior[0]['max']
  257.       end end
  258.     return action.auto_targets = unit if unit
  259.     return action.auto_targets = [:rand]
  260.   end
  261.  
  262.   # NewMethod: 地图技能
  263.   def proc_map_skill
  264.     return unless SceneManager.scene_is?(Scene_Map)
  265.     Msk.each {|i, v| skill = $data_skills[i]
  266.       h = {}; v.each {|i, v| h[i] = v.split(',').map{|s| s.strip}}
  267.       next unless skills.include?(skill)
  268.       next unless usable?(skill)
  269.       next unless h['步数'].empty? or $game_party.steps % eval(h['步数']) == 0
  270.       next unless h['条件'].empty? or eval(h['条件'])
  271.       pay_skill_cost(skill)
  272.       item.effects.each {|effect| item_global_effect_apply(effect)} if
  273.         eval(h['消息'])
  274.       make_auto_targets(action, h['范围']).each {|target|
  275.         skill.repeats.times {target.item_apply(self, skill)}}}
  276.   end
  277.   #--------------------------------------------------------------------------
  278. end
  279. #==============================================================================
  280. class Game_Actor < Game_Battler
  281.   #--------------------------------------------------------------------------
  282.   # AliasMethod: 地图画面上回合结束的处理
  283.   alias :turn_end_on_map_ask :turn_end_on_map
  284.   def turn_end_on_map; turn_end_on_map_ask
  285.     proc_map_skill end
  286.   #--------------------------------------------------------------------------
  287. end
  288. #==============================================================================
  289. class Game_Enemy < Game_Battler
  290.   #--------------------------------------------------------------------------
  291.   # NewMethod: 获取技能实例的数组
  292.   def skills
  293.     added_skills.sort.collect {|id| $data_skills[id] }
  294.   end
  295.   #--------------------------------------------------------------------------
  296. end
  297. #==============================================================================
  298. class Game_Action
  299.   #--------------------------------------------------------------------------
  300.   # 判断用定义
  301.   def guard?; item == $data_skills[subject.guard_skill_id] end
  302.   def skill?(id = 0)
  303.     return item == $data_skills[id] if id > 0
  304.     return item.is_a?(RPG::Skill) end
  305.   def item?(id = 0)
  306.     return item == $data_items[id] if id > 0
  307.     return item.is_a?(RPG::Item) end
  308.   #--------------------------------------------------------------------------
  309. end
  310. #==============================================================================
  311. class Game_AutoAction < Game_Action
  312.   #--------------------------------------------------------------------------
  313.   attr_accessor :auto_action
  314.   attr_accessor :auto_targets
  315.  
  316.   # 初始化对象
  317.   def initialize(subject, forcing, skill_id)
  318.     super(subject, forcing)
  319.     set_skill(skill_id) end
  320.  
  321.   # 清除
  322.   def clear; super
  323.     @auto_action = false
  324.     @auto_targets = [] end
  325.  
  326.   # 生成目标数组
  327.   def make_targets
  328.     return super if @auto_targets.include?(:rand)
  329.     return @auto_targets end
  330.  
  331.   # 目标为队友
  332.   def targets_for_friends
  333.     @target_index = rand(subject.friends_unit.members.size) if
  334.       @auto_targets.include?(:rand)
  335.     super end
  336.   #--------------------------------------------------------------------------
  337. end
  338. #==============================================================================
  339. class Scene_Battle < Scene_Base
  340.   #--------------------------------------------------------------------------
  341.   # AliasMethod: 更新画面
  342.   alias :update_ask :update
  343.   def update; update_ask
  344.     BattleManager.terminate unless process_autoskill
  345.   end
  346.  
  347.   # AliasMethod: 开始队伍指令的选择
  348.   alias :start_party_command_selection_ask :start_party_command_selection
  349.   def start_party_command_selection
  350.     return if BattleManager.judge_win_loss
  351.     start_party_command_selection_ask
  352.   end
  353.  
  354.   # AliasMethod: 回合开始
  355.   alias :turn_start_ask :turn_start
  356.   def turn_start; turn_start_ask
  357.     all_battle_members.each {|battler| battler.set_last_action}
  358.     check_auto_skills(all_battle_members, '回合开始')
  359.   end
  360.  
  361.   # AliasMethod: 回合结束
  362.   alias :turn_end_ask :turn_end
  363.   def turn_end
  364.     check_auto_skills(all_battle_members, '回合结束')
  365.     turn_end_ask end
  366.  
  367.   # OverWrite: 处理战斗行动
  368.   def process_action
  369.     return if scene_changing?
  370.     if !@subject || !@subject.current_action
  371.       @subject = BattleManager.next_subject end
  372.     return turn_end unless @subject
  373.     return unless @subject
  374.     check_auto_skills([@subject], '行动前')
  375.     process_action_b
  376.     process_action_end unless @subject.current_action
  377.     check_auto_skills([@subject], '行动后')
  378.   end
  379.  
  380.   # NewMethod: 处理战斗行动
  381.   def process_action_b
  382.     if @subject.current_action
  383.       @subject.current_action.prepare
  384.       if @subject.current_action.valid?
  385.         @status_window.open
  386.         execute_action
  387.       end
  388.       @subject.remove_current_action
  389.     end
  390.   end
  391.  
  392.   # NewMethod: 处理自动技能
  393.   def process_autoskill
  394.     return false if BattleManager.autoskill_users.empty?
  395.     @log_window.wait
  396.     last_subject = @subject if @subject
  397.     @subject = BattleManager.autoskill_users.shift
  398.     @using_auto_skill = true
  399.     process_action_b
  400.     @subject = last_subject if last_subject
  401.     @using_auto_skill = false
  402.     return true
  403.   end
  404.  
  405.   # AliasMethod: 使用技能/物品
  406.   alias :use_item_ask :use_item
  407.   def use_item
  408.     if @using_auto_skill
  409.       use_item_ask
  410.     else; use_item_no_autoskill end
  411.   end
  412.  
  413.   # NewMethod: 使用非自发技能/物品
  414.   def use_item_no_autoskill
  415.     item = @subject.current_action.item
  416.     @log_window.display_use_item(@subject, item)
  417.     @subject.use_item(item)
  418.     refresh_status
  419.     targets = @subject.current_action.make_targets.compact
  420.     show_animation(targets, item.animation_id)
  421.     check_auto_skills(targets, '受伤前', @subject, item)
  422.     targets.each {|target| item.repeats.times { invoke_item(target, item) } }
  423.     check_auto_skills(targets, '受伤后', @subject, item)
  424.   end
  425.  
  426.   # AliasMethod: 应用技能/物品效果
  427.   alias :apply_item_effects_ask :apply_item_effects
  428.   def apply_item_effects(target, item)
  429.     apply_item_effects_ask(target, item)
  430.     target.set_result_log
  431.   end
  432.  
  433.   # NewMethod: 使用自发技能
  434.   def check_auto_skills(subjects = [], *args)
  435.     subjects.each {|subject| subject.proc_auto_skill(*args) if subject}
  436.     while process_autoskill
  437.   end end
  438.   #--------------------------------------------------------------------------
  439. end
  440. #==============================================================================
  441. module BattleManager
  442.   #--------------------------------------------------------------------------
  443.   class << self
  444.     alias :battle_start_ask :battle_start
  445.     alias :on_encounter_ask :on_encounter; end
  446.  
  447.   # AliasMethod: 战斗开始
  448.   def self.battle_start
  449.     @battle_result = nil
  450.     battle_start_ask
  451.     SceneManager.scene.check_auto_skills($game_party.members+$game_troop.members, '战斗开始')
  452.     on_encounter_ask
  453.     if @preemptive
  454.       $game_message.add(sprintf(Vocab::Preemptive, $game_party.name))
  455.     elsif @surprise
  456.       $game_message.add(sprintf(Vocab::Surprise, $game_party.name))
  457.     end
  458.     wait_for_message
  459.   end
  460.  
  461.   # AliasMethod: 遇敌时的处理
  462.   def self.on_encounter; end
  463.  
  464.   # OverWrite: 胜利时的处理
  465.   def self.process_victory
  466.     play_battle_end_me
  467.     replay_bgm_and_bgs
  468.     $game_message.add(sprintf(Vocab::Victory, $game_party.name))
  469.     display_exp
  470.     gain_gold
  471.     gain_drop_items
  472.     gain_exp
  473.     battle_end(0)
  474.     return true
  475.   end
  476.  
  477.   # OverWrite: 中止时的处理
  478.   def self.process_abort
  479.     replay_bgm_and_bgs
  480.     battle_end(1)
  481.     return true
  482.   end
  483.  
  484.   # OverWrite: 全灭时的处理
  485.   def self.process_defeat
  486.     $game_message.add(sprintf(Vocab::Defeat, $game_party.name))
  487.     wait_for_message
  488.     replay_bgm_and_bgs if @can_lose
  489.     battle_end(2)
  490.     return true
  491.   end
  492.  
  493.   # OverWrite: 战斗结束 > 结果(0:胜利 1:撤退 2:全灭)
  494.   def self.battle_end(result)
  495.     @phase = nil
  496.     @battle_result = result
  497.     $game_party.on_battle_end
  498.     $game_troop.on_battle_end
  499.     SceneManager.scene.check_auto_skills($game_party.members, '战斗结束')
  500.   end
  501.  
  502.   # NewMethod: 退出管理器
  503.   def self.terminate
  504.     return unless @battle_result
  505.     revive_battle_members if @battle_result == 2 && @can_lose
  506.     @event_proc.call(@battle_result) if @event_proc
  507.     SceneManager.return
  508.     SceneManager.goto(Scene_Gameover) if @battle_result == 2 && !@can_lose
  509.     SceneManager.exit if $BTEST
  510.   end
  511.  
  512.   # NewMethod: 自发技能行动列表
  513.   def self.autoskill_users
  514.     @autoskill_users ||= []
  515.     @autoskill_users.each {|battler| battler.make_speed }
  516.     @autoskill_users.sort! {|a,b| b.speed - a.speed }
  517.     return @autoskill_users
  518.   end
  519.   #--------------------------------------------------------------------------
  520. end
  521. #==============================================================================
  522. # ▼ END
  523. #==============================================================================


这是夜光云的神脚本,可以在任何时间段下根据任何条件发动技能,你再把技能导入公共事件就可以了。


RUBY 代码复制
  1. #状态自然与强制解除触发公共事件
  2. #状态备注<触发公共事件 X> X为公共事件编号
  3. module StateRemoveCommonEventsKal
  4.  
  5.   TAG_NAME = "触发公共事件"
  6.  
  7.   class IDExtractor
  8.     def get_common_event_id_for_state(state_id)
  9.       rpg_state = get_rpg_state(state_id)
  10.       extract_common_event_id(rpg_state.note)
  11.     end
  12.  
  13.     private
  14.  
  15.     def get_rpg_state(state_id)
  16.       $data_states.find do |rpg_state|
  17.         rpg_state && rpg_state.id == state_id
  18.       end
  19.     end
  20.  
  21.     def extract_common_event_id(note)
  22.       id = note[/<#{TAG_NAME}\s+(\d+)\s*>/, 1]
  23.       id.nil? ? nil : id.to_i
  24.     end
  25.   end
  26.  
  27.   class CommonEventRunner
  28.     def run(common_event_id)
  29.       page = make_page(common_event_id)
  30.       $game_troop.interpreter.setup(page.list)
  31.     end
  32.  
  33.     private
  34.  
  35.     def make_page(id)
  36.       page = RPG::Troop::Page.new
  37.       # 117 => common event code, 0 => indent, id => id of common event
  38.       page.list.unshift(RPG::EventCommand.new(117, 0, [id]))
  39.       page
  40.     end
  41.   end
  42.  
  43.   @id_extractor = IDExtractor.new
  44.   @common_event_runner = CommonEventRunner.new
  45.  
  46.   def self.run_event_from_state(state_id)
  47.     event_id = @id_extractor.get_common_event_id_for_state(state_id)
  48.     @common_event_runner.run(event_id) if event_id
  49.   end
  50. end
  51.  
  52. class Game_BattlerBase
  53.   alias_method :erase_state_srce_kal, :erase_state
  54.  
  55.   def erase_state(state_id)
  56.     StateRemoveCommonEventsKal.run_event_from_state(state_id)
  57.     erase_state_srce_kal(state_id)
  58.   end
  59. end


状态解除时触发事件



至于闪避和暴击……不知道在Game_Battler里加入$game_temp.reserve_common_event(25)能有效不

评分

参与人数 1梦石 +1 收起 理由
taroxd + 1 认可答案

查看全部评分

回复 支持 反对

使用道具 举报

Lv1.梦旅人

梦石
0
星屑
50
在线时间
4 小时
注册时间
2015-12-24
帖子
6
3
 楼主| 发表于 2015-12-29 19:14:10 | 只看该作者
脚本很有用~小妹谢过了~
回复 支持 反对

使用道具 举报

Lv1.梦旅人

梦石
0
星屑
50
在线时间
4 小时
注册时间
2015-12-24
帖子
6
4
 楼主| 发表于 2016-1-4 16:26:46 | 只看该作者
饿。我弄了很久,和横战脚本冲突的,技能动作完全变了,战斗结束还会报错
回复 支持 反对

使用道具 举报

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

本版积分规则

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

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

GMT+8, 2024-11-17 04:46

Powered by Discuz! X3.1

© 2001-2013 Comsenz Inc.

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