State Manager¶
- class game_state.StateManager(window)¶
The State Manager used for managing multiple State(s).
- Parameters:
window (
Surface) –Added in version 1.0.
The main game window.
- Attributes:
- is_running:
bool Added in version 2.0.
A bool for controlling the game loop.
Trueby default.
- is_running:
- property current_state: State | None¶
The current state if applied. Will be
Noneotherwise.Changed in version 2.0: Changed from method to property.
Note
This is a read-only attribute. To change states use
change_state()instead.
- property last_state: State | None¶
The last state object if any. Will be
NoneotherwiseChanged in version 2.0: Changed from method to property.
Note
This is a read-only attribute.
- property lazy_state_map: Dict[str, Tuple[Type[State], List[StateArgs] | None]]¶
A dictionary copy of all the added lazy state names mapped to their respective type and state args.
Added in version 2.2.
Note
This is a read-only attribute.
Note
Once the lazy state has been fully initialized, it will be removed from the lazy state map.
- property state_map: Dict[str, State]¶
A dictionary copy of all the state names mapped to their respective instance.
Changed in version 2.0: Changed from method to property.
Added in version 1.0.
Note
This is a read-only attribute.
- property global_on_enter: Callable[[State, State | None], None] | None¶
The global on_enter listener called right before a state’s on_enter listener.
Changed in version 2.0.3: Global listeners can accept
Nonenow.Added in version 2.0.
Note
This has to be assigned before changing the states.
The first argument passed to the function is the current state and the second is the previous state which may be
None.Example for a
global_on_enterfunction-def global_on_enter( current_state: State, previous_state: None | State ) -> None: if previous_state: print( f"GLOBAL ENTER - Entering {current_state.state_name} from {previous_state.state_name}" )
- property global_on_leave: Callable[[State | None, State], None] | None¶
The global on_leave listener called right before a state’s on_leave listener.
Changed in version 2.0.3: Global listeners can accept
Nonenow.Added in version 2.0.
Note
This has to be assigned before changing the states.
The first argument passed to the function is the current state which may be
Noneand the second is the next state to take place.Example for a
global_on_leavefunction-def global_on_leave( current_state: None | State, next_state: State ) -> None: if current_state: print( f"GLOBAL LEAVE - Leaving {current_state.state_name} to {next_state.state_name}" )
- property global_on_setup: Callable[[State], None] | None¶
The global
on_setupfunction for all states.Changed in version 2.0.3: Global listeners can accept
Nonenow.Added in version 2.0.
Note
This has to be assigned before loading the states into the manager.
The first argument passed to the function is the current state which has been setup.
Example for a
global_on_setupfunction-def global_setup(state: State) -> None: print(f"GLOBAL SETUP - Setting up state: {state.state_name}")
- change_state(state_name)¶
Changes the current state and updates the last state. This method executes the
State.on_leave()&State.on_enter()state & global listeners (global_on_leave()&global_on_enter())Added in version 1.0.
- Parameters:
state_name (
str) –The name of the State you want to switch to.- Raises:
game_state.errors.StateError- Raised when the state name doesn’t exist in the manager.
- Return type:
- connect_state_hook(path, **kwargs)¶
Calls the hook function of the state file.
Added in version 1.0.
- Parameters:
- Raises:
game_state.errors.StateError- Raised when the hook function was not found in the state file to be loaded.
- Return type:
- add_lazy_states(*lazy_states, force=False, state_args=None)¶
Lazily adds the States into the StateManager. Unlike
load_states(), it only initializes the state when required i.e. whenchange_state()switches to the lazy state.Added in version 2.2.
- Parameters:
states –
The States to be loaded into the manager.force (
bool) –DefaultFalse.Loads the State regardless of whether the State has already been loaded or notwithout raising any internal error.Warning
If set to
Trueit may lead to unexpected behavior.state_args (
Optional[Iterable[StateArgs]]) –The data to be passed to the subclassed states upon their initialization in the manager.
- Raises:
game_state.errors.StateLoadError- Raised when the state has already been loaded.Only raised when
forceis set toFalse. game_state.errors.StateLoadError- Raised when the passed argument(s) is not subclassed from
State.
- Return type:
- load_states(*states, force=False, state_args=None)¶
Loads the States into the StateManager.
Changed in version 2.1: Method now accepts
state_args.Added in version 1.0.
- Parameters:
- The States to be loaded into the manager.
force (
bool) –DefaultFalse.Loads the State regardless of whether the State has already been loaded or notwithout raising any internal error.Warning
If set to
Trueit may lead to unexpected behavior.state_args (
Optional[Iterable[StateArgs]]) –The data to be passed to the subclassed states upon their initialization in the manager.
- Raises:
game_state.errors.StateLoadError- Raised when the state has already been loaded.Only raised when
forceis set toFalse. game_state.errors.StateError- Raised when the passed argument(s) is not subclassed from
State.
- Return type:
- reload_state(state_name, force=False, **kwargs)¶
Reloads the specified State. A short hand to
unload_state()&load_states().Added in version 1.0.
- Parameters:
state_name (
str) –TheStatename to be reloaded.force (
bool) –DefaultFalse.Reloads the State even if it’s an actively running State withoutraising any internal error.Warning
If set to
Trueit may lead to unexpected behavior.**kwargs (
Any) –The keyword arguments to be passed to theStateManager.unload_state&StateManager.load_state.
- Return type:
- Returns:
- Returns the newly made
Stateinstance. - Raises:
game_state.errors.StateLoadError- Raised when the state has already been loaded.Only raised when
forceis set toFalse.
- remove_lazy_state(state_name)¶
Removes the specified lazy state from the
StateManager.Added in version 2.2.
- Parameters:
state_name (
str) –The state to be removed from the manager.**kwargs –
The keyword arguments to be passed on to the raised errors.
- Return type:
- Returns:
- Either returns
Noneif the lazy state was not found or it returns atuple with the first element being the lazy state and the second beingtheStateArgsif any were passed.
- unload_state(state_name, force=False, **kwargs)¶
Unloads the specified state from the
StateManager.Added in version 1.0.
- Parameters:
state_name (
str) –The state name to be unloaded from the manager.force (
bool) –DefaultFalse.Unloads the State even if it’s an actively running State without raising anyinternal error.Warning
If set to
Trueit may lead to unexpected behavior.**kwargs (
Any) –The keyword arguments to be passed on to the raised errors.
- Return type:
- Returns:
- The
Stateclass of the deleted State name. - Raises:
game_state.errors.StateLoadError- Raised when the state doesn’t exist in the manager to be unloaded.
game_state.errors.StateError- Raised when trying to unload an actively running State.Only raised when
forceis set toFalse.