Galv’s Random Loot V.1.0

Demo – Version 1.0 >

#------------------------------------------------------------------------------#
#  Galv's Random Loot
#------------------------------------------------------------------------------#
#  For: RPGMAKER VX ACE
#  Version 1.0
#------------------------------------------------------------------------------#
#  2012-09-29 - Version 1.0 - release
#------------------------------------------------------------------------------#
#  This script allows you to have a script call to gain random loot from chests.
#  Add notetags to items to specify level requirements and rarity values.
#  A notetag can also be added to items that you want to increase the chance to
#  find rarer loot.
#------------------------------------------------------------------------------#
#  Instructions:
#  Notetag ITEMS, ARMORS and WEAPONS that you want to random with the following:
#  (If items do not have these tags, they will not appear in a random chest.)
#------------------------------------------------------------------------------#
#
#  <rarity: x>                    # The rarity value (higher is rarer)
#  <level-min: x>                 # Min level of player for item to show
#  <level-max: x>                 # Max level of player for item to show
#
#------------------------------------------------------------------------------#
#  Option notetag for ARMORS and WEAPONS
#------------------------------------------------------------------------------#
#
#  <lucky: x>                     # All equipped lucky items are added to
#                                 # the chance to get rarer items.
#
#------------------------------------------------------------------------------#
#  Using this script call, you can randomly obtain an item:
#  random_item(type, min rareness, max rareness, monster-in-a-box)
#------------------------------------------------------------------------------#
#  EXAMPLE:
#
#  random_item(1, 10, 50, 1)
#
#------------------------------------------------------------------------------#
#  type can be 1: item, 2: armor, 3: weapons, 4: any
#
#  min rarness and max rareness determine the item rarity that the script
#  call will successfully obtain.
#  eg. min rareness = 10 and max rareness is 50, then that script call will
#  generate a number between 10 and 50. An item can be obtained only if it has
#  rarity EQUAL to or LESS THAN the number generated.
#
#  monster-in-a-box troop is used to decide what TROOP ID appears if you are
#  unlucky enough to random it.
#------------------------------------------------------------------------------#
#  This method works better if items/weapons/armors are organised with common
#  at the top and rarer items further down in their database lists.
#------------------------------------------------------------------------------#
 
$imported = {} if $imported.nil?
$imported["Random_Loot"] = true
 
module Random_Loot
 
#------------------------------------------------------------------------------#
#  SCRIPT SETUP OPTIONS
#------------------------------------------------------------------------------#
 
  GET_MESSAGE = "You received "       # Text before item name.
  GET_MESSAGE_AFTER = "!"             # Text after item name.
 
  FAIL_MESSAGE = "It's empty!"        # Text when random item comes up nothing.
 
  SOUND_EFFECT = ["Item1", 90, 100]   # Sound effect of gaining an item.
                                      # ["SE Name", volume, pitch]
                                      # Make "SE Name" = "" for no sound.
 
  MONSTER_CHANCE = 10                 # % chance that if no item is found, a
                                      # battle will happen instead.
  ESCAPE_MONSTER = true               # Can you escape it? true or false
 
  MONSTER_MESSAGE = "Monster in a box!!"     # Message when a monster appears.
                                             # Make it "" to disable.
 
#------------------------------------------------------------------------------#
#  END SCRIPT SETUP OPTIONS
#------------------------------------------------------------------------------#
 
end
 
module Random_Loot_Notetags
  def loot_rarity
    if @loot_rarity.nil?
      if @note =~ /<rarity: (.*)>/i
        @loot_rarity = $1.to_i
      else
        @loot_rarity = 0
      end
    end
    @loot_rarity
  end
  def loot_level_min
    if @loot_level_min.nil?
      if @note =~ /<level-min: (.*)>/i
        @loot_level_min = $1.to_i
      else
        @loot_level_min = 0
      end
    end
    @loot_level_min
  end
  def loot_level_max
    if @loot_level_max.nil?
      if @note =~ /<level-max: (.*)>/i
        @loot_level_max = $1.to_i
      else
        @loot_level_max = 0
      end
    end
    @loot_level_max
  end
  def loot_lucky
    if @loot_lucky.nil?
      if @note =~ /<lucky: (.*)>/i
        @loot_lucky = $1.to_i
      else
        @loot_lucky = 0
      end
    end
    @loot_lucky
  end
end # Random_Loot_Notetags
 
class RPG::Item
  include Random_Loot_Notetags
end
class RPG::Armor
  include Random_Loot_Notetags
end
class RPG::Weapon
  include Random_Loot_Notetags
end
 
class Game_Interpreter
 
  def random_item(type, rarity_min, rarity_max, monster_id)
    if type >= 4
      type = rand(3) + 1
    end
    if type == 1
      @loot = $data_items
    elsif type == 2
      @loot = $data_armors
    else
      @loot = $data_weapons
    end
 
    mem = 0
    eqs = 0
    luck_bonus = 0
    no_equips = ($game_party.members.count) * ($game_party.members[0].equips.count)
 
    no_equips.times { |i|
        if $game_party.members[mem].equips[eqs] != nil
          luck_bonus += $game_party.members[mem].equips[eqs].loot_lucky
        end
        if eqs < 5
          eqs += 1
        else
          eqs = 1
          mem += 1
        end
    }
 
    no_items = @loot.count - 1
    rare_chance = rand(rarity_max - rarity_min) + rarity_min + luck_bonus + 1
    checked = 0
    random_item = rand(no_items) + 1
    restart = false
    begin_count = 1
 
    no_items.times { |i|
      i = i + random_item
      begin_count += 1 if restart
      if i > no_items
        i = i - i + begin_count
        restart = true
      end
 
      if @loot[i].loot_level_max >= $game_party.leader.level && @loot[i].loot_level_min <= $game_party.leader.level
        if @loot[i].loot_rarity <= rare_chance
          $game_party.gain_item(@loot[i], 1)
          RPG::SE.new(Random_Loot::SOUND_EFFECT[0], Random_Loot::SOUND_EFFECT[1], Random_Loot::SOUND_EFFECT[2]).play
          $game_message.add(Random_Loot::GET_MESSAGE + @loot[i].name.to_s + Random_Loot::GET_MESSAGE_AFTER)
          return
        end
      end
      checked += 1
 
      if checked == no_items
        monster_chance = rand(100) + 1
        if monster_chance <= Random_Loot::MONSTER_CHANCE
          if Random_Loot::MONSTER_MESSAGE != ""
            $game_message.add("\\>" + Random_Loot::MONSTER_MESSAGE + "\\.\\.\\.\\^")
            wait_for_message
          end
          BattleManager.setup(monster_id, Random_Loot::ESCAPE_MONSTER, false)
          SceneManager.call(Scene_Battle)
        else
          $game_message.add(Random_Loot::FAIL_MESSAGE)
          wait_for_message
        end
      end
    }
  end
 
end # Game_Interpreter

3 thoughts on “Galv’s Random Loot V.1.0

  1. Trace says:

    at first i want to ask this on the pop up’s comment but . . . . nevermind . . .
    any idea how to remove text window after receiving an item ?
    i have no scripting skill . . .

    • Galv says:

      Sorry if it’s not in the settings then the script will need to be modified. Unfortunately I am too busy for requests and also I will be re-writing this later so can’t spend time on it

  2. Trace says:

    oh, that’s alright . . .
    thank you for the lightning response technique . . .
    :V

Leave a Reply

Fill in your details below or click an icon to log in:

WordPress.com Logo

You are commenting using your WordPress.com account. Log Out /  Change )

Facebook photo

You are commenting using your Facebook account. Log Out /  Change )

Connecting to %s