1993-2009 Zonemaker Tous droits réservés - All rights reserved
   
  Zonemaker
  Scripts
 
Dans cette section vous aurez besoin d'un logiciel appelé Winrar Zip Archive qui vous permettra de décompresser les téléchargements que nous vous proposons. Nous vous invitons a le télécharger si vous ne l'avez pas cliquez ici !
---------------------------------------------------------------------------------------------------------------------------------------
Bonjour,
Aujourd'hui nous avons construit spécialement pour vous un script qui vous permettra d'avoir une sauvegarde améliorée avec plusieurs slot ! Nous allons procéder à l'explication :
Cliquez ici pour télécharger le script ! Puis faites un clic droit sur l'archive et cliquez sur Extract files...
Alors une fenêtre s'ouvre ! Cliquez sur le + de Mes documents puis sur le + de RPGXP ! Cliquez ensuite sur le + " Du nom que vous avez donné à votre projet " Exemple : Project 1 ou Votre prénom etc. puis cliquez sur le + de Graphics puis cliquez sur Graphics puis sur OK !
Ensuite ouvrez l'éditeur de scripts (F11) et remplacez le script Scene_Files par celui-ci : Sélectionnez tout le texte jusqu'a STOP ! Puis lisez la suite pour finir !

=begin
#------------------------------------------------------------------------
#                     Menu Sauvegarde améliorée
#                               RPG Maker XP
#
# Auteur : Aymeric Admin
#
# Créé le  14 Mai 2008
#
#
# Fonction :  Permet d'améliorer le menu sauvegarde. Il est possible de supprimer
#             une sauvegarde. Un message de confirmation pour remplacer
#             ou effacer est présent aussi.
#
# Site : www.zonemaker.fr.gd
#
# Remarque : Script disponible aussi sous RPG Maker VX
#
#------- Modification ---------
#
#------------------------------------------------------------------------
# N'oubliez pas de mettre avant le script "Main" :
class Scene_Load < Scene_File 
  def scene
    return 0
  end
end
class Scene_Save < Scene_File 
  def scene
    return 1
  end
  def on_decision(filename)
    $game_system.se_play($data_system.save_se)
    file = File.open(filename, "wb")
    write_save_data(file)
    file.close
  end
end

#------------------------------------------------------------------------
=end

module AM_SAVE

#--------------------------------------------------------
#                 Définissez les images
#--------------------------------------------------------
 
  GAUGE_EXP       = "015-Greens01" # Image pour la gauge d'expérience
  GAUGE_HP        = "014-Reds01"   # Image pour la gauge de points de vie
  GAUGE_SP        = "013-Blues01"  # Image pour la gauge de poins de magie
  FOND_GAUGE      = "Back2"        # Fond des jauges
  WINDOWSKIN_BIS = "001-Blue01"          # Windowskin lorsqu'il y a un slot utilisé
  FOND            = "fond_save"    # Arrière plan
 
  # La constante ci-dessous permet d'inverser les windowskins. Si vous mettez
  # "true", le "WINDOWSKIN_BIS" de ci-dessus sera appliqué seulement aux slots
  # de sauvegardes vides. Sinon, si vous mettez "false", ça sera le windowskin par défaut
  # qui sera appliqué aux slot vides
  INVERSE_WINDOWSKIN = false
 
end

#--------------------------------------------------------
#             Module Files (Crée par Samarium)
#       Ce module permetrra de prendre toutes les
#               données du fichier rxdata
#--------------------------------------------------------

module Files
  class Donnees
    # Index du fichier
    attr_accessor :file_index
    # Donnée de la classe File
    attr_reader :time_stamp
    # Donées du ficher rxdata
    attr_reader :characters
    attr_reader :frame_count
    attr_reader :system
    attr_reader :switches
    attr_reader :variables
    attr_reader :self_switches
    attr_reader :screen
    attr_reader :actors
    attr_reader :party
    attr_reader :troop
    attr_reader :map
    attr_reader :player
    def initialize(file_index = 0)
      @file_index = file_index
      if exist? 
        file = File.open(filename, "r")
        @time_stamp         = file.mtime
        @characters         = Marshal.load(file)
        @frame_count        = Marshal.load(file)
        @system             = Marshal.load(file)
        @switches           = Marshal.load(file)
        @variables          = Marshal.load(file)
        @self_switches      = Marshal.load(file)
        @screen             = Marshal.load(file)
        @actors             = Marshal.load(file)
        @party              = Marshal.load(file)
        @troop              = Marshal.load(file)
        @map                = Marshal.load(file)
        @player             = Marshal.load(file)
        file.close
      end
    end
    def exist?
      return FileTest.exist?(filename)
    end
    def filename
      return "Save#{file_index + 1}.rxdata"
    end
  end 
end

#--------------------------------------------------------
#              Window_SaveFile modifié
#             Les fenêtres pour les slots
#--------------------------------------------------------

class Window_SaveFile < Window_Base
 
  attr_reader   :selected                
 
  def initialize(file_index, filename = nil)
    super(15, 64 + file_index % 4 * 85, 130, 80)
    self.contents = Bitmap.new(width - 32, height - 32)
    self.contents.font.name = $fontface
    @opacity = 80
    self.opacity = @opacity
    @file_index = file_index
    # Charge les données du fichier.
    @game = Files::Donnees.new(file_index)

    refresh
    @selected = false
  end
 
  def refresh
    self.contents.clear
    self.contents.font.size = 18
    name = "Slot #{@file_index + 1}"
    self.contents.font.color = normal_color
  # name = "File #{@file_index + 1}"
    self.contents.draw_text(0, 0, 600, 32, name)
    # Si il y a déjà une sauvegarde
  
   
    if @game.exist?
      @game = Files::Donnees.new(@file_index)
       windowskin = AM_SAVE::INVERSE_WINDOWSKIN ? AM_SAVE::WINDOWSKIN_BIS : $game_system.windowskin_name
      self.windowskin = RPG::Cache.windowskin(windowskin)
      text = @game.time_stamp.strftime("%d/%m/%Y %H:%M")
    else
       windowskin = AM_SAVE::INVERSE_WINDOWSKIN ? $game_system.windowskin_name : AM_SAVE::WINDOWSKIN_BIS
      self.windowskin = RPG::Cache.windowskin(windowskin)
       text = "Vide"
    end
    self.contents.font.size = 15
    self.contents.font.color = normal_color
    self.contents.draw_text(0, 25, 600, 32, text)
  end
  def selected=(selected)
    @selected = selected
    update_cursor_rect
  end
  # Défini l'opacité et positionnement du slot lorsque ce dernier est sélectionné
  def update_cursor_rect
    if @selected
      self.opacity = 255
      self.x = 30
    else
      self.opacity = @opacity
      self.x = 15
    end
  end
end

#--------------------------------------------------------
#               Window_SaveStatus
#   Fenêtre avec les indications des héros (PV, MP ...)
#--------------------------------------------------------

class Window_FileStatus < Window_Base
 
  def initialize
    super(640, 80, 440, 300)
    self.contents = Bitmap.new(width - 32, height - 32)
    self.contents.font.name = $fontface
    self.contents.font.size = 15
    self.opacity = 150
    refresh
  end
  def refresh(file_index=0)
      self.contents.clear
       @game = Files::Donnees.new(file_index)
      if @game.exist?
        # Affiche en boucle les héros
        for i in 0...@game.characters.size
          # Algorithme pour afficher 2 héros sur 2 colonnes
          x = i < 2 ? 64 : 270
          j = (i == 2  or i == 0) ? 0 : j+1
          y = j * 135
          # Affichage des caractéristiques
          actor = @game.party.actors[i]
          draw_actor_name(actor, x, y)
          draw_actor_graphic(actor, x - 40, y + 80)
  #       draw_actor_class(actor, x + 144, y)
          draw_actor_level(actor, x, y + 16)
          draw_actor_state(actor, x + 60, y + 16)
          draw_actor_exp(actor, x, y + 40)
          draw_actor_hp(actor, x , y + 60)
          draw_actor_sp(actor, x, y + 80)
        end
      end
    end
  # Permet de faire bouger vers la gauche la fenêtre
  def bouger
    self.x -= 50 if self.x >= 220 if @game.exist?
    return true if self.x <= 220
  end
  # permet de retirer la fenêtre de l'écran
   def retirer
    self.x += 50 if self.x <= 640 if @game.exist?
    return true if self.x >= 640
  end
  # Déssine une jauge
  def draw_gauge(x, y, min, max, file, width, height)
    pourcentage = max == 0 ? 0 : min.to_f / max.to_f
    gauge = RPG::Cache.picture(file)
    fond = RPG::Cache.picture(AM_SAVE::FOND_GAUGE)
    gauge_dest = Rect.new(x, y, width * pourcentage, gauge.height)
    fond_dest = Rect.new(x, y,width, fond.height)
    gauge_source = Rect.new(0,0, gauge.width, gauge.height)
    fond_source = Rect.new(0,0, fond.width,fond.height)
    self.contents.stretch_blt(fond_dest, fond, fond_source)
    self.contents.stretch_blt(gauge_dest, gauge, gauge_source)
  end 
 # Reprise de la méthode de Window_Base en affichant la jauge d'expérience
  def draw_actor_exp(actor, x, y)
    min = actor.level == 99 ? 1 : actor.exp_s
    max = actor.level == 99 ? 1 : actor.next_exp_s
    draw_gauge(x + 32, y + 16, min, max,AM_SAVE::GAUGE_EXP, 80,
    if actor.level == 99
      self.contents.draw_text(x + 33, y, 600, 32, "-----/-----")
    else
      self.contents.draw_text(x + 33, y, 600, 32, min.to_s + "/" + max.to_s)
    end
    self.contents.font.color = system_color
    self.contents.draw_text(x, y, 32, 32, "Exp")
   end
  # Reprise de la méthode de Window_Base en affichant la jauge de PV
  def draw_actor_hp(actor, x, y, width=144)
    draw_gauge(x + 32, y + 16,actor.hp , actor.maxhp,AM_SAVE::GAUGE_HP, 80,
    self.contents.font.color = system_color
    self.contents.draw_text(x, y, 32, 32, $data_system.words.hp)
      if width - 32 >= 108
      hp_x = x + width - 138
      flag = true
    elsif width - 32 >= 48
      hp_x = x + width - 88
      flag = false
    end
    self.contents.font.color = actor.hp == 0 ? knockout_color :
      actor.hp <= actor.maxhp / 4 ? crisis_color : normal_color
    self.contents.draw_text(hp_x, y, 48, 32, actor.hp.to_s, 2)
    if flag
      self.contents.font.color = normal_color
      self.contents.draw_text(hp_x + 48, y, 12, 32, "/", 1)
      self.contents.draw_text(hp_x + 60, y, 48, 32, actor.maxhp.to_s)
    end
  end
  # Reprise de la méthode de Window_Base en affichant la jauge de MP
  def draw_actor_sp(actor, x, y, width = 144)
    draw_gauge(x + 32, y + 16,actor.sp , actor.maxsp,AM_SAVE::GAUGE_SP, 80,
    self.contents.font.color = system_color
    self.contents.draw_text(x, y, 32, 32, $data_system.words.sp)
    if width - 32 >= 108
     sp_x = x + width - 138
      flag = true
    elsif width - 32 >= 48
      sp_x = x + width - 88
      flag = false
    end
    self.contents.font.color = actor.sp == 0 ? knockout_color :
      actor.sp <= actor.maxsp / 4 ? crisis_color : normal_color
    self.contents.draw_text(sp_x, y, 48, 32, actor.sp.to_s, 2)
    if flag
      self.contents.font.color = normal_color
      self.contents.draw_text(sp_x + 48, y, 12, 32, "/", 1)
      self.contents.draw_text(sp_x + 60, y, 48, 32, actor.maxsp.to_s)
    end
  end
end

#--------------------------------------------------------
#                   Window_FileInfo
#     Fenêtre avec les infos du jeu en bas de l'écran
#--------------------------------------------------------

class Window_FileInfo < Window_Base
 
  def initialize
    super(-4, 480, 681, 80)
    self.contents = Bitmap.new(width, height)
    self.contents.font.name = $fontface
    self.contents.font.color = normal_color
    self.opacity = 150
   
    refresh
  end
 
  def refresh(file_index = 0)
    self.contents.clear
    @game = Files::Donnees.new(file_index)
    if @game.exist?
       self.contents.font.size = 20
      @total_sec = @game.frame_count / Graphics.frame_rate
      cx = contents.text_size($data_system.words.gold).width
      cgold = contents.text_size(@game.party.gold.to_s).width
      # Affiche argent possédé, sauvegardes effetués et temps joué
      self.contents.draw_text(4, 0, 130, 32, "Argent possédé :")
      self.contents.draw_text(140, 0, 120-cx-2, 32, @game.party.gold.to_s)
      self.contents.draw_text(142 + cgold, 0, cx, 32, $data_system.words.gold)
      self.contents.draw_text(250, 0, 300, 32, "Sauvegardes effectuées : " + @game.system.save_count.to_s)
      hour = @total_sec / 60 / 60
      min = @total_sec / 60 % 60
      sec = @total_sec % 60
      time_string = sprintf("d:d:d", hour, min, sec)
      self.contents.draw_text(4, 20, 100, 32, "Temps joué : ")
      self.contents.draw_text(140, 20, 100, 32, time_string)
      self.contents.font.size = 16
      self.contents.draw_text(370, 20, 400, 32, "Appuyez sur Z pour effacer une sauvegarde")
    end
  end
 # permet de faire bouger la fenêtre vers le haut
  def bouger
    self.y -= 10 if self.y > 420 if @game.exist?
  end
end

#--------------------------------------------------------
#                   Window_FileConfirm
#              Fenêtre pour les confirmations
#--------------------------------------------------------

class Window_FileConfirm < Window_Selectable
 
   attr_reader :type

  def initialize
    super(640, 160, 410, 130)
    self.contents = Bitmap.new(width - 32, height - 32)
    self.contents.font.name = $fontface
    self.contents.font.size = 20
    refresh
    self.active = false
    self.opacity = 150
    @type = 0
  end
 # Affiche des phrases de confirmation selon le type choisit
  def refresh(type = 0)
    self.contents.clear
    @type = type
    self.index = 1
    if type == 0
      self.contents.draw_text(0, 10, 410, 32, "Il existe déjà une sauvegarde à cet emplacement.", 1)
      self.contents.draw_text(50, 32, 300, 32, "Etes vous sûr de la remplacer ?", 1)
    elsif type == 1
      self.contents.draw_text(50, 20, 300, 32, "Etes vous sûr de la supprimer ?", 1)
    elsif type == 2
       self.index = -1
       self.contents.draw_text(0, 40, 400, 32, "Le fichier a été supprimé avec succès", 1)
    elsif type == 3 or type == 4
       self.index = -1
       self.contents.draw_text(0, 40, 400, 32, "Jeu sauvegardé avec succès", 1)  
     end
     # Sélection du "Oui" ou "Non"
    if type != 2 and type != 3 and type != 4
      self.contents.draw_text(110, 70, 50, 32, "Oui", 1)
      self.contents.draw_text(220, 70, 50, 32, "Non", 1)
    end
  end

  def update_cursor_rect
    if @index < 0
      self.cursor_rect.empty
    else
      self.cursor_rect.set(110 * @index, 70, 50, 32)
    end
  end
  # Bouge la fenêtre vers la gauche
  def bouger
   self.x -= 50 if self.x >= 220
   return true if self.x <= 220    
 end
  # Retire la fenêtre
  def retirer
   self.x += 50 if self.x <= 640
   return true if self.x >= 640
  end
end

#--------------------------------------------------------
#                   Scene_File modifié
#           Scene et actions pour les sauvegardes
#--------------------------------------------------------

class Scene_File
 
  def initialize(help_text)
    @help_text = help_text
  end
 
  def main
    # Initialisation des objets pour les différentes fenêtres
    @help_window = Window_Help.new
    @help_window.set_text(@help_text, 1)  
    @file_status_window = Window_FileStatus.new
    @file_info_window = Window_FileInfo.new
    @confirm_window = Window_FileConfirm.new
    @confirm = false
    @delete = false
    @auto_retirer = false
    # Affichage du fond
    @sprite = Sprite.new
    @sprite.bitmap = RPG::Cache.picture(AM_SAVE::FOND)
    @help_window.opacity = 0
    @savefile_windows = []
    for i in 0..3
      @savefile_windows.push(Window_SaveFile.new(i, make_filename(i)))
    end
    @file_index = 0
    @savefile_windows[@file_index].selected = true
    # Mise à jour comme toujours
    Graphics.transition
    loop do
      Graphics.update
      Input.update
      update
      if $scene != self
        break
      end
    end
    Graphics.freeze
    @help_window.dispose
    @file_status_window.dispose
    @file_info_window.dispose
    @sprite.dispose
     @confirm_window.dispose
    for i in @savefile_windows
      i.dispose
    end
  end

  def update
    # Mise à jour des fenêtres
    @help_window.update
    @file_status_window.update
    @file_info_window.update
    @confirm_window.update
    @sprite.update
    for i in @savefile_windows
      i.update
    end
    # Si la fenêtre de confirmation est active, on affiche la sélection
    if @confirm_window.active
       update_confirm
    end
    # On bouge la fenêtre d'info
    @file_info_window.bouger
    # Si on demande confirmation
    if @confirm
       # On bouge la fenêtre de confirmation après avoir retirer la fenêtre de Statut
      if @file_status_window.retirer
         @confirm_window.bouger
         @confirm_window.active  = true
         save_reussie if @confirm_window.type == 3  if @confirm_window.bouger
      end
    else
      # Réciproquement ...
      if @confirm_window.retirer
      @file_status_window.bouger 
      @confirm_window.active  = false
    end
  end
    # Si on demande le retirement automatique
    if @auto_retirer
      @auto_retirer = false
      @savefile_windows[@file_index].refresh
      # On affiche pendant 2 secondes
      wait(2)
     end
    # Si on appuie sur Entrée
    if Input.trigger?(Input::C)
      # Si c'est pour une confirmation
         if @confirm
           case @confirm_window.index
           # Annulation
           when 2
           $game_system.se_play($data_system.cancel_se)
           @confirm = false
           return
           # validation
           when 1           
             case @confirm_window.type
              when 0 
                # on sauvegarde
                 on_decision(make_filename(@file_index))
                save_reussie
              when 1
                # On supprime
                delete(make_filename(@file_index))
                @confirm_window.refresh(2)
                @auto_retirer = true
              end
            end
          else
            # Si la scene est "Scene_Save"
            if scene == 1
              # Si il existe déjç une sauvegarde
              if File.exist?(make_filename(@file_index))
               @confirm_window.refresh
               # On demande confirmation
               @confirm = true
             else
               # Sinon, on sauvegarde directement
               on_decision(make_filename(@file_index))
                @confirm_window.refresh(3)
                @confirm = true
               end
             else
               # Si la scene est "Scene_Load"
               on_decision(make_filename(@file_index))
            end
          end
        return
      end
    # Si on appuie sur "Echap" : Annulation
    if Input.trigger?(Input::B)
      # On revient au menu
      if !@confirm
        on_cancel
      else
        # On enlève la fenêtr de confirmation
        $game_system.se_play($data_system.cancel_se)
        @confirm = false
      end
     return
   end
  # Si on appuie sur "Z"
  if Input.trigger?(Input::A) and File.exist?(make_filename(@file_index))
    # on demande confirmation
     @confirm_window.refresh(1)
     @confirm = true
   return
 end
 # Si on choisit les slots
  if !@confirm
    if Input.repeat?(Input::DOWN)
      if Input.trigger?(Input::DOWN) or @file_index < 3
        @file_status_window.x = 640
        @file_info_window.y = 480
        $game_system.se_play($data_system.cursor_se)
        @savefile_windows[@file_index].selected = false
        @file_index = (@file_index + 1) % 4
        @savefile_windows[@file_index].selected = true
        # On réfraichit les fenêtres
        @file_status_window.refresh(@file_index)
        @file_info_window.refresh(@file_index)
      return
      end
    end
    if Input.repeat?(Input::UP)
      if Input.trigger?(Input::UP) or @file_index > 0
        @file_status_window.x = 640
        @file_info_window.y = 480
        $game_system.se_play($data_system.cursor_se)
        @savefile_windows[@file_index].selected = false
        @file_index = (@file_index + 3) % 4
        @savefile_windows[@file_index].selected = true
         # On réfraichit les fenêtres
        @file_status_window.refresh(@file_index)
        @file_info_window.refresh(@file_index)
        return
      end
    end
  end 
  end
  # Le nom du fichier
  def make_filename(file_index)
    game = Files::Donnees.new(file_index)
    return game.filename
  end
  # Sélection dans la fenêtre de confirmation
  def update_confirm
    if (Input.trigger?(Input::LEFT) or Input.trigger?(Input::UP)) and @confirm_window.index != 1
      $game_system.se_play($data_system.cursor_se)
      @confirm_window.index = 1
      return
    elsif (Input.trigger?(Input::RIGHT) or Input.trigger?(Input::DOWN)) and @confirm_window.index != 2
      $game_system.se_play($data_system.cursor_se)
      @confirm_window.index = 2
      return
    end
  end
   # Attente (Calcul en secondes)   
   def wait(time)
    total_sec_dep = Graphics.frame_count / Graphics.frame_rate
    loop do
       total_sec = Graphics.frame_count / Graphics.frame_rate
        Graphics.update
        Input.update
        if total_sec >= (total_sec_dep + time)
          @confirm = false
          break
        end
      end
    return
    end
# Si la sauvegarde est réussie, on éfraichit les fenêtres et on retire automatiquement
 def save_reussie
     @savefile_windows[@file_index].refresh
     @file_status_window.refresh(@file_index)
     @file_info_window.refresh(@file_index)
     @confirm_window.refresh(4)
     @auto_retirer = true
  end
 # Suppression du fichier  
  def delete(filename)
    File.delete(filename)
    @file_info_window.y = 480
  end
end
STOP ! STOP ! STOP ! STOP ! STOP ! STOP ! STOP ! STOP !

 

Puis fait un clic droit sur le script main et clic sur Nouveau script puis écrivez ceci :

class   Scene_Load   <   Scene_File     
      def   scene
            return   0
      end
end
class   Scene_Save   <   Scene_File     
      def   scene
            return   1
      end
      def   on_decision(filename)
            $game_system.se_play($data_system.save_se)
            file   =   File.open(filename,   "wb")
            write_save_data(file)
            file.close
      end
end

Autre script:
Pour mettre plein d'options dans vos messages.
Creer un script en dessus de main et nommer le:
Advanced_Message et inserez ceci:
# ▼▲▼ XRXS 9. メッセージ表示フルグレードアップ ver..12d ▼▲▼
# Original Script by 桜雅 在土, 和希, RaTTiE
# Script from: http://f26.aaacafe.ne.jp/~xxms/RPGXP_XRXS9.htm
#
#
#
#To found all my NEW features, press CONTROL+F and search for the word "#NEW"
#To found the code where the "Skip Letter By Letter mode", search for "# SKIP"
#
# You can found all the command list on my website
# rmxp.dubealex.com
# Go in the "Script" section.


#==============================================================================
# ■ Window_Message
#==============================================================================
class Window_Message < Window_Selectable
# 一文字ずつ描写
DEFAULT_TYPING_ENABLE = true # falseにすると瞬間表示
#--------------------------------------------------------------------------
# ● オブジェクト初期化
#--------------------------------------------------------------------------
alias xrxs9_initialize initialize
def initialize

$fontface = $defaultfonttype
$fontsize = $defaultfontsize

# IF for any reasons the FONT doesn't appears in your game, this is
# because you are using a different version of RMXP. Look in the class MAIN
# (under this one)
# Go at line #10 and #12, and just copy the word that begins with a $ sign
# and replace what is after the equal sign on lign #27 and 28 of this class.

xrxs9_initialize
# 再生サウンド名がない場合は""とする
if $soundname_on_speak == nil then
$soundname_on_speak = ""
end
# 外字ファイルパス設定
$gaiji_file = "./Graphics/Gaiji/sample.png"
# 外字データ読み込み
if FileTest.exist?($gaiji_file)
@gaiji_cache = Bitmap.new($gaiji_file)
else
@gaigi_cache = nil
end
# 文字透過転送用バッファ
@opacity_text_buf = Bitmap.new(32, 32)
end
#--------------------------------------------------------------------------
# ● メッセージ終了処理
#--------------------------------------------------------------------------
alias xrxs9_terminate_message terminate_message
def terminate_message
if @name_window_frame != nil
@name_window_frame.dispose
@name_window_frame = nil
end
if @name_window_text != nil
@name_window_text.dispose
@name_window_text = nil
end
xrxs9_terminate_message
end
#--------------------------------------------------------------------------
# ● リフレッシュ
#--------------------------------------------------------------------------
def refresh
# 初期化
self.contents.clear
self.contents.font.color = normal_color
self.contents.font.name = $fontface
@x = @y = @max_x = @max_y = @indent = @lines = 0
@face_indent = 0
@opacity = 255
@cursor_width = 0
@write_speed = 0
@write_wait = 0
@mid_stop = false
@face_file = nil
# @popchar が -2 の場合、標準位置。-1の場合、文字センター。
# 0以上の場合 キャラポップ。0は主人公、1以降はイベント。
@popchar = -2
# 選択肢なら字下げを行う
if $game_temp.choice_start == 0
@x = 8
end
# 表示待ちのメッセージが・る場合
if $game_temp.message_text != nil
@now_text = $game_temp.message_text
# 顔表示指定Fが・るか?
if (/A[Ff][(.+?)]/.match(@now_text))!=nil then
# ファイルチェック
if FileTest.exist?("Graphics/Pictures/" + $1 + ".png")
# 顔グラを描画
@face_file = $1 + ".png"
self.contents.blt(16, 16, RPG::Cache.picture(@face_file), Rect.new(0, 0, 96, 96))
# 全行 128ピクセルのインデントを入れる。
@x = @face_indent = 128
end
@now_text.gsub!(/[Ff][(.*?)]/) { "" }
end
# 制御文字処理
begin
last_text = @now_text.clone
# Vを独自ルーチンに変更(追加部分)
@now_text.gsub!(/[Vv][([IiWwAaSs]?)([0-9]+)]/) { convart_value($1, $2.to_i) }
end until @now_text == last_text
@now_text.gsub!(/[Nn][([0-9]+)]/) do
$game_actors[$1.to_i] != nil ? $game_actors[$1.to_i].name : ""
end

#NEW
#Dubealex Show Monster Name Feature
@now_text.gsub!(/[Mm][([0-9]+)]/) do
$data_enemies[$1.to_i] != nil ? $data_enemies[$1.to_i].name : ""
end
#End new command

#NEW
#Dubealex Show Item Price Feature
@now_text.gsub!(/[Pp]rice[([0-9]+)]/) do
$data_items[$1.to_i] != nil ? $data_items[$1.to_i].price : ""
end
#End new command

#NEW
#Dubealex Show Hero Class Name Feature
@now_text.gsub!(/[Cc]lass[([0-9]+)]/) do
$data_classes[$data_actors[$1.to_i].class_id] != nil ? $data_classes[$data_actors[$1.to_i].class_id].name : ""
end
#End new command

#NEW
#Dubealex Show Current Map Name Feature
@now_text.gsub!(/[Mm]ap/) do
$game_map.name != nil ? $game_map.name : ""
end
#End new command

# nameが・るか?
name_window_set = false
if (/[Nn]ame[(.+?)]/.match(@now_text)) != nil
# 値を設定
name_window_set = true
name_text = $1
# name[]部分を削除
@now_text.sub!(/[Nn]ame[(.*?)]/) { "" }
end
# ウィンドウ位置判定
if (/[Pp][([-1,0-9]+)]/.match(@now_text))!=nil then
@popchar = $1.to_i
if @popchar == -1
@x = @indent = 48
@y = 4
end
@now_text.gsub!(/[Pp][([-1,0-9]+)]/) { "" }
end
# ウィンドウ幅の取得
@max_choice_x = 0
if @popchar >= 0
@text_save = @now_text.clone
@max_x = 0
@max_y = 4
for i in 0..3
line = @now_text.split(/n/)[3-i]
@max_y -= 1 if line == nil and @max_y <= 4-i
next if line == nil
line.gsub!(/w[(w+)]/) { "" }
cx = contents.text_size(line).width
@max_x = cx if cx > @max_x
if i >= $game_temp.choice_start
@max_choice_x = cx if cx > @max_choice_x
end
end
self.width = @max_x + 32 + @face_indent
self.height = (@max_y - 1) * 32 + 64
@max_choice_x -= 68
@max_choice_x -= @face_indent*216/128
else
@max_x = self.width - 32 - @face_indent
for i in 0..3
line = @now_text.split(/n/)[i]
next if line == nil
line.gsub!(/w[(w+)]/) { "" }
cx = contents.text_size(line).width
if i >= $game_temp.choice_start
@max_choice_x = cx if cx > @max_choice_x
end
end
@max_choice_x += 8
end
# 選択肢ならカーソルの幅を更新
@cursor_width = 0
#if @lines >= $game_temp.choice_start
# @cursor_width = [@cursor_width, @max_choice_x - @face_indent].max
#end
# 便宜上、"" を "00" に変換
@now_text.gsub!(//) { "00" }
# "C" を "01" に、"G" を "02" に、
# "S" を "03" に、"A" を "04" に変換
@now_text.gsub!(/[Cc][([0123456789ABCDEF#]+)]/) { "01[#{$1}]" }
@now_text.gsub!(/[Gg]/) { "02" }
@now_text.gsub!(/[Ss][([0-9]+)]/) { "03[#{$1}]" }
@now_text.gsub!(/[Aa][(.*?)]/) { "04[#{$1}]" }

#NEW
#Dubealex Font Change Features
@now_text.gsub!(/[Tt][(.*?)]/) { "50[#{$1}]" }
#End of dubealex feature

@now_text.gsub!(/[.]/) { "05" }
@now_text.gsub!(/[|]/) { "06" }
# 競合すると何かと気まずいので、16以降を使用する
@now_text.gsub!(/[>]/) { "16" }
@now_text.gsub!(/[<]/) { "17" }
@now_text.gsub!(/[!]/) { "20" }
@now_text.gsub!(/[~]/) { "21" }
@now_text.gsub!(/[Ee][([0-9]+)]/) { "22[#{$1}]" }
# インデント設定(追加部分)
@now_text.gsub!(/[Ii]/) { "23" }
# テキスト透過率指定(追加部分)
@now_text.gsub!(/[Oo][([0-9]+)]/) { "24[#{$1}]" }
# テキストサイズ指定(追加部分)
@now_text.gsub!(/[Hh][([0-9]+)]/) { "25[#{$1}]" }
# 空白挿入(追加部分)
@now_text.gsub!(/[Bb][([0-9]+)]/) { "26[#{$1}]" }
# ルビ表示(追加部分)
@now_text.gsub!(/[Rr][(.*?)]/) { "27[#{$1}]" }
# ここで一旦ウィンドウ位置更新
reset_window
# nameが・るか?
if name_window_set
# オフセット位置
off_x = 0
off_y = -10
# 枠だけウィンドウの作成(余白を 2 に設定)
space = 2
x = self.x + off_x - space / 2
y = self.y + off_y - space / 2
w = self.contents.text_size(name_text).width + 8 + space
h = 26 + space
@name_window_frame = Window_Frame.new(x, y, w, h)
@name_window_frame.z = self.z + 1
# 擬似的な空中文字描写ウィンドウを作成
x = self.x + off_x + 4
y = self.y + off_y
@name_window_text = Air_Text.new(x, y, name_text)
@name_window_text.z = self.z + 2
end
end
# ウィンドウを更新
reset_window
# 選択肢の場合
if $game_temp.choice_max > 0
@item_max = $game_temp.choice_max
self.active = true
self.index = 0
end
# 数値入力の場合
if $game_temp.num_input_variable_id > 0
digits_max = $game_temp.num_input_digits_max
number = $game_variables[$game_temp.num_input_variable_id]
@input_number_window = Window_InputNumber.new(digits_max)
@input_number_window.number = number
@input_number_window.x = self.x + 8
@input_number_window.y = self.y + $game_temp.num_input_start * 32
end
end
#--------------------------------------------------------------------------
# ● フレーム更新
#--------------------------------------------------------------------------
def update
super
# フェードインの場合
if @fade_in
self.contents_opacity += 24
if @input_number_window != nil
@input_number_window.contents_opacity += 24
end
if self.contents_opacity == 255
@fade_in = false
end
return
end
@now_text = nil if @now_text == "" # 変換
# 表示待ちのメッセージが・る場合
if @now_text != nil and @mid_stop == false
if @write_wait > 0
@write_wait -= 1
return
end
text_not_skip = DEFAULT_TYPING_ENABLE
while true
# 最大 x y の保存。
@max_x = @x if @max_x < @x
@max_y = @y if @max_y < @y
# c に 1 文字を取得 (文字が取得できなくなるまでループ)
if (c = @now_text.slice!(/./m)) != nil
# の場合
if c == "00"
# 本来の文字に戻す
c = ""
end
# C[n] の場合

if c == "01"
@now_text.sub!(/[([0123456789ABCDEF#]+)]/, "")
temp_color = $1
color = temp_color.to_i
leading_x = temp_color.to_s.slice!(/./m)
if leading_x == "#"
self.contents.font.color = hex_color(temp_color)
next
end
if color >= 0 and color <= 7
self.contents.font.color = text_color(color)
end
next
end

# G の場合
if c == "02"
# ゴールドウィンドウを作成
if @gold_window == nil and @popchar <= 0
@gold_window = Window_Gold.new
@gold_window.x = 560 - @gold_window.width
if $game_temp.in_battle
@gold_window.y = 192
else
@gold_window.y = self.y >= 128 ? 32 : 384
end
@gold_window.opacity = self.opacity
@gold_window.back_opacity = self.back_opacity
end
# 次の文字へ
c = ""
end
# S[n] の場合
if c == "03"
# 文字色を変更
@now_text.sub!(/[([0-9]+)]/, "")
speed = $1.to_i
if speed >= 0 and speed <= 19
@write_speed = speed
end
# 次の文字へ
c = ""
end
# A[soundname] の場合
if c == "04"
# 再生ファイルを変更するための準備
@now_text.sub!(/[(.*?)]/, "")
buftxt = $1.dup.to_s
# 再生ファイル名に"/"が・るか?
if buftxt.match(///) == nil and buftxt != "" then
# なければ"Audio/SE/"を結合する
$soundname_on_speak = "Audio/SE/" + buftxt
else
# ・ればそのままコピー
$soundname_on_speak = buftxt.dup
end
# 次の文字へ
c = ""
elsif c == "04"
# 次の文字へ
c = ""
end
# . の場合
if c == "05"
@write_wait += 5
c = ""
end
# | の場合
if c == "06"
@write_wait += 20
c = ""
end
# > の場合
if c == "16"
text_not_skip = false
c = ""
end
# <の場合
if c == "17"
text_not_skip = true
c = ""
end
# !の場合
if c == "20"
@mid_stop = true
c = ""
end
# ~の場合
if c == "21"
terminate_message
return
end
# Iの場合(追加部分)
if c == "23"
# 今の@xをインデント位置に設定
@indent = @x
c = ""
end
# Oの場合(追加部分)
if c == "24"
@now_text.sub!(/[([0-9]+)]/, "")
@opacity = $1.to_i
color = self.contents.font.color
self.contents.font.name = $fontface
self.contents.font.color = Color.new(color.red, color.green, color.blue, color.alpha * @opacity / 255)
c = ""
end
# Hの場合(追加部分)
if c == "25"
@now_text.sub!(/[([0-9]+)]/, "")
self.contents.font.size = [[$1.to_i, 6].max, 32].min
c = ""
end
# Bの場合(追加部分)
if c == "26"
@now_text.sub!(/[([0-9]+)]/, "")
@x += $1.to_i
c = ""
end

#NEW
#Dubealex Font Change Command
if c == "50"
@now_text.sub!(/[(.*?)]/, "")
buftxt = $1.dup.to_s
if buftxt.match(///) == nil and buftxt != "" then
self.contents.font.name = buftxt
end
c = ""
end
#end of font change command

# Rの場合(追加部分)
if c == "27"
@now_text.sub!(/[(.*?)]/, "")
# 文字を描画
@x += ruby_draw_text(self.contents, @x, @y * line_height + (line_height - self.contents.font.size), $1, @opacity)
# 文字描写のSEを演奏
if $soundname_on_speak != ""
Audio.se_play($soundname_on_speak)
end
c = ""
end
# アイコン描画用シーケンスの場合(追加部分)
if c == "30"
# アイコンファイル名を取得
@now_text.sub!(/[(.*?)]/, "")
# アイコンを描画
self.contents.blt(@x , @y * line_height + 8, RPG::Cache.icon($1), Rect.new(0, 0, 24, 24))
# 文字描写のSEを演奏
if $soundname_on_speak != ""
Audio.se_play($soundname_on_speak)
end
@x += 24
# 次の文字へ
c = ""
end
# 改行文字の場合
if c == "n"
# y に 1 を加算
@lines += 1
@y += 1
@x = 0 + @indent + @face_indent
# 選択肢なら字下げを行う
if @lines >= $game_temp.choice_start
@x = 8 + @indent + @face_indent
# カーソルの更新
@cursor_width = @max_choice_x
end
# 次の文字へ
c = ""
end
# 外字表示の場合
if c == "22"
# []部分の除去
@now_text.sub!(/[([0-9]+)]/, "")
# 外字を表示
@x += gaiji_draw(4 + @x, @y * line_height + (line_height - self.contents.font.size), $1.to_i)
# 次の文字へ
c = ""
end
if c != ""
# 文字を描画
self.contents.draw_text(0+@x, 32 * @y, 40, 32, c)
@x += self.contents.text_size(c).width
# 文字描写のSEを演奏
if $soundname_on_speak != "" then
Audio.se_play($soundname_on_speak)
end
end
# Bボタンが押された場合

# SKIP
# This allow you to SKIP the letter by letter using a button
# At your own choice
# Here's how to customize it:
# Replace the letter in the end of the line "if Input.trigger?(Input::C)"
# That is on line #512
# By the letter of your choice:
#
# B = Escape, 0 (On The NumPad), X
# C = Enter, Space Bar and C
# A = Shift, Z
if Input.press?(Input::C)
text_not_skip = false
end
else
text_not_skip = true
break
end
# 終了判定
if text_not_skip
break
end
end
@write_wait += @write_speed
return
end
# 数値入力中の場合
if @input_number_window != nil
@input_number_window.update
# 決定
if Input.trigger?(Input::C)
$game_system.se_play($data_system.decision_se)
$game_variables[$game_temp.num_input_variable_id] =
@input_number_window.number
$game_map.need_refresh = true
# 数値入力ウィンドウを解放
@input_number_window.dispose
@input_number_window = nil
terminate_message
end
return
end
# メッセージ表示中の場合
if @contents_showing
# 選択肢の表示中でなければポーズサインを表示
if $game_temp.choice_max == 0
self.pause = true
end


if Input.trigger?(Input::B)
if $game_temp.choice_max > 0 and $game_temp.choice_cancel_type > 0
$game_system.se_play($data_system.cancel_se)
$game_temp.choice_proc.call($game_temp.choice_cancel_type - 1)
terminate_message
end
end

if Input.trigger?(Input::C)
if $game_temp.choice_max > 0
$game_system.se_play($data_system.decision_se)
$game_temp.choice_proc.call(self.index)
end
if @mid_stop
@mid_stop = false
return
else
terminate_message
end
end
return
end
# フェードアウト中以外で表示待ちのメッセージか選択肢が・る場合
if @fade_out == false and $game_temp.message_text != nil
@contents_showing = true
$game_temp.message_window_showing = true
refresh
Graphics.frame_reset
self.visible = true
self.contents_opacity = 0
if @input_number_window != nil
@input_number_window.contents_opacity = 0
end
@fade_in = true
return
end
# 表示すべきメッセージがないが、ウィンドウが可視状態の場合
if self.visible
@fade_out = true
self.opacity -= 48
if self.opacity == 0
self.visible = false
@fade_out = false
$game_temp.message_window_showing = false
end
return
end
end
#--------------------------------------------------------------------------
# ● キャラクターの取得
# parameter : パラメータ
#--------------------------------------------------------------------------
def get_character(parameter)
# パラメータで分岐
case parameter
when 0 # プレイヤー
return $game_player
else # 特定のイベント
events = $game_map.events
return events == nil ? nil : events[parameter]
end
end
#--------------------------------------------------------------------------
# ● ウィンドウの位置と不透明度の設定
#--------------------------------------------------------------------------
def reset_window
# 判定
if @popchar >= 0
events = $game_map.events
if events != nil
character = get_character(@popchar)
x = [[character.screen_x - 0 - self.width / 2, 4].max, 636 - self.width].min
y = [[character.screen_y - 48 - self.height, 4].max, 476 - self.height].min
self.x = x
self.y = y
end
elsif @popchar == -1
self.x = -4
self.y = -4
self.width = 648
self.height = 488
else
if $game_temp.in_battle
self.y = 16
else
case $game_system.message_position
when 0 # 上
self.y = 16
when 1 # 中
self.y = 160
when 2 # 下
self.y = 304
end
self.x = 80
if @face_file == nil
self.width = 480
else
self.width = 600
self.x -= 60
end
self.height = 160
end
end
self.contents = Bitmap.new(self.width - 32, self.height - 32)
self.contents.font.color = normal_color
self.contents.font.name = $fontface
if @face_file != nil
self.contents.blt(16, 16, RPG::Cache.picture(@face_file), Rect.new(0, 0, 96, 96))
end
if @popchar == -1
self.opacity = 255
self.back_opacity = 0
elsif $game_system.message_frame == 0
self.opacity = 255
self.back_opacity = 160
else
self.opacity = 0
self.back_opacity = 160
end
end
#--------------------------------------------------------------------------
# ● 外字描画
#--------------------------------------------------------------------------
# x   :x座標
# y   :y座標
# num  :外字番号
# 返り値:外字幅(@x増加値)
#--------------------------------------------------------------------------
def gaiji_draw(x, y, num)
# 外字データが存在しない場合は何もしない
if @gaiji_cache == nil
return 0
else
# 指定した外字がキャッシュ範囲を超えている場合は何もしない
if @gaiji_cache.width < num * 24
return 0
end

# 文字サイズを計算
if self.contents.font.size >= 20 and self.contents.font.size <= 24
size = 24
else
size = self.contents.font.size * 100 * 24 / 2200
end

# 外字データをstretch_bltで転送
self.contents.stretch_blt(Rect.new(x, y, size, size), @gaiji_cache, Rect.new(num * 24, 0, 24, 24))

# 文字描写のSEを演奏
if $soundname_on_speak != "" then
Audio.se_play($soundname_on_speak)
end

# 文字サイズを返す
return size
end
end
#--------------------------------------------------------------------------
# ● line_height
#--------------------------------------------------------------------------
# 返り値:行の高さ(@y増加値)を返します。
#--------------------------------------------------------------------------
def line_height
# 現状、選択肢等に対応ができない為、自動的に32を返します。
return 32

# 文字サイズを計算
if self.contents.font.size >= 20 and self.contents.font.size <= 24
return 32
else
return self.contents.font.size * 15 / 10
end
end
#--------------------------------------------------------------------------
# ● ルビ文字描画
#--------------------------------------------------------------------------
# target :描画対象。Bitmapクラスを指定。
# x :x座標
# y :y座標
# str  :描画文字列。本文,ルビの形式で入力。
#      ,区切りが2つ以上・った場合は自動的に無視される。
# opacity:透過率(0~255)
# 返り値 :文字幅(@x増加値)。
#--------------------------------------------------------------------------
def ruby_draw_text(target, x, y, str,opacity)
# フォントサイズをバックアップしておく
sizeback = target.font.size
# ルビサイズの計算
target.font.size * 3 / 2 > 32 ? rubysize = 32 - target.font.size : rubysize = target.font.size / 2
rubysize = [rubysize, 6].max

# opacityに規定値以上の値が入っている場合は修正。
opacity = [[opacity, 0].max, 255].min
# strをsplitで分割し、split_sに格納
split_s = str.split(/,/)

# split_sがnilの場合は""にしておく(誤動作防止)
split_s[0] == nil ? split_s[0] = "" : nil
split_s[1] == nil ? split_s[1] = "" : nil

# heightとwidthを計算
height = sizeback + rubysize
width = target.text_size(split_s[0]).width

# バッファ用の幅計算(ルビの幅が本文の幅を越える可能性が・る為)
target.font.size = rubysize
ruby_width = target.text_size(split_s[1]).width
target.font.size = sizeback

buf_width = [target.text_size(split_s[0]).width, ruby_width].max

# 本文の描画幅とルビの描画幅の差を1/2にして変数に格納(後で使用)
width - ruby_width != 0 ? sub_x = (width - ruby_width) / 2 : sub_x = 0

# opacityが255(透過なし)の場合は通常描画
if opacity == 255
# ルビの描画
target.font.size = rubysize
target.draw_text(x + sub_x, y - target.font.size, target.text_size(split_s[1]).width, target.font.size, split_s[1])
target.font.size = sizeback
# 本文の描画
target.draw_text(x, y, width, target.font.size, split_s[0])
return width
else
# 表示テキストのheight、widthがバッファサイズを上回る場合は
# バッファを再生成する。
if @opacity_text_buf.width < buf_width or @opacity_text_buf.height < height
@opacity_text_buf.dispose
@opacity_text_buf = Bitmap.new(buf_width, height)
# そうでない場合はバッファクリア。
else
@opacity_text_buf.clear
end
# バッファにテキスト描画
# ルビの描画
@opacity_text_buf.font.size = rubysize
@opacity_text_buf.draw_text(0 , 0, buf_width, rubysize, split_s[1], 1)
@opacity_text_buf.font.size = sizeback
# 本文の描画
@opacity_text_buf.draw_text(0 , rubysize, buf_width, sizeback, split_s[0], 1)
# ルビの幅が本文の幅を下回る場合
if sub_x >= 0
target.blt(x, y - rubysize, @opacity_text_buf, Rect.new(0, 0, buf_width, height), opacity)
# ルビの幅が本文の幅を上回る場合
else
target.blt(x + sub_x, y - rubysize, @opacity_text_buf, Rect.new(0, 0, buf_width, height), opacity)
end
# 文字サイズを返す
return width
end
end
#--------------------------------------------------------------------------
# ● V変換
#--------------------------------------------------------------------------
# option :オプション。無指定又は規定外の場合はindexのユーザ変数値を返す。
# index :インデックス
# 返り値 :変換結果(アイコン表示用シーケンス込み)
#--------------------------------------------------------------------------
def convart_value(option, index)
# optionがnilの場合は""に直す(誤動作防止)
option == nil ? option = "" : nil

# optionはdowncaseしておく。
option.downcase!

# �30はアイコン表示用のシーケンス。30[アイコンファイル名]で定義。
case option
when "i"
unless $data_items[index].name == nil
r = sprintf("30[%s]%s", $data_items[index].icon_name, $data_items[index].name)
end
when "w"
unless $data_weapons[index].name == nil
r = sprintf("30[%s]%s", $data_weapons[index].icon_name, $data_weapons[index].name)
end
when "a"
unless $data_armors[index].name == nil
r = sprintf("30[%s]%s", $data_armors[index].icon_name, $data_armors[index].name)
end
when "s"
unless $data_skills[index].name == nil
r = sprintf("30[%s]%s", $data_skills[index].icon_name, $data_skills[index].name)
end
else
r = $game_variables[index]
end

r == nil ? r = "" : nil
return r
end
#--------------------------------------------------------------------------
# ● 解放
#--------------------------------------------------------------------------
def dispose
terminate_message

# 外字キャッシュ開放
if @gaiji_cache != nil
unless @gaiji_cache.disposed?
@gaiji_cache.dispose
end
end

# 文字透過転送用バッファ開放
unless @opacity_text_buf.disposed?
@opacity_text_buf.dispose
end

$game_temp.message_window_showing = false
if @input_number_window != nil
@input_number_window.dispose
end
super
end
#--------------------------------------------------------------------------
# ● カーソルの矩形更新
#--------------------------------------------------------------------------
def update_cursor_rect
if @index >= 0
n = $game_temp.choice_start + @index
self.cursor_rect.set(8 + @indent + @face_indent, n * 32, @cursor_width, 32)
else
self.cursor_rect.empty
end
end
end
#==============================================================================
# ■ Window_Frame (枠だけで中身の無いウィンドウ)
#==============================================================================
class Window_Frame < Window_Base
#--------------------------------------------------------------------------
# ● オブジェクト初期化
#--------------------------------------------------------------------------
def initialize(x, y, width, height)
super(x, y, width, height)
self.contents = nil
#self.back_opacity = 240
end
#--------------------------------------------------------------------------
# ● 解放
#--------------------------------------------------------------------------
def dispose
super
end
end
#==============================================================================
# ■ Air_Text (何も無いところに文字描写 = 枠の無い瞬間表示メッセージウィンドウ)
#==============================================================================
class Air_Text < Window_Base
#--------------------------------------------------------------------------
# ● オブジェクト初期化
#--------------------------------------------------------------------------
def initialize(x, y, designate_text)
super(x-16, y-16, 32 + designate_text.size * 12, 56)
self.opacity = 0
self.back_opacity = 0
self.contents = Bitmap.new(self.width - 32, self.height - 32)
w = self.contents.width
h = self.contents.height
self.contents.font.name = $fontface
self.contents.font.color = normal_color
self.contents.draw_text(0, 0, w, h, designate_text)
end
#--------------------------------------------------------------------------
# ● 解放
#--------------------------------------------------------------------------
def dispose
self.contents.clear
super
end
end
Voila le script est fini
---------------------------------------------------------------------------
Ceci est un script vous permettant de depasser le lv 99 et vos caracteristiques pourront aussi dépasser le max:creer un fichier en dessus de main et coller le code ci-dessous:
#LV限界突破
# Liste des limites de stat, de hp, de sp et de niveau!!
BASE_FINAL_LEVEL = 9999 #上限レベル(あんまり大きな値を設定するとハングします)
MAXHP_LIMIT = 99999999 #HP限界値
MAXSP_LIMIT = 99999999 #SP限界値
STR_LIMIT = 999999 #STR限界値
DEX_LIMIT = 999999 #DEX限界値
AGI_LIMIT = 999999 #AGI限界値
INT_LIMIT = 999999 #INT限界値

class Game_Actor < Game_Battler
def new_final_level
lv = BASE_FINAL_LEVEL
#以下上限LV個別指定用
#case self.id
#when 1
# lv = 255
#when 2
# lv = 999
#when 8
# lv = 15600
#end
return lv
end
#--------------------------------------------------------------------------
# ● EXP 計算
#--------------------------------------------------------------------------
def make_exp_list
actor = $data_actors[@actor_id]
@exp_list = Array.new(new_final_level + 2)
@exp_list[1] = 0
pow_i = 2.4 + actor.exp_inflation / 100.0
for i in 2..new_final_level + 1
if i > new_final_level
@exp_list[i] = 0
else
n = actor.exp_basis * ((i + 3) ** pow_i) / (5 ** pow_i)
@exp_list[i] = @exp_list[i-1] + Integer(n)
end
end
end
#--------------------------------------------------------------------------
# ● MaxHP の取得
#--------------------------------------------------------------------------
def maxhp
n = [[base_maxhp + @maxhp_plus, 1].max, MAXHP_LIMIT].min
for i in @states
n *= $data_states[i].maxhp_rate / 100.0
end
n = [[Integer(n), 1].max, MAXHP_LIMIT].min
return n
end
#--------------------------------------------------------------------------
# ● 基本 MaxHP の取得
#--------------------------------------------------------------------------
def base_maxhp
n = $data_actors[@actor_id].parameters[0, 1]
n += $data_actors[@actor_id].parameters[0, 2] * @level
return n
end
#--------------------------------------------------------------------------
# ● 基本 MaxSP の取得
#--------------------------------------------------------------------------
def base_maxsp
n = $data_actors[@actor_id].parameters[1, 1]
n += $data_actors[@actor_id].parameters[1, 2] * @level
return n
end
#--------------------------------------------------------------------------
# ● 基本腕力の取得
#--------------------------------------------------------------------------
def base_str
n = $data_actors[@actor_id].parameters[2, 1]
n += $data_actors[@actor_id].parameters[2, 2] * @level
weapon = $data_weapons[@weapon_id]
armor1 = $data_armors[@armor1_id]
armor2 = $data_armors[@armor2_id]
armor3 = $data_armors[@armor3_id]
armor4 = $data_armors[@armor4_id]
n += weapon != nil ? weapon.str_plus : 0
n += armor1 != nil ? armor1.str_plus : 0
n += armor2 != nil ? armor2.str_plus : 0
n += armor3 != nil ? armor3.str_plus : 0
n += armor4 != nil ? armor4.str_plus : 0
return [[n, 1].max, STR_LIMIT].min
end
#--------------------------------------------------------------------------
# ● 基本器用さの取得
#--------------------------------------------------------------------------
def base_dex
n = $data_actors[@actor_id].parameters[3, 1]
n += $data_actors[@actor_id].parameters[3, 2] * @level
weapon = $data_weapons[@weapon_id]
armor1 = $data_armors[@armor1_id]
armor2 = $data_armors[@armor2_id]
armor3 = $data_armors[@armor3_id]
armor4 = $data_armors[@armor4_id]
n += weapon != nil ? weapon.dex_plus : 0
n += armor1 != nil ? armor1.dex_plus : 0
n += armor2 != nil ? armor2.dex_plus : 0
n += armor3 != nil ? armor3.dex_plus : 0
n += armor4 != nil ? armor4.dex_plus : 0
return [[n, 1].max, DEX_LIMIT].min
end
#--------------------------------------------------------------------------
# ● 基本素早さの取得
#--------------------------------------------------------------------------
def base_agi
n = $data_actors[@actor_id].parameters[4, 1]
n += $data_actors[@actor_id].parameters[4, 2] * @level
weapon = $data_weapons[@weapon_id]
armor1 = $data_armors[@armor1_id]
armor2 = $data_armors[@armor2_id]
armor3 = $data_armors[@armor3_id]
armor4 = $data_armors[@armor4_id]
n += weapon != nil ? weapon.agi_plus : 0
n += armor1 != nil ? armor1.agi_plus : 0
n += armor2 != nil ? armor2.agi_plus : 0
n += armor3 != nil ? armor3.agi_plus : 0
n += armor4 != nil ? armor4.agi_plus : 0
return [[n, 1].max, AGI_LIMIT].min
end
#--------------------------------------------------------------------------
# ● 基本魔力の取得
#--------------------------------------------------------------------------
def base_int
n = $data_actors[@actor_id].parameters[5, 1]
n += $data_actors[@actor_id].parameters[5, 2] * @level
weapon = $data_weapons[@weapon_id]
armor1 = $data_armors[@armor1_id]
armor2 = $data_armors[@armor2_id]
armor3 = $data_armors[@armor3_id]
armor4 = $data_armors[@armor4_id]
n += weapon != nil ? weapon.int_plus : 0
n += armor1 != nil ? armor1.int_plus : 0
n += armor2 != nil ? armor2.int_plus : 0
n += armor3 != nil ? armor3.int_plus : 0
n += armor4 != nil ? armor4.int_plus : 0
return [[n, 1].max, INT_LIMIT].min
end
#--------------------------------------------------------------------------
# ● EXP の変更
# exp : 新しい EXP
#--------------------------------------------------------------------------
def exp=(exp)
# ★EXPの上限チェックを解除
@exp = [exp, 0].max
# レベルアップ
while @exp >= @exp_list[@level+1] and @exp_list[@level+1] > 0
@level += 1
# スキル習得
for j in $data_classes[@class_id].learnings
if j.level == @level
learn_skill(j.skill_id)
end
end
end
# レベルダウン
while @exp < @exp_list[@level]
@level -= 1
end
# 現在の HP と SP が最大値を超えていたら修正
@hp = [@hp, self.maxhp].min
@sp = [@sp, self.maxsp].min
end
#--------------------------------------------------------------------------
# ● レベルの変更
# level : 新しいレベル
#--------------------------------------------------------------------------
def level=(level)
# 上下限チェック
# ★LV上限をnew_final_levelでチェックするように変更
level = [[level, new_final_level].min, 1].max
# EXP を変更
self.exp = @exp_list[level]
end
end


class Game_Battler
#--------------------------------------------------------------------------
# ● MaxSP の取得
#--------------------------------------------------------------------------
def maxsp
n = [[base_maxsp + @maxsp_plus, 0].max, MAXSP_LIMIT].min
for i in @states
n *= $data_states[i].maxsp_rate / 100.0
end
n = [[Integer(n), 0].max, MAXSP_LIMIT].min
return n
end
#--------------------------------------------------------------------------
# ● 腕力の取得
#--------------------------------------------------------------------------
def str
n = [[base_str + @str_plus, 1].max, STR_LIMIT].min
for i in @states
n *= $data_states[i].str_rate / 100.0
end
n = [[Integer(n), 1].max, STR_LIMIT].min
return n
end
#--------------------------------------------------------------------------
# ● 器用さの取得
#--------------------------------------------------------------------------
def dex
n = [[base_dex + @dex_plus, 1].max, DEX_LIMIT].min
for i in @states
n *= $data_states[i].dex_rate / 100.0
end
n = [[Integer(n), 1].max, DEX_LIMIT].min
return n
end
#--------------------------------------------------------------------------
# ● 素早さの取得
#--------------------------------------------------------------------------
def agi
n = [[base_agi + @agi_plus, 1].max, AGI_LIMIT].min
for i in @states
n *= $data_states[i].agi_rate / 100.0
end
n = [[Integer(n), 1].max, AGI_LIMIT].min
return n
end
#--------------------------------------------------------------------------
# ● 魔力の取得
#--------------------------------------------------------------------------
def int
n = [[base_int + @int_plus, 1].max, INT_LIMIT].min
for i in @states
n *= $data_states[i].int_rate / 100.0
end
n = [[Integer(n), 1].max, INT_LIMIT].min
return n
end
#--------------------------------------------------------------------------
# ● MaxHP の設定
# maxhp : 新しい MaxHP
#--------------------------------------------------------------------------
def maxhp=(maxhp)
@maxhp_plus += maxhp - self.maxhp
@maxhp_plus = [[@maxhp_plus, -MAXHP_LIMIT].max, MAXHP_LIMIT].min
@hp = [@hp, self.maxhp].min
end
#--------------------------------------------------------------------------
# ● MaxSP の設定
# maxsp : 新しい MaxSP
#--------------------------------------------------------------------------
def maxsp=(maxsp)
@maxsp_plus += maxsp - self.maxsp
@maxsp_plus = [[@maxsp_plus, -MAXSP_LIMIT].max, MAXSP_LIMIT].min
@sp = [@sp, self.maxsp].min
end
#--------------------------------------------------------------------------
# ● 腕力の設定
# str : 新しい腕力
#--------------------------------------------------------------------------
def str=(str)
@str_plus += str - self.str
@str_plus = [[@str_plus, -STR_LIMIT].max, STR_LIMIT].min
end
#--------------------------------------------------------------------------
# ● 器用さの設定
# dex : 新しい器用さ
#--------------------------------------------------------------------------
def dex=(dex)
@dex_plus += dex - self.dex
@dex_plus = [[@dex_plus, -DEX_LIMIT].max, DEX_LIMIT].min
end
#--------------------------------------------------------------------------
# ● 素早さの設定
# agi : 新しい素早さ
#--------------------------------------------------------------------------
def agi=(agi)
@agi_plus += agi - self.agi
@agi_plus = [[@agi_plus, -AGI_LIMIT].max, AGI_LIMIT].min
end
#--------------------------------------------------------------------------
# ● 魔力の設定
# int : 新しい魔力
#--------------------------------------------------------------------------
def int=(int)
@int_plus += int - self.int
@int_plus = [[@int_plus, -INT_LIMIT].max, INT_LIMIT].min
end
end

Voilà le script est fini ! a:link { color:#6699FF;
 
  Tu as eu aujourd'hui : 41510 visiteurs (78750 hits) Sur ton site !  
 
1993-2009 Zonemaker Tous droits réservés - All rights reserved Ce site web a été créé gratuitement avec Ma-page.fr. Tu veux aussi ton propre site web ?
S'inscrire gratuitement