Per 2016, RMID pindah ke RMID Discord (Invite link dihapus untuk mencegah spambot -Theo @ 2019). Posting sudah tidak bisa dilakukan lagi.
Mohon maaf atas ketidaknyamanannya dan mohon kerjasamanya.

Share | 
 

 [Solved] MoonMan Wall Tile Extension

Topik sebelumnya Topik selanjutnya Go down 
[Solved] MoonMan Wall Tile Extension Empty2012-05-06, 15:41
Post[Solved] MoonMan Wall Tile Extension
#1
yade26 
Novice
Novice
yade26

Level 5
Posts : 132
Thanked : 0
Engine : RMVX Ace
Skill : Skilled
Type : Scripter

[Solved] MoonMan Wall Tile Extension Vide
Gan, ada yg tau gk script Moonman Wall Tile Extension...
di Rpgmakervx.net link demonya udh mati... :cry:
klo bisa share disini...???

juga sekalian klo bisa... tolong jelasin mengenai script ini.... :shocked:
[Solved] MoonMan Wall Tile Extension Empty2012-05-06, 15:44
PostRe: [Solved] MoonMan Wall Tile Extension
#2
marjoni01 
Senior
Senior
marjoni01

Level 5
Posts : 971
Thanked : 5
Engine : RMVX Ace
Skill : Intermediate
Type : Developer

[Solved] MoonMan Wall Tile Extension Vide
:swt: Ini pertanyaan yang aneh..
Kalau gk tahu apa gunanya kenapa minta scriptnya :ngacay2:
Itu hanya buat Seperti tembok2 doang
Dan sayangnya saya juga tidak punya :kabur:
[Solved] MoonMan Wall Tile Extension Empty2012-05-06, 15:54
PostRe: [Solved] MoonMan Wall Tile Extension
#3
Tamu 
Tamu
Anonymous


[Solved] MoonMan Wall Tile Extension Vide
@joni:
Kalau nggak tahu yang jangan nge-junk lah.. :swt:
@yade:
pertama-tama anda salah kamar
harusnya di rgss2 request
Wa punya..
Creditnya dah tau kan..

Wall Tile Extension v1.0
Code:
#============================================================================
#
# ** Wall Tile Extension * Ver1.00 
# * Creator: 月紳士 (Moon Man)    ( http://tsukishinshi.blog73.fc2.com )
#
# * RPG Maker VX RGSS2 Script
#
# * Translation by: Mr. Anonymous ( http://anonymouscreations.we.bs )
#
#============================================================================
=begin

This script chiefly enhances the movement judgment and enables the following
expressions for the wall tiles.

.Basic Features
  The following functions work by using this script:

 * Enables movement behind walls and atop roofs.

 * Reproduction of the XP ceiling conceal, which makes designated tiles conceal
  characters like they did in XP.
 
 * Creates "invisible passage" so you can make secret passages or movement under
  fake bridges.
 
 * Added passability options.

 * A function to create ladders/stairs which penetrate normally impassible tiles.

 * Bridges automatically act as such, having you walk on and under them, at the
  same time if events do it, with no events to control it.

#------------------------------------------------------------------------------

* Tags

 * Bridge Passage Area
    When you need to create a bridge in which the player can move under when in
    a vehicle, first create a new area that contains said bridge, and name the
    area:
            <bridge>

 * Event Behind Roof/Ceiling/Wall/Cliff
    When you need to create an event that rests behind a roof, cieling, wall,
    cliff, etc, (if BACK_SEEING = true, when the player is 1 tile away from this
    event it will also be shown as semi-transparent) create an event and include
    the follow tag in its name:

            <behind>

 * Event Behind Roof/Ceiling/Wall/Cliff (when BACK_SEEING = true)
    When you need to create an event that rests behind a roof, cieling, wall,
    cliff, etc, and is NOT shown as semi-transparent while near it, create an
    event and include the follow tag in its name:

            <hidebehind>

=end

#==============================================================================
# * Customization
#==============================================================================

module Expansion_Passable
  # * Cliff Type Maps
  # In the following array, you may define what maps determined as "Cliff" maps.
  # These allow for recognition of certain tiles to function differently. This
  # is used to create a slope-like effect (different grass tile elevations)
  # for some tiles without making it global across all maps. It's best to test
  # this function out for yourself by testing it in the demo, then remove the
  # 5 (by default) from the array and try it again.
  # Note that since this is an array, it can contain multiple map IDs as such:
  # CLIFF_MAP = [5, 6, 7, 12, 30]
  CLIFF_MAP = [18]
 
  # * True wall depth
  # This allows you to specify whether the player can move down the full depth
  # of the wall or only the first tile. For example, if set as true, and a wall
  # is 3 tiles high + 1 tile for ceiling/roofing, then the player will be able
  # to move all the way down to the base of the wall (down three tiles).
  # It's easier just to test it both ways to understand.
  # true  : Wall depth and player moveability range is increased to wall scale.
  # false : Wall depth and player moveability is fixed at 1 tile.
  BACK_TILE_DEEP = false
 
  # * Display of character behind cieling tiles
  # This allows you to adjust whether the character is visible (semi-transparent)
  # or not displayed at all when the character is behind a roof/ceiling tile.
  # true  : Characters are draw semi-transparent
  # false : Characters are hidden
  BACK_SEEING = true
 
  # * Remove Shadow Tiles ID
  # The "No Shadow" tile indicates a tile that removes and autoshadow tile that
  # would normally be displayed on it. It is used for removing any awkward look
  # that would normally  be produced by creating special hills or cliffs.
  # When not using this feature, set the value as nil.
  SHADOW_ERASER_TILE_ID = 768
 
  # * Prohibit Docking Tile ID
  # The "No Docking" tile indicates a tile that does not allow for a vehicle to
  # 'dock' at. It is used to determine features such as cliffs that the player
  # should not be allowed to dock on, given it would have raised elevation.
  # When not using this feature, set the value as nil.
  PROHIBITED_GET_OFF_TILE_ID = 769

  # * Walk Through Wall Tile ID
  # The "Walk Through" tile indicates a tile that allows the player to walk
  # through it, used specifically for segements where you allow the player to
  # walk through a given wall.
  # When not using this feature, set the value as nil.
  ADDITION_BACK_TILE_ID = 770

  # * Delete Background Tile ID
  # The "No Background" tile indicates a tile that deletes the tile behind it.
  # It is primarily used for determining roof/cieling tiles with the player
  # cannot walk behind.
  # When not using this feature, set the value as nil.
  DELETE_BACK_TILE_ID = 771
  REMOVE_TILE_MARKER = 783
 
end

#==============================================================================
# * Tile customization options (very advanced users only!)
#==============================================================================

module Data_Tile
  # Ceiling, roof, & terrain tile feature setup
  FUNCTION_TILE = [
  2816, 2960,                                    # Plains (field and outdoor)
  3200, 3344,                                    # Dry    (field and outdoor)
  3584, 3728,                                    # Desert (field and outdoor)
  3968, 4016,                                    # Snow  (field and outdoor)
  4352, 4400, 4448, 4496, 4544, 4592, 4640, 4688, # Roof        (1st Column)
  4736, 4784, 4832, 4880, 4928, 4976, 5024, 5072, # Wall        (1st Column)             
  5120, 5168, 5216, 5264, 5312, 5360, 5408, 5456, # Roof        (2nd Column)
  5504, 5552, 5600, 5648, 5696, 5744, 5792, 5840, # Wall        (2nd Column)   
  5888, 5936, 5984, 6032, 6080, 6128, 6176, 6224, # Cave Ceiling (1st Column)
  6272, 6320, 6368, 6416, 6464, 6512, 6560, 6608, # Cave Wall    (1st Column)
  6656, 6704, 6752, 6800, 6848, 6896, 6944, 6992, # Cave Ceiling (2nd Column)
  7040, 7088, 7136, 7184, 7232, 7280, 7328, 7376, # Cave Wall    (2nd Column)
  7424, 7472, 7520, 7568, 7616, 7664, 7712, 7760, # Cave Ceiling (3rd Column)
  7808, 7856, 7904, 7952, 8000, 8048, 8096, 8144, # Cave Wall    (3rd Column)
  1952, 2000]                                    # Dummy TileIDs                 
 
  # * Horizontal bridge TileIDs
  BRIDRE_LENGTH = [17, 808, 810, 812]

  # * Vertical bridge TileIDs
  BRIDGE_BREADTH = [18, 19, 21, 23, 809, 811, 813]
 
  # * TileIDs treated as entrances for stairs, ladders, and caves
  # When the player is on one of these tiles, the passage settings are altered
  # so that the player is constrainted within the tile's ideal passage.
  STEP = [67, 68, 69, 70, 71, 172, 173, 174, 175,
          260, 261, 262, 263, 268, 269, 270,
          271, 278, 279, 284, 285, 286, 287,
          612, 613, 616, 617, 618, 619,
          1600, 1601, 1602, 1603, 1604, 1605, 1606, 1607,
          1608, 1609, 1610, 1611, 1612, 1613, 1614, 1615]     
 
 
  # * TileID for passability determination under bridges
  # The default of TileID 1664 is not visible within the editor and has no in-
  # game image. If not necessary, please do not change this value.
  UNDER_BRIDGE = 1664
 
end

#==============================================================================
# * Please do not change autotile setup
#==============================================================================

module Data_Auto_Tile
  # Array for each direction in which the tiles have an edge (AutotileID)
  # Floor type
  VERGE_DOWN_A  = [28, 29, 30, 31, 33, 38, 39, 40, 41, 43, 44, 45, 46]
  VERGE_LEFT_A  = [16, 17, 18, 19, 32, 34, 35, 40, 41, 42, 43, 44, 46]
  VERGE_RIGHT_A = [24, 25, 26, 27, 32, 36, 37, 38, 39, 42, 44, 45, 46]
  VERGE_UP_A    = [20, 21, 22, 23, 33, 34, 35, 36, 37, 42, 43, 45, 46]
 
  # Wall Type
  VERGE_DOWN_B  = [ 8,  9, 10, 11, 12, 13, 14, 15]
  VERGE_LEFT_B  = [ 1,  3,  5,  7,  9, 11, 13, 15]
  VERGE_RIGHT_B = [ 4,  5,  6,  7, 12, 13, 14, 15]
  VERGE_UP_B    = [ 2,  3,  6,  7, 10, 11, 14, 15]

end

#==============================================================================
# ■ RPG::Area
#==============================================================================

class RPG::Area
  #--------------------------------------------------------------------------
  # ○ 公開インスタンス変数
  #--------------------------------------------------------------------------
  attr_accessor :ship_pass
end

#==============================================================================
# ■ Game_Map
#------------------------------------------------------------------------------
#  マップを扱うクラスです。スクロールや通行可能判定などの機能を持っています。
# このクラスのインスタンスは $game_map で参照されます。
#==============================================================================

class Game_Map
  #--------------------------------------------------------------------------
  # ○ 公開インスタンス変数
  #--------------------------------------------------------------------------
  attr_reader  :under_bridge_passages
  attr_reader  :back_tiles_position
  attr_reader  :keep_back_position
  attr_reader  :ex_data
  attr_reader  :prohibited_get_off
  #--------------------------------------------------------------------------
  # ◎ セットアップ
  #    map_id : マップ ID
  #--------------------------------------------------------------------------
  alias tig_ep_setup setup
  def setup(map_id)
    tig_ep_setup(map_id)
    @ex_data = Table.new(width, height, 3)
    @under_bridge_passages = {}
    @back_tiles_position = []
    @keep_back_position = []
    prohibited_get_off_setup
    setup_back_tiles
    shadow_eraser_tile_setup
  end
  #--------------------------------------------------------------------------
  # ○ 接岸禁止タイルのセットアップ
  #    map_id : マップ ID
  #--------------------------------------------------------------------------
  def prohibited_get_off_setup
    @prohibited_get_off = []
    return if Expansion_Passable::PROHIBITED_GET_OFF_TILE_ID == nil
    for x in 0...width
      for y in 0...height
        if @map.data[x, y, 2] == Expansion_Passable::PROHIBITED_GET_OFF_TILE_ID
          @map.data[x, y, 2] = 0
          @prohibited_get_off.push([x, y])
        end
      end
    end
  end
  #--------------------------------------------------------------------------
  # ○ 影消しタイルのセットアップ
  #--------------------------------------------------------------------------
  def shadow_eraser_tile_setup
    return if Expansion_Passable::SHADOW_ERASER_TILE_ID == nil
    for x in 0...width
      for y in 0...height
        if @map.data[x, y, 2] == Expansion_Passable::SHADOW_ERASER_TILE_ID
          r_x = round_x(x - 1)
          tile_id = @map.data[r_x, y, 0]

          if (4352...5888).include?(tile_id) or
            (6272...6656).include?(tile_id) or
            (7040...7424).include?(tile_id) or
            (7808...8192).include?(tile_id)
            dummy_tile_id = 2000 + auto_(tile_id)
          else
            dummy_tile_id = 1952 + auto_(tile_id)
          end
         
          @map.data[x, y, 2] = 0
          @map.data[r_x, y, 1] = @map.data[r_x, y, 0]
          @map.data[r_x, y, 0] = dummy_tile_id
        end
      end
    end
  end
  #--------------------------------------------------------------------------
  # ○ 指定座標のタイルIDの取得
  #--------------------------------------------------------------------------
  def point_tile_id(x, y)
    return [data[x, y, 0], data[x, y, 1], data[x, y, 2]]
  end
  #--------------------------------------------------------------------------
  # ○ オートタイルIDの取得(オートタイル郡の中で順番にIDをつけた独自のIDです)
  #--------------------------------------------------------------------------
  def auto_(tile_id)
    return 0 unless (1952...8192).include?(tile_id)
    return (tile_id - 1952) % 48
  end
  #--------------------------------------------------------------------------
  # ○ トップタイルIDの取得(オートタイル郡の最初のID)
  #--------------------------------------------------------------------------
  def top_(tile_id)
    return 0 if tile_id == nil
    return (tile_id - auto_(tile_id))
  end
  #--------------------------------------------------------------------------
  # ○ スクリプト機能を使用する屋根・天井・壁タイルか?
  #--------------------------------------------------------------------------
  def ceiling?(tile_id)
    return false unless Data_Tile::FUNCTION_TILE.include?(top_(tile_id))
    return true if wall?(tile_id)
    return true if (1952...2048).include?(tile_id)
    return true if (4352...4736).include?(tile_id)
    return true if (5120...5504).include?(tile_id)
    return true if (5888...6272).include?(tile_id)
    return true if (6656...7040).include?(tile_id)
    return (7424...7808).include?(tile_id)
  end
  #--------------------------------------------------------------------------
  # ○ スクリプト機能を使用する壁タイルか?
  #--------------------------------------------------------------------------
  def wall?(tile_id)
    return false unless Data_Tile::FUNCTION_TILE.include?(top_(tile_id))
    return true if (4736...5120).include?(tile_id)
    return true if (5504...5888).include?(tile_id)
    return true if (6272...6656).include?(tile_id)
    return true if (7040...7424).include?(tile_id)
    return (7808...8192).include?(tile_id)
  end
  #--------------------------------------------------------------------------
  # ○ スクリプト機能を使用する地形タイルか?
  #--------------------------------------------------------------------------
  def cliff?(tile_id)
    return false unless Data_Tile::FUNCTION_TILE.include?(top_(tile_id))
    return [2816, 3200, 3584, 2960, 3344, 3728, 4112].include?(top_(tile_id))
  end
  #--------------------------------------------------------------------------
  # ○ 指定の向きにオートタイルチップの境目があるか?
  #--------------------------------------------------------------------------
  def verge?(tile_id, direction)
    auto_tile_id = auto_(tile_id)
   
    return false if auto_tile_id == 0
    return false unless ceiling?(tile_id) or cliff?(tile_id)
    if (2000...2048).include?(tile_id) or
      (4352...5888).include?(tile_id) or
      (6272...6656).include?(tile_id) or
      (7040...7424).include?(tile_id) or
      (7808...8192).include?(tile_id)          # オートタイルの線画タイプ判別
      case direction # 壁タイプの場合 方向ごとに振り分け
      when 2 ; return true if Data_Auto_Tile::VERGE_DOWN_B.include?(auto_tile_id)
      when 4 ; return true if Data_Auto_Tile::VERGE_LEFT_B.include?(auto_tile_id)
      when 6 ; return true if Data_Auto_Tile::VERGE_RIGHT_B.include?(auto_tile_id)
      when 8 ; return true if Data_Auto_Tile::VERGE_UP_B.include?(auto_tile_id)
      end
    else
      case direction # 床タイプの場合 方向ごとに振り分け
      when 2 ; return true if Data_Auto_Tile::VERGE_DOWN_A.include?(auto_tile_id)
      when 4 ; return true if Data_Auto_Tile::VERGE_LEFT_A.include?(auto_tile_id)
      when 6 ; return true if Data_Auto_Tile::VERGE_RIGHT_A.include?(auto_tile_id)
      when 8 ; return true if Data_Auto_Tile::VERGE_UP_A.include?(auto_tile_id)
      end
    end
  end
  #--------------------------------------------------------------------------
  # ○ 指定の向きに通行不可の境目があるか?
  #--------------------------------------------------------------------------
  def rip?(tile_id, front_tile_id, direction)
    if Data_Tile::BRIDRE_LENGTH.include?(tile_id[2])
      return true if direction == 4 or direction == 6
    elsif Data_Tile::BRIDGE_BREADTH.include?(tile_id[2])
      return true if direction == 2 or direction == 8
    end
    if cliff?(tile_id[0])
      return false unless ceiling?(front_tile_id[0]) or cliff?(front_tile_id[0])
      if cliff?(front_tile_id[0]) and verge?(front_tile_id[0], 10 - direction)
        return false
      end
    end
   
    return verge?(tile_id[0], direction)
  end
  #--------------------------------------------------------------------------
  # ○ 指定の向きに準じた橋タイルか?(渡ることの出来る向きか)
  #--------------------------------------------------------------------------
  def bridge?(tile_id, direction)
    if direction == 2 or direction == 8
      return true if Data_Tile::BRIDRE_LENGTH.include?(tile_id)
    elsif direction == 4 or direction == 6
      return true if Data_Tile::BRIDGE_BREADTH.include?(tile_id)
    end
    return false
  end
  #--------------------------------------------------------------------------
  # ○ <船の橋下通過>処理をするエリアか?
  #--------------------------------------------------------------------------
  def ship_pass_area?(x, y)
    result = false
    for area in $data_areas.values
      next if area == nil
      next unless area.ship_pass
      next if $game_map.map_id != area.map_id
      next if x < area.rect.x
      next if y < area.rect.y
      next if x >= area.rect.x + area.rect.width
      next if y >= area.rect.y + area.rect.height
      result = true
    end
    return result
  end
  #--------------------------------------------------------------------------
  # ○ 裏回り用タイル存在座標ピックアップと通行判定初期化
  #--------------------------------------------------------------------------
  def setup_back_tiles
   
    for i in 4352...8192
      @passages[i] = 0x00 if ceiling?(i)        # 天井タイルの通行判定を○に
    end

    back_tiles = []                              # 裏回りタイル郡の生成
    for i in 2816...8192
      next unless ceiling?(i) or cliff?(i)
      next if wall?(i)
      next unless verge?(i, 8)
      if cliff?(i)
        next unless Expansion_Passable::CLIFF_MAP.include?(@map_id)
      end
      back_tiles.push(i)
    end

    for i in (Data_Tile::BRIDRE_LENGTH + Data_Tile::BRIDGE_BREADTH)
      @passages[i] = 0x10                      # 橋タイル通行判定を☆に
    end   
    @passages[Data_Tile::UNDER_BRIDGE] = 0x00    # 橋下用タイルの通行判定を○に
   
    for x in 0...width
      for reverse_y in 1..height
        y = height - reverse_y
        tile_id = point_tile_id(x, y)
        if (Data_Tile::BRIDRE_LENGTH + Data_Tile::BRIDGE_BREADTH).include?(tile_id[2])
          @back_tiles_position.push([x, y])
          if (2048...2815).include?(tile_id[0])
            @map.data[x, y, 1] = Data_Tile::UNDER_BRIDGE
            if ship_pass_area?(x, y)
              @under_bridge_passages[[x, y]] = 1
            else
              @under_bridge_passages[[x, y]] = 0
            end
          elsif @passages[tile_id[0]] != 0x06
            @map.data[x, y, 1] = Data_Tile::UNDER_BRIDGE
            @under_bridge_passages[[x, y]] = -1
          end
          if @under_bridge_passages[[x, y]] != 0 and Data_Tile::BRIDGE_BREADTH.include?(tile_id[2])
            @keep_back_position.push([x, round_y(y+1)])
          end
        elsif tile_id[2] != 0 and @passages[tile_id[2]] & 0x10 == 0x10
          if @back_tiles_position.include?([x, round_y(y+1)])
            @keep_back_position.push([x, y])
          else
            @ex_data[x, y, 2] = @map.data[x, y, 2]
          end
        end
        if (2816...8192).include?(tile_id[0])
          if back_tiles.include?(tile_id[0])
            @back_tiles_position.push([x, y])
            @ex_data[x, y, 0] = @map.data[x, y, 0]
            @ex_data[x, y, 1] = @map.data[x, y, 1]
            if tile_id[2] != Expansion_Passable::ADDITION_BACK_TILE_ID
              @ex_data[x, y, 2] = @map.data[x, y, 2]
            end
            @map.data[x, y, 1] = 0
            @map.data[x, y, 2] = 0
            if Expansion_Passable::BACK_TILE_DEEP
              unless @back_tiles_position.include?([x, round_y(y+1)])
                unless wall?(data[x, round_y(y+1), 0]) and
                      verge?(data[x, round_y(y+1), 0], 2)
                  @back_tiles_position.push([x, round_y(y+1)])
                  @ex_data[x, round_y(y+1), 0] = @map.data[x, round_y(y+1), 0]
                  @ex_data[x, round_y(y+1), 1] = @map.data[x, round_y(y+1), 1]
                  @ex_data[x, round_y(y+1), 2] = @map.data[x, round_y(y+1), 2]
                  @map.data[x, round_y(y+1), 1] = 0
                  @map.data[x, round_y(y+1), 2] = 0
                end
              end
            end
          elsif Expansion_Passable::ADDITION_BACK_TILE_ID != nil and
                tile_id[2] == Expansion_Passable::ADDITION_BACK_TILE_ID
            @back_tiles_position.push([x, y])
            @ex_data[x, y, 0] = @map.data[x, y, 0]
            @ex_data[x, y, 1] = @map.data[x, y, 1]
            @map.data[x, y, 1] = 0
            @map.data[x, y, 2] = 0
            if (2816...8192).include?(@map.data[x, round_y(y-1), 0])
              @ex_data[x, round_y(y-1), 0] = @map.data[x, round_y(y-1), 0]
              @ex_data[x, round_y(y-1), 1] = @map.data[x, round_y(y-1), 1]
            end
          end
        end
      end
    end
   
    if Expansion_Passable::DELETE_BACK_TILE_ID != nil
      for x in 0...width
        for y in 0...height
          if @ex_data[x, y, 2] == Expansion_Passable::DELETE_BACK_TILE_ID
            @back_tiles_position.delete([x, y])
            @ex_data[x, y, 2] = 0
          elsif @map.data[x, y, 2] == Expansion_Passable::DELETE_BACK_TILE_ID
            @map.data[x, y, 2] = 0
          end
        end
      end
    end
   
  end
  #--------------------------------------------------------------------------
  # ○ 裏回り用タイルの存在する座標か?
  #--------------------------------------------------------------------------
  def back_tile?(x, y)
    return false if @back_tiles_position == nil
    return @back_tiles_position.include?([x, y])
  end
end

#==============================================================================
# ■ Game_Character
#------------------------------------------------------------------------------
#  キャラクターを扱うクラスです。このクラスは Game_Player クラスと Game_Event
# クラスのスーパークラスとして使用されます。
#==============================================================================

class Game_Character
  #--------------------------------------------------------------------------
  # ○ 公開インスタンス変数
  #--------------------------------------------------------------------------
  attr_reader  :on_tile
  attr_reader  :turn_back
  attr_accessor :no_turn_back
  attr_reader  :not_back_seeing
  #--------------------------------------------------------------------------
  # ◎ オブジェクト初期化
  #--------------------------------------------------------------------------
  alias tig_ep_initialize initialize
  def initialize
    tig_ep_initialize
    @vehicle_type = -1
    @turn_back = false
    @no_turn_back = false
    @on_tile = true
    @back_seeing = false
    @not_back_seeing = false
  end
  #--------------------------------------------------------------------------
  # ◎ フレーム更新
  #--------------------------------------------------------------------------
  alias tig_ep_update update
  def update
    if @first_update == nil
      update_turn_back
      @first_update = true
    end
    tig_ep_update
  end
  #--------------------------------------------------------------------------
  # ◎ 茂み深さの更新
  #--------------------------------------------------------------------------
  alias tig_ep_update_bush_depth update_bush_depth
  def update_bush_depth
    update_turn_back
    tig_ep_update_bush_depth
  end
  #--------------------------------------------------------------------------
  # ○ 裏回り状態更新
  #--------------------------------------------------------------------------
  def update_turn_back
    unless @real_x == @x * 256 and @real_y == @y * 256
      @back_seeing = false
      @on_tile = false if @turn_back
    else
      @turn_back = false if @no_turn_back
      unless $game_map.back_tile?(@x, @y)
        @turn_back = false
        @no_turn_back = false
      end
      @on_tile = true unless @turn_back
    end
    if not @turn_back or @no_turn_back
      if $game_map.keep_back_position != nil and $game_map.keep_back_position.include?([@x, @y])
        @on_tile = false
        return
      end
    end
  end
  #--------------------------------------------------------------------------
  # ○ 段差マップ用・拡張通過判定
  #--------------------------------------------------------------------------
  def ex_passable(direction, test = false)
    front_x = $game_map.x_with_direction(@x, direction)
    front_y = $game_map.y_with_direction(@y, direction)   
    tile_id = $game_map.point_tile_id(@x, @y)
    front_tile_id = $game_map.point_tile_id(front_x, front_y)
   
    if Data_Tile::STEP.include?(front_tile_id[0]) or
      Data_Tile::STEP.include?(front_tile_id[2])
      return true
    else
      unless $game_map.wall?(front_tile_id[0])
        return true if Data_Tile::STEP.include?(tile_id[0])
        return true if Data_Tile::STEP.include?(tile_id[2])
      end
    end
   
    if $game_map.back_tiles_position.include?([@x, @y]) and @turn_back # この場が裏
      if $game_map.under_bridge_passages.key?([front_x, front_y])
        if (@vehicle_type == -1 and $game_map.under_bridge_passages[[front_x, front_y]] == 1) or
          $game_map.under_bridge_passages[[front_x, front_y]] <= 0
          return false unless debug_through? or @through
        end
      end
      if $game_map.back_tiles_position.include?([front_x, front_y]) # 目の前が裏
        return true
      else                                                # 目の前が裏でない
        if $game_map.rip?(tile_id, front_tile_id, direction)        # この場に境目がある
          if $game_map.rip?(front_tile_id, tile_id, 10 - direction) # 目の前に境目がある
            return false unless debug_through? or @through # 通行不可
          else
            return true
          end
        else                                              # この場に境目がない
          return false unless debug_through? or @through  # 通行不可
        end
      end
    else                                                  # この場は裏でない
      unless $game_map.bridge?(front_tile_id[2], direction) or # 橋がなければ
            $game_map.bridge?(tile_id[2], direction)   
        if $game_map.rip?(tile_id, front_tile_id, direction) # この場に境目がある
          return false unless debug_through? or @through # 通行不可
        else                                              # この場に境目がない
          if $game_map.rip?(front_tile_id, tile_id, 10 - direction) # 目の前に境目がある
            if $game_map.back_tiles_position.include?([front_x, front_y]) # 目の前が裏タイル
              unless $game_map.bridge?(tile_id[2], direction)  # この場が橋でなければ
                if $game_map.under_bridge_passages.key?([front_x, front_y])
                  if (@vehicle_type == -1 and $game_map.under_bridge_passages[[front_x, front_y]] == 1) or
                    $game_map.under_bridge_passages[[front_x, front_y]] <= 0
                    return false unless debug_through? or @through
                  end
                end
                unless @no_turn_back
                  @turn_back = true unless test            # 裏回り開始
                  @back_seeing = true
                end
              end
            else                                          # 目の前が裏タイルでない
              unless $game_map.bridge?(tile_id[2], direction) # この場が橋でなければ
                return false unless debug_through? or @through # 通行不可
              end
            end
          else                                            # 目の前に境目がない
            if $game_map.wall?(front_tile_id[0])
              return false unless debug_through? or @through # 通行不可
            end
          end
        end
      end
    end
   
    if $game_map.back_tile?(front_x, front_y) and not @turn_back
      for i in [2, 1, 0]                        # レイヤーの上から順に調べる
        tile_id = $game_map.ex_data[front_x, front_y, i] # タイル ID を取得
        unless tile_id == nil
          pass = $game_map.passages[tile_id]    # 通行属性を取得
          next if pass & 0x10 == 0x10          # [☆] : 通行に影響しない
          next if pass & 0x01 == 0x00          # [○] : 通行可
          if pass & 0x01 == 0x01                # [×] : 通行不可
            return false unless debug_through? or @through
          end
        end
      end
    end 

    return true
  end
  #--------------------------------------------------------------------------
  # ◎ 下に移動
  #    turn_ok : その場での向き変更を許可
  #--------------------------------------------------------------------------
  alias tig_ep_move_down move_down
  def move_down(turn_ok = true)
    last_turn_back = @turn_back
    unless ex_passable(2)
      turn_down if turn_ok
      @move_failed = true
      check_event_trigger_touch(@x, @y+1)  # 接触イベントの起動判定
      return
    end
    tig_ep_move_down(turn_ok)
    if @move_failed and @turn_back and not last_turn_back
      @turn_back = false
    end
  end
  #--------------------------------------------------------------------------
  # ◎ 左に移動
  #    turn_ok : その場での向き変更を許可
  #--------------------------------------------------------------------------
  alias tig_ep_move_left move_left
  def move_left(turn_ok = true)
    last_turn_back = @turn_back
    unless ex_passable(4)
      turn_left if turn_ok
      @move_failed = true
      check_event_trigger_touch(@x-1, @y)  # 接触イベントの起動判定
      return
    end
    tig_ep_move_left(turn_ok)
    if @move_failed and @turn_back and not last_turn_back
      @turn_back = false
    end
  end
  #--------------------------------------------------------------------------
  # ◎ 右に移動
  #    turn_ok : その場での向き変更を許可
  #--------------------------------------------------------------------------
  alias tig_ep_move_right move_right
  def move_right(turn_ok = true)
    last_turn_back = @turn_back
    unless ex_passable(6)
      turn_right if turn_ok
      check_event_trigger_touch(@x+1, @y)  # 接触イベントの起動判定
      @move_failed = true
      return
    end
    tig_ep_move_right(turn_ok)
    if @move_failed and @turn_back and not last_turn_back
      @turn_back = false
    end
  end
  #--------------------------------------------------------------------------
  # ◎ 上に移動
  #    turn_ok : その場での向き変更を許可
  #--------------------------------------------------------------------------
  alias tig_ep_move_up move_up
  def move_up(turn_ok = true)
    last_turn_back = @turn_back
    unless ex_passable(8)
      turn_up if turn_ok
      check_event_trigger_touch(@x, @y-1)  # 接触イベントの起動判定
      @move_failed = true
      return
    end
    tig_ep_move_up(turn_ok)
    if @move_failed and @turn_back and not last_turn_back
      @turn_back = false
    end
  end
  #--------------------------------------------------------------------------
  # ● キャラクター衝突判定
  #    x : X 座標
  #    y : Y 座標
  #    プレイヤーと乗り物を含め、通常キャラの衝突を検出する。
  #--------------------------------------------------------------------------
  def collide_with_characters?(x, y)
    for event in $game_map.events_xy(x, y)          # イベントの座標と一致
      next unless parallel?(event)                  ##### 追加部分 (この行) #####
      unless event.through                          # すり抜け OFF?
        return true if self.is_a?(Game_Event)      # 自分がイベント
        return true if event.priority_type == 1    # 相手が通常キャラ
      end
    end
    if @priority_type == 1                          # 自分が通常キャラ
      return true if $game_player.pos_nt?(x, y)    # プレイヤーの座標と一致
      return true if $game_map.boat.pos_nt?(x, y)  # 小型船の座標と一致
      return true if $game_map.ship.pos_nt?(x, y)  # 大型船の座標と一致
    end
    return false
  end
  #--------------------------------------------------------------------------
  # ○ キャラクターの同軸存在判定
  #--------------------------------------------------------------------------
  def parallel?(event)
   
    if @x == event.x
      if @y < event.y
        direction = 2
      elsif @y > event.y
        direction = 8
      end
    elsif  @y = event.y
      if @x < event.x
        direction = 6
      elsif @x > event.x
        direction = 4
      end
    end
   
    return @turn_back == event.turn_back if direction == nil
    last_turn_back = @turn_back
    passable = ex_passable(direction)
    tile_id = $game_map.data[event.x, event.y, 0]
    unless $game_map.wall?(tile_id)
      return false unless passable
    end
   
    if last_turn_back != @turn_back
      @turn_back = last_turn_back
      return @turn_back != event.turn_back
    else
      return true unless $game_map.back_tile?(event.x, event.y)
      return @turn_back == event.turn_back
    end
   
  end
end

#==============================================================================
# ■ Game_Event
#------------------------------------------------------------------------------
#  イベントを扱うクラスです。条件判定によるイベントページ切り替えや、並列処理
# イベント実行などの機能を持っており、Game_Map クラスの内部で使用されます。
#==============================================================================

class Game_Event < Game_Character
  #--------------------------------------------------------------------------
  # ◎ オブジェクト初期化
  #    map_id : マップ ID
  #    event  : イベント (RPG::Event)
  #--------------------------------------------------------------------------
  alias tig_ep_event_initialize initialize
  def initialize(map_id, event)
    tig_ep_event_initialize(map_id, event)
    set_turn_back_setting
  end
  #--------------------------------------------------------------------------
  # ○ Get Initial Arrangement Position (Place behind)
  #-------------------------------------------------------------------------- 
  def set_turn_back_setting
    @event.name = @event.name.sub(/[\<<]behind[\>>]/, "")
    @turn_back = $& != nil
    @on_tile = $& == nil
    @event.name = @event.name.sub(/[\<<]hidebehind[\>>]/, "")
    @not_back_seeing = $& != nil
  end
end

#==============================================================================
# ** Game_Vehicle
#------------------------------------------------------------------------------
#  乗り物を扱うクラスです。このクラスは Game_Map クラスの内部で使用されます。
# 現在のマップに乗り物がないときは、マップ座標 (-1,-1) に設定されます。
#==============================================================================

class Game_Vehicle < Game_Character 
  def on_tile
    if @driving
      return $game_player.on_tile
    else
      return @on_tile
    end
  end
end

#==============================================================================
# ** Game_Player
#------------------------------------------------------------------------------
#  プレイヤーを扱うクラスです。イベントの起動判定や、マップのスクロールなどの
# 機能を持っています。このクラスのインスタンスは $game_player で参照されます。
#==============================================================================

class Game_Player < Game_Character
  #--------------------------------------------------------------------------
  # ○ 裏配置イベント透過状態か?
  #-------------------------------------------------------------------------- 
  def back_seeing?
    return true if @turn_back or @back_seeing
    return false
  end
  #--------------------------------------------------------------------------
  # ● 同位置のイベント起動判定
  #    triggers : トリガーの配列
  #--------------------------------------------------------------------------
  def check_event_trigger_here(triggers)
    return false if $game_map.interpreter.running?
    result = false
    for event in $game_map.events_xy(@x, @y)
      next unless parallel?(event)                ##### 追加部分 (この行) #####
      if triggers.include?(event.trigger) and event.priority_type != 1
        event.start
        result = true if event.starting
      end
    end
    return result
  end
  #--------------------------------------------------------------------------
  # ● 正面のイベント起動判定
  #    triggers : トリガーの配列
  #--------------------------------------------------------------------------
  def check_event_trigger_there(triggers)
    return false if $game_map.interpreter.running?
    result = false
    front_x = $game_map.x_with_direction(@x, @direction)
    front_y = $game_map.y_with_direction(@y, @direction)
    for event in $game_map.events_xy(front_x, front_y)
      next unless parallel?(event)                ##### 追加部分 (この行) #####
      if triggers.include?(event.trigger) and event.priority_type == 1
        event.start
        result = true
      end
    end
    if result == false and $game_map.counter?(front_x, front_y)
      front_x = $game_map.x_with_direction(front_x, @direction)
      front_y = $game_map.y_with_direction(front_y, @direction)
      for event in $game_map.events_xy(front_x, front_y)
        next unless parallel?(event)              ##### 追加部分 (この行) #####
        if triggers.include?(event.trigger) and event.priority_type == 1
          event.start
          result = true
        end
      end
    end
    return result
  end
  #--------------------------------------------------------------------------
  # ◎ 乗り物から降りる
  #    現在乗り物に乗っていることが前提。
  #--------------------------------------------------------------------------
  alias tig_ep_get_off_vehicle get_off_vehicle
  def get_off_vehicle
    return if $game_map.back_tile?(@x, @y)
    if @vehicle_type == 0 or @vehicle_type == 1
      front_x = $game_map.x_with_direction(@x, @direction)
      front_y = $game_map.y_with_direction(@y, @direction)
      return if $game_map.under_bridge_passages[[front_x, front_y]] == 1
      return if $game_map.prohibited_get_off.include?([front_x, front_y])
      @no_turn_back = true
    end
    tig_ep_get_off_vehicle
  end
end

#==============================================================================
# ** Spriteset_Map
#------------------------------------------------------------------------------
#  マップ画面のスプライトやタイルマップなどをまとめたクラスです。このクラスは
# Scene_Map クラスの内部で使用されます。
#==============================================================================

class Spriteset_Map
  #--------------------------------------------------------------------------
  # ◎ ビューポートの作成
  #--------------------------------------------------------------------------
  alias tig_ep_create_viewports create_viewports
 def create_viewports
    tig_ep_create_viewports
    @viewport4 = Viewport.new(0, 0, 640, 480) # 追加レイヤー�"��"ューポート
    if Expansion_Passable::BACK_SEEING
      @viewport5 = Viewport.new(0, 0, 640, 480) # 裏回りキャラ透過�"��"ューポート
    end
    @viewport6 = Viewport.new(0, 0, 640, 480) # 色調変更�"��"ューポート
  end
  #--------------------------------------------------------------------------
  # ◎ タイルマップの作成
  #--------------------------------------------------------------------------
  alias tig_ep_create_tilemap create_tilemap
  def create_tilemap
    tig_ep_create_tilemap
    setup_shadow_eraser_tilemap
    @ex_tilemap = Tilemap.new(@viewport4)
    @ex_tilemap.bitmaps[0] = Cache.system("TileA1")
    @ex_tilemap.bitmaps[1] = Cache.system("TileA2")
    @ex_tilemap.bitmaps[2] = Cache.system("TileA3")
    @ex_tilemap.bitmaps[3] = Cache.system("TileA4")
    @ex_tilemap.bitmaps[4] = Cache.system("TileA5")
    @ex_tilemap.bitmaps[5] = Cache.system("TileB")
    @ex_tilemap.bitmaps[6] = Cache.system("TileC")
    @ex_tilemap.bitmaps[7] = Cache.system("TileD")
    @ex_tilemap.bitmaps[8] = Cache.system("TileE")
    @ex_tilemap.map_data = $game_map.ex_data
    @ex_tilemap.passages = $game_map.passages
  end
  #--------------------------------------------------------------------------
  # ○ 影消し処理用タイルの準備
  #--------------------------------------------------------------------------
  def setup_shadow_eraser_tilemap
    for i in 1952...2048
      @tilemap.passages[i] = 0x00
    end
  end
  #--------------------------------------------------------------------------
  # ◎ 飛行船の影スプライトの作成
  #--------------------------------------------------------------------------
  alias tig_ep_create_shadow create_shadow
  def create_shadow
    tig_ep_create_shadow
    @shadow_sprite.viewport = @viewport4
  end
  #--------------------------------------------------------------------------
  # ◎ タイルマップの解放
  #--------------------------------------------------------------------------
  alias tig_ep_dispose_tilemap dispose_tilemap
  def dispose_tilemap
    tig_ep_dispose_tilemap
    @ex_tilemap.dispose
  end
  #--------------------------------------------------------------------------
  # ◎ ビューポートの解放
  #--------------------------------------------------------------------------
  alias tig_ep_dispose_viewports dispose_viewports
  def dispose_viewports
    tig_ep_dispose_viewports
    @viewport4.dispose
    @viewport5.dispose if Expansion_Passable::BACK_SEEING
    @viewport6.dispose
  end
  #--------------------------------------------------------------------------
  # ◎ タイルマップの更新
  #--------------------------------------------------------------------------
  alias tig_ep_update_tilemap update_tilemap
  def update_tilemap
    tig_ep_update_tilemap
    @ex_tilemap.ox = $game_map.display_x / 8
    @ex_tilemap.oy = $game_map.display_y / 8
    @ex_tilemap.update
  end
  #--------------------------------------------------------------------------
  # ◎ キャラクタースプライトの更新
  #--------------------------------------------------------------------------
  alias tig_ep_update_characters update_characters
  def update_characters
    back_seeing_characters = []
    for sprite in @character_sprites
      next if sprite.character.not_back_seeing
      if $game_player.back_seeing? and Expansion_Passable::BACK_SEEING
        x = $game_player.x ; y = $game_player.y
        if ($game_map.round_x(x-2)..$game_map.round_x(x+2)).include?(sprite.character.x) and
          ($game_map.round_y(y-2)..$game_map.round_y(y+2)).include?(sprite.character.y)
          back_seeing_characters.push(sprite.character)
        end
      end
      if sprite.character.on_tile
        sprite.viewport = @viewport4
      else
        sprite.viewport = @viewport1
      end
    end
    back_seeing(back_seeing_characters)
   
    tig_ep_update_characters
  end
  #--------------------------------------------------------------------------
  # ○ 裏回りキャラ透過
  #-------------------------------------------------------------------------- 
  def back_seeing(characters)
    return unless Expansion_Passable::BACK_SEEING
    @back_seeing_sprites = [] if @back_seeing_sprites == nil
    @characters = [] if @characters == nil
    now_character = []
    for character in characters
      now_character.push(character)
      unless @characters.include?(character)
        new_sprite = Sprite_Character.new(@viewport5, character)
        new_sprite.back_seeing = true
        @back_seeing_sprites.push(new_sprite)
        @characters.push(new_sprite.character)
      end
    end
   
    for sprite in @back_seeing_sprites
      if now_character.include?(sprite.character)
        sprite.update
      else
        @characters.delete(sprite.character)
        sprite.dispose
        @back_seeing_sprites.delete(sprite)
      end
    end
  end
  #--------------------------------------------------------------------------
  # ● ビューポートの更新
  #--------------------------------------------------------------------------
  def update_viewports
    @viewport6.tone = $game_map.screen.tone        ##### 修正部分 (この行) #####
    @viewport1.ox = $game_map.screen.shake
   
    @viewport4.ox = $game_map.screen.shake        ### 追加部分 (この行から) ###
    if Expansion_Passable::BACK_SEEING
      @viewport5.rect.set($game_player.screen_x - 48, $game_player.screen_y - 64, 96, 96)
      @viewport5.ox = $game_map.screen.shake
    end                                            ### 追加部分 (ここ行まで) ###
   
    @viewport2.color = $game_map.screen.flash_color
    @viewport3.color.set(0, 0, 0, 255 - $game_map.screen.brightness)
    @viewport1.update
    @viewport2.update
    @viewport3.update
   
    @viewport4.update                              ### 追加部分 (この行から) ###
    @viewport5.update if Expansion_Passable::BACK_SEEING
    @viewport6.update                              ### 追加部分 (ここ行まで) ###
  end
end

#==============================================================================
# ** Sprite_Character
#------------------------------------------------------------------------------
#  キャラクター表示用のスプライトです。Game_Character クラスのインスタンスを
# 監視し、スプライトの状態を自動的に変化させます。
#==============================================================================

class Sprite_Character < Sprite_Base
  #--------------------------------------------------------------------------
  # ○ 公開インスタンス変数
  #--------------------------------------------------------------------------
  attr_accessor :back_seeing
  #--------------------------------------------------------------------------
  # ◎ オブジェクト初期化
  #    viewport  : ビューポート
  #    character : キャラクター (Game_Character)
  #--------------------------------------------------------------------------
  alias tig_ep_initialize initialize
  def initialize(viewport, character = nil)
    tig_ep_initialize(viewport, character)
    @back_seeing = false
  end
  #--------------------------------------------------------------------------
  # ◎ フレーム更新
  #--------------------------------------------------------------------------
  alias tig_ep_update update
  def update
    tig_ep_update
    if @back_seeing
      self.opacity = 40 if self.opacity > 100
      self.x -= $game_player.screen_x - 48
      self.y -= $game_player.screen_y - 64
    end
  end
end

#==============================================================================
# ** Scene_Title
#------------------------------------------------------------------------------
#  タイトル画面の処理を行うクラスです。
#==============================================================================

class Scene_Title < Scene_Base
  #--------------------------------------------------------------------------
  # ◎ データベースのロード
  #    name から<船の橋下通過>の設定を得ます。
  #--------------------------------------------------------------------------
  alias tig_ep_load_database load_database
  def load_database
    tig_ep_load_database
    for area in $data_areas.values
      area.name = area.name.sub(/[\<<]bridge[\>>]/, "") # adjust area name
      area.ship_pass = $& != nil                        # set ship passability
    end
  end
end

Thanks...



Terakhir diubah oleh Axelandria tanggal 2012-05-06, 16:09, total 2 kali diubah
[Solved] MoonMan Wall Tile Extension Empty2012-05-06, 16:01
PostRe: [Solved] MoonMan Wall Tile Extension
#4
yade26 
Novice
Novice
yade26

Level 5
Posts : 132
Thanked : 0
Engine : RMVX Ace
Skill : Skilled
Type : Scripter

[Solved] MoonMan Wall Tile Extension Vide
@joni : maaf yg ane tanya bukan apa gunanya script ini... cuma jelasin scriptnya...

@ Axelandria : wah thanks gan :)


[Solved] Momod kunci aja dah... Thread ini...
[Solved] MoonMan Wall Tile Extension Empty2012-05-06, 17:29
PostRe: [Solved] MoonMan Wall Tile Extension
#5
LowlingLife 
Administrator
Administrator
LowlingLife

Kosong
Posts : 2000
Thanked : 25
Engine : Multi-Engine User
Awards:

[Solved] MoonMan Wall Tile Extension Vide
Oke pertama-tama saya moved dulu ini ke RGSS 2 Request.

Abis itu saya locked thread ini.
[Solved] MoonMan Wall Tile Extension Empty
PostRe: [Solved] MoonMan Wall Tile Extension
#6
Sponsored content 




[Solved] MoonMan Wall Tile Extension Vide
 

[Solved] MoonMan Wall Tile Extension

Topik sebelumnya Topik selanjutnya Kembali Ke Atas 

Similar topics

+
Halaman 1 dari 1

Permissions in this forum:Anda tidak dapat menjawab topik
RPGMakerID :: Scripts & Event Systems :: RMVX Scripts :: RGSS2 Request :: RGSS2 Request Archive-