|
Just got XP!; And....
|
|
Topic Started: May 1 2005, 05:02 AM (534 Views)
|
|
Alastyr
|
May 1 2005, 03:57 PM
Post #21
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
darn... Same error? Do you know what line it takes you to? The number not what it says...I can't find it.
|
|
|
| |
|
VaunFinnel
|
May 1 2005, 04:02 PM
Post #22
|
|
Board Member Level 1
- Posts:
- 2
- Group:
- Retired Moderator
- Member
- #3
- Joined:
- September 29, 2004
|
no idea.......
|
------ A wise man once told me, "Touch that and I'll cut off your fingers." Thanks Dad. ------ Don't follow in my footsteps, I run into walls. o_0. ------ print "Hello World!"
|
| |
|
Draken
|
May 1 2005, 04:05 PM
Post #23
|
|
Your Local Black Dragon
- Posts:
- 9
- Group:
- Retired Moderator
- Member
- #249
- Joined:
- March 6, 2005
|
i dont understand it... i done the script thing, and i dont have a CLUE how to use the script? how do u use it!!!!!???
|
|
| |
|
Alastyr
|
May 1 2005, 04:09 PM
Post #24
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
the part of the file that has the error, looks like this right?
- Code:
-
$game_actor.actor001.mandatory = true
If so put a '#' in front of it to make it a comment. I don't think it should be in the script. You're supposed to use that format the call the script.
And you put each section in the right script right? Not just as one huge script...
Try calling the script by making an event with a call script command like this:
- Code:
-
$game_actor.actor[001].mandatory = true $scene = Scene_Switch.new
|
|
|
| |
|
VaunFinnel
|
May 1 2005, 04:20 PM
Post #25
|
|
Board Member Level 1
- Posts:
- 2
- Group:
- Retired Moderator
- Member
- #3
- Joined:
- September 29, 2004
|
No, the $game_actor.actor001.mandatory = true is in the Call Script box, and the
$game_actor.actor[001].mandatory = true $scene = Scene_Switch.new
didn't work. Everything is in its rightful place, i've quadruple checked it.
|
------ A wise man once told me, "Touch that and I'll cut off your fingers." Thanks Dad. ------ Don't follow in my footsteps, I run into walls. o_0. ------ print "Hello World!"
|
| |
|
Alastyr
|
May 1 2005, 04:21 PM
Post #26
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
confound this script. I'll have to find a game that uses it correctly... I'll do that later, I have to go now...
|
|
|
| |
|
Draken
|
May 1 2005, 06:35 PM
Post #27
|
|
Your Local Black Dragon
- Posts:
- 9
- Group:
- Retired Moderator
- Member
- #249
- Joined:
- March 6, 2005
|
cya later, ill try it agen myself and figure it out
if i do ill tell u Vaun
|
|
| |
|
VaunFinnel
|
May 1 2005, 08:21 PM
Post #28
|
|
Board Member Level 1
- Posts:
- 2
- Group:
- Retired Moderator
- Member
- #3
- Joined:
- September 29, 2004
|
I got a good one working, but its only good if you have all the characters availbe, and it runs on conditional branches and variables.
|
------ A wise man once told me, "Touch that and I'll cut off your fingers." Thanks Dad. ------ Don't follow in my footsteps, I run into walls. o_0. ------ print "Hello World!"
|
| |
|
VaunFinnel
|
May 1 2005, 09:11 PM
Post #29
|
|
Board Member Level 1
- Posts:
- 2
- Group:
- Retired Moderator
- Member
- #3
- Joined:
- September 29, 2004
|
Urg.....i'm becoming fed up wiht this stupid switch char screen thingy. He has two screenshots of it working, so i know its something on my end. The scripts are all put in right, i think its just the stupid call script thing. BTW, whatever happened to call common event? they get rid of it?
|
------ A wise man once told me, "Touch that and I'll cut off your fingers." Thanks Dad. ------ Don't follow in my footsteps, I run into walls. o_0. ------ print "Hello World!"
|
| |
|
Alastyr
|
May 1 2005, 09:19 PM
Post #30
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
1st page, 1st column, almost to the bottom: 'Common Event' Use that.
|
|
|
| |
|
VaunFinnel
|
May 1 2005, 09:21 PM
Post #31
|
|
Board Member Level 1
- Posts:
- 2
- Group:
- Retired Moderator
- Member
- #3
- Joined:
- September 29, 2004
|
Thanks Alastyr, btw, i went to d/l LoA to play and for some scirpts, but its to lrage for my crappy dial-up. You think you could send me scripts through e-mail? Knoxontholos@aol.com
|
------ A wise man once told me, "Touch that and I'll cut off your fingers." Thanks Dad. ------ Don't follow in my footsteps, I run into walls. o_0. ------ print "Hello World!"
|
| |
|
Alastyr
|
May 1 2005, 09:28 PM
Post #32
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
Yeah sure. I'll send you the scripts data file and the icons needed for the ring menu. You can the icons if you want.
|
|
|
| |
|
VaunFinnel
|
May 1 2005, 09:29 PM
Post #33
|
|
Board Member Level 1
- Posts:
- 2
- Group:
- Retired Moderator
- Member
- #3
- Joined:
- September 29, 2004
|
Yay, thank you. *goes back to work on Char. Switching Script* *grumble...grumble*
|
------ A wise man once told me, "Touch that and I'll cut off your fingers." Thanks Dad. ------ Don't follow in my footsteps, I run into walls. o_0. ------ print "Hello World!"
|
| |
|
Alastyr
|
May 1 2005, 09:32 PM
Post #34
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
Sent!
|
|
|
| |
|
VaunFinnel
|
May 1 2005, 09:41 PM
Post #35
|
|
Board Member Level 1
- Posts:
- 2
- Group:
- Retired Moderator
- Member
- #3
- Joined:
- September 29, 2004
|
TY, i also sent something back.
|
------ A wise man once told me, "Touch that and I'll cut off your fingers." Thanks Dad. ------ Don't follow in my footsteps, I run into walls. o_0. ------ print "Hello World!"
|
| |
|
Alastyr
|
May 1 2005, 09:46 PM
Post #36
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
Got it. I'll look into it.
|
|
|
| |
|
Draken
|
May 2 2005, 11:48 AM
Post #37
|
|
Your Local Black Dragon
- Posts:
- 9
- Group:
- Retired Moderator
- Member
- #249
- Joined:
- March 6, 2005
|
im gutted, u all have AIM on AOL and i only have the wonderful BT Broadband at 2mb speed
(whoops I brag too much) do u guys have MSN?
|
|
| |
|
Alastyr
|
May 2 2005, 09:51 PM
Post #38
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
You can see what IM's a user is subsribed to by looking at the bar beneth them.
Look there V and you will see I have both AIM and MSN.
|
|
|
| |
|
Alastyr
|
May 4 2005, 12:30 AM
Post #39
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
Here's my first custom script: a party-switching screen. If you wanted a screen to switch in and out characters from your party, like with the PHS screen of FF7, or the End Of Time screen of Chrono Trigger.
It uses 4 files:
Scene_Switch
CODE
- Code:
-
#============================================================================== # Scene_Switch class definition #------------------------------------------------------------------------------ # This class represents the party switching sub-screen. It allows the player # to switch in and out characters from the party. Characters that are not in # the party but that are available are said 'in reserve'. # # Characters available are those that exist in Game_Actors::data and whose # property unavailable is set to false. In the default script, an actor is # loaded in Game_Actors::data when s/he is added for the very first time in the # party and is never deleted, unless it's done explicitly with scripts. # # This script requires you to create 2 additional attributes for the Game_Actor # class: mandatory and unavailable. Both are boolean values. # # Mandatory is a boolean variable that, when set to true, means that the actor # can't be switched out of the party. This is useful for main characters, that # are in many RPGs required most of the time, if not always. The switch screen # will display the word "Mandatory" in red above an actor that can't be put out # of the party. # # Unavailable is another boolean variable that, when set to true, means that # although the actor is defined in Game_Actors::data, won't appear in the # reserve window. This is useful when a character leaves the party in the # story, but you don't want to reset his stats and name when s/he comes back. # # Usage of this script requires the 3 other files: Window_SwitchParty, # Window_SwitchReserve and Window_SwitchStatus, as well as a few modifications # of the default scripts: # # 1 - In Game_Actor, add in the class definition (under "class Game_Actor # [...]"): # attr_reader :actor_id # attr_accessor :mandatory # attr_accessor :unavailable # # 2 - Again, in Game_Actor, add in the setup method (under "def setup"): # mandatory = false # unavailable = false # # 3 - In Game_Actors (with an "s"!) add in the class definition: # attr_accessor :data # # 4 - In Game_Party, change: # attr_reader :actors # for # attr_accessor :actors # # By exseiken, October 04, 2004 #==============================================================================
class Scene_Switch
#---------------------------------------------------------------------------- # Initialize the sub-screen. If it was called from the menu, it will return # to the main menu when closed, otherwise, it will return to the map. # # Parameters: # from_menu: Determines whether or not the scene was called from # the menu or not [true|false] # min_size: The minimum amount of characters that the new party # must have [1; 4] # max_size: The maximum amount of characters that the new party # must have [min_size; 4] #---------------------------------------------------------------------------- def initialize(from_menu, min_size = 1, max_size = 4) # store the data telling whether or not the scene was called from the menu @from_menu = from_menu # store the array bounds for the max_size and min_size @min_size = [[min_size, 1].max, 4].min @max_size = [[max_size, @min_size].max, 4].min end #---------------------------------------------------------------------------- # The main routine, controlling the life of the object. #---------------------------------------------------------------------------- def main # create the window containing the current party members @party_window = Window_SwitchParty.new
# create the window containing all available party members @reserve_window = Window_SwitchReserve.new(10) # create the window showing information about the selected character, be it # from the party window or from the reserve window @status_window = Window_SwitchStatus.new # if the party is empty, the active window is reserve_window, otherwise # it's the party window if $game_party.actors.size == 0 @party_window.active = false else @reserve_window.active = false end # set this status window as the two other windows' help window @party_window.help_window = @status_window @reserve_window.help_window = @status_window # display the transition Graphics.transition # enter the main loop loop do # flip the screen Graphics.update # get the buttons pressed Input.update # update the sub-screen update # if the scene has changed, return if $scene != self break end end # stop drawing graphics Graphics.freeze # destroy the sub-windows @status_window.dispose @reserve_window.dispose @party_window.dispose end #---------------------------------------------------------------------------- # Method called on every frame: update the contents of the scene (the 3, # windows) and read on the keyboard. #---------------------------------------------------------------------------- def update # update all sub-windows @party_window.update @reserve_window.update @status_window.update # if the active screen is party_window, update it, else update the reserve # window if @party_window.active update_party return else update_reserve return end end #---------------------------------------------------------------------------- # Called when the focus is on the party window. Read on the keyboard and # update the state of the scene according to the buttons pressed. If the # played pressed B while this mode is on, the new party will be set and # the scene will close. #---------------------------------------------------------------------------- def update_party # if the B (back) button was pressed, return to the preceeding screen if Input.trigger?(Input::B) # remove all holes in the party new_party = @party_window.new_party.compact # get the number of party members n = new_party.size # if the party doesn't have an acceptable amount of party members, don't # allow quitting the sub-screen if n < @min_size or n > @max_size # play the buzzer and exit $game_system.se_play($data_system.buzzer_se) return end # play the confirm sound $game_system.se_play($data_system.decision_se) # set the new party $game_party.actors = new_party # return to the calling scene if @from_menu $scene = Scene_Menu.new(5) else $scene = Scene_Map.new end # refresh the player's sprite $game_player.refresh
# skip (optimizing) return # if the C (confirm) button was pressed, switch the control to the reserve # window elsif Input.trigger?(Input::C) # if the selected character is not nil, and is unavailable, play the buzzer if(@party_window.actor != nil and @party_window.actor.mandatory) # play the buzzer $game_system.se_play($data_system.buzzer_se) else # play the decision sound $game_system.se_play($data_system.decision_se) # unactivate the party window @party_window.active = false # activate the reserve window @reserve_window.active = true end end end #---------------------------------------------------------------------------- # Called when the focus is on the reserve window. Read on the keyboard and # update the state of the scene according to the buttons pressed. #---------------------------------------------------------------------------- def update_reserve # if the B (back) button was pressed, give back the focus to the party # window if Input.trigger?(Input::B) # play the cancel sound $game_system.se_play($data_system.decision_se) # unactivate the reserve window @reserve_window.active = false # activate the party window @party_window.active = true # skip return # if the C (confirm) button was pressed, switch the party member in reserve # with the one selected in the party elsif Input.trigger?(Input::C) # play the confirm sound $game_system.se_play($data_system.decision_se) # swap the 2 party members @party_window.change_selection(@reserve_window.swap_characters(@party_window.actor)) # unactivate the reserve window @reserve_window.active = false # activate the party window @party_window.active = true end end end
Window_SwitchParty
CODE
- Code:
-
#============================================================================== # Window_SwitchParty class definition #------------------------------------------------------------------------------ # A window that displays all 4 character slots in the party, and offers a # cursor to modify it. # # By exseiken, October 04, 2004 #==============================================================================
class Window_SwitchParty < Window_Selectable
#---------------------------------------------------------------------------- # Create public access variables #---------------------------------------------------------------------------- attr_reader :new_party # The party shown in the window [R-O] #---------------------------------------------------------------------------- # Window's constructor. Create the window's contents, makes a copy of the # current party, then stocks it into member variable new_party, for later # use. #---------------------------------------------------------------------------- def initialize() # create the window and its contents super(0, 0, 256, 480) self.contents = Bitmap.new(width - 32, height - 32) self.contents.font.name = $fontface self.contents.font.size = $fontsize # copy the party @new_party = $game_party.actors.clone # always 4 party members @item_max = 4 # select the first character if @new_party.size > 0 @index = @new_party.index(@new_party.first ) else @index = 0 end # draw the window's contents refresh # update the cursor rectangle update_cursor_rect end #---------------------------------------------------------------------------- # Return the actor currently selected. #---------------------------------------------------------------------------- def actor # return the selected actor, or nil if none @new_party[@index] end #---------------------------------------------------------------------------- # Update the contents of the window: clear the contents bitmap, then rebuild # it. #---------------------------------------------------------------------------- def refresh # clear the contents of the bitmap self.contents.clear # draw each non-null party member for i in 0..@new_party.size - 1 # get the actor actor = @new_party[i] # if the actor is valid, draw it on the screen if actor != nil # calculate the y coordinate y = 116 * i # draw the actor's graphic draw_actor_graphic(actor, 24, y + 80) # draw the actor's name draw_actor_name(actor, 64, y + 32)
# if the actor is not available, write in red "can't select" if actor.mandatory self.contents.font.color = Color.new(255, 0, 0, 255) self.contents.draw_text(0, y, 224, 32, "Mandatory", 1) end end end end #---------------------------------------------------------------------------- # Update the position rectangle of the cursor. #---------------------------------------------------------------------------- def update_cursor_rect # reset the cursor rectangle self.cursor_rect.set(0, 116 * @index, width - 32, 96) end #---------------------------------------------------------------------------- # Change the actor selected for another, then redraw the entire window. # # Parameters: # actors: The actor that will replace the selected one #---------------------------------------------------------------------------- def change_selection(actor) # change the actor (can be nil to remove it) @new_party[@index] = actor # redraw the window refresh end #---------------------------------------------------------------------------- # Update the help window. (Here, the help window is really the actor status # window.) #---------------------------------------------------------------------------- def update_help # draw the selected actor's name, level, status conditions and stats @help_window.draw_actor_status(@new_party[@index]) end end
Window_SwitchReserve
CODE
- Code:
-
#============================================================================== # Window_SwitchReserve class definition #------------------------------------------------------------------------------ # A window that displays all characters available to pick in the party. Offers # a cursor to select them # # By exseiken, October 04, 2004 #==============================================================================
class Window_SwitchReserve < Window_Selectable
#---------------------------------------------------------------------------- # Window constructor. Create the contents bitmap and fill it with all # characters that are not into the party, but that are loaded in the data # member of the Game_Actors global object. # # Parameters: # max_size: The maximum of characters that can fit into that # window #---------------------------------------------------------------------------- def initialize(max_size) # initialize the window and its contents super(256, 128, 384, 352) self.contents = Bitmap.new(width - 32, height - 32) self.contents.font.name = $fontface self.contents.font.size = $fontsize
# initialize the list for the first time @actor_list = $game_actors.data.clone # remove currently active party members $game_party.actors.each do |actor| @actor_list[actor.actor_id] = nil end # remove all actors that are unavailable $game_actors.data.each do |actor| if actor != nil and actor.unavailable @actor_list[actor.actor_id] = nil end end # remove all holes in the list @actor_list.compact! # set the maximum of characters the list can contain @item_max = max_size # 2 columns, 5 rows @column_max = 2 @row_max = 5 # select the first item @index = 0 # default: unactive self.active = false # draw the window's contents refresh # draw the cursor rectangle update_cursor_rect end #---------------------------------------------------------------------------- # Update the contents of the window: clear the contents bitmap, then rebuild # it. #---------------------------------------------------------------------------- def refresh # clear the contents of the bitmap self.contents.clear # display all actors for i in 0..@actor_list.size # get the concerned actor actor = @actor_list[i] # if the actor is non-nil, draw it if actor != nil # get the coordinates x = (i & 0x01) == 1 ? 176 : 0 y = (i >> 0x01) * 64 # draw the actor's sprite draw_actor_graphic(actor, x + 24, y + 48) # draw the actor's name draw_actor_name(actor, x + 64, y + 16) end end end #---------------------------------------------------------------------------- # Update the position rectangle of the cursor. #---------------------------------------------------------------------------- def update_cursor_rect # if the screen is not active, don't display the cursor if not active self.cursor_rect.empty # otherwise, display it else self.cursor_rect.set((@index & 0x01) == 1 ? 176 : 0, (@index >> 0x01) * 64, 176, 64) end end #---------------------------------------------------------------------------- # Takes a character, put in into the list at the selected position, and # returns the character that was presently there. If there was no # character, returns nil. # # Parameters: # actor_to_switch: The character to put at the selected position #---------------------------------------------------------------------------- def swap_characters(actor_to_switch) # store the old actor (needed for swapping) old_actor = @actor_list[@index] # put the new actor at the place @actor_list[@index] = actor_to_switch # redraw the window refresh # return the old actor return old_actor end #---------------------------------------------------------------------------- # Update the help window. (Here, the help window is really the actor status # window.) #---------------------------------------------------------------------------- def update_help # draw the selected actor's name, level, status conditions and stats @help_window.draw_actor_status(@actor_list[@index]) end end
SwitchStatus
CODE
- Code:
-
#============================================================================== # Window_SwitchStatus class definition #------------------------------------------------------------------------------ # A window that displays the status of a character being selected. # # By exseiken, October 04, 2004 #==============================================================================
class Window_SwitchStatus < Window_Base
#---------------------------------------------------------------------------- # Construct the window: create the contents bitmap. #---------------------------------------------------------------------------- def initialize # create the window and initialize its contents super(256, 0, 384, 128) self.contents = Bitmap.new(width - 32, height - 32) self.contents.font.name = $fontface self.contents.font.size = $fontsize end #---------------------------------------------------------------------------- # Draw the status on an actor on the window's contents. # # Parameters: # actor: The actor to put on the screen #---------------------------------------------------------------------------- def draw_actor_status(actor) # clear the contents of the bitmap self.contents.clear # if the actor to draw is nil, leave the window empty if actor == nil return end # draw the actor's graphic draw_actor_graphic(actor, 24, 56) # draw the actor's name, level draw_actor_name(actor, 64, 0) draw_actor_level(actor, 288, 0) draw_actor_hp(actor, 64, 32) draw_actor_sp(actor, 64, 64) end end
Now, you have a few files to modify:
In the Game_Actor script, add this just after the line "class Game_Actor [...]" in the beginning
CODE
- Code:
-
attr_reader :actor_id attr_accessor :mandatory attr_accessor :unavailable
Again in Game_Actor, in the method setup (beginning under the line "def setup(actor_id)" and up to the "end" statement), add anywhere the following
CODE
- Code:
-
mandatory = false unavailable = false
In the Game_Actors script, add this just after the line "class Game_Actors [...]" in the beginning
CODE
- Code:
-
attr_accessor :data
In the Game_Party script, change the following line:
CODE
- Code:
-
attr_reader :actors
for this one
CODE
- Code:
-
attr_accessor :actors
To display the screen from the map screen, use the Call Script command and type this:
CODE
- Code:
-
$scene = Scene_Switch.new(false, minimum_party_size_allowed, maximum_party_size_allowed)
or you can just write
CODE
- Code:
-
$scene = Scene_Switch.new(false)
Calling it from your CMS is the same thing, except that you set the first parameter to true. (Which will make the game return to your main menu.)
If the new actor parameter, "mandatory", is true, it means that the character can't be moved out of the party. This is useful for heroes, that are usually required through a major part of a game. If you want to make a party member mandatory, use this:
CODE
- Code:
-
$game_actor.actors[number_of_the_party_member_to_become_mandatory].mandatory = true
To make it non-mandatory, use this:
CODE
- Code:
-
$game_actor.actors[number_of_the_party_member_to_become_non_mandatory].mandatory = false
The other new actor parameter is "unavailable". If it's set to true, the character won't appear in the reserve window. If you want to make a party member unavailable, use this:
CODE
- Code:
-
$game_actor.actors[number_of_the_party_member_to_become_mandatory].unavailable = true
To make it non-mandatory, use this:
CODE
- Code:
-
$game_actor.actors[number_of_the_party_member_to_become_non_mandatory].unavailable = false
I hope you'll find it useful
Everything above is an exact quote from the maker of this script
|
|
|
| |
|
Alastyr
|
May 4 2005, 12:36 AM
Post #40
|
|
- Posts:
- 0
- Group:
- Member
- Member
- #234
- Joined:
- February 26, 2005
|
This may help as well
Hmm maybe you made a mistake in your Call Script, or maybe I didn't explain it well.
Try this in your Call Script:
CODE
- Code:
-
$game_party.actors[0].mandatory = true $scene = Scene_Switch.new(false)
The first character in your party should become mandatory. If you wanted the second character to become mandatory, use "$game_party.actors[1] ...", for the second, it's "$game_party.actors[2] ..." and so on. The "unavailable" property works alike, except that you use ".unavailable" instead or ".mandatory". Before that, however, make sure that the exists, or it will crash. (Like, you can't remove party member 3 if there's no party member 3)
If it still doesn't work, after you get an error message, go in the script window. After the game crashes, the script editor cursor will be positionned at the line that caused an error. Please post the entire line that caused the error. I have tested it a lot before posting, but no software is 100% bug-free.
About your second question: when you add a character in your party, for the very first time (with Change Party) he or she is automatically available (unless the "unavailable" property is set), so if that character is not in your party, s/he should be in the reserve window on the right. If, after the character has been in your party, you want to remove him, set the "unavailable" property =true.
In other words, once a character joins the party, it's always available in the reserve window. Because that's not always desired, I added the "unavailable" property.
Also, there's an alternative to the script I wrote. The one I wrote required you to have that character in your party to change the "mandatory" and "unavailable" properties. If you want to modify those properties without having to add the concerned character in the party beforehand, you can use "$game_actors.data[]", since it contains ALL characters that joined the party.
Since I suck at explaining, here's an example, where I will make character #4 unavailable.
CODE
- Code:
-
$game_actors.data[4].unavailable = true
Just change the 4 for the number of the character you want to make unavailable. For "mandatory", it's the same thing.
Once again, make sure the character you want to make mandatory or unavailable has already joined your party, otherwise it will crash.
|
|
|
| |
| 1 user reading this topic (1 Guest and 0 Anonymous)
|