Difference between revisions of "GSDP:GAM100/CProcessing/SetNextGameState()"
From Inside
< GSDP:GAM100 | CProcessing
>Zachary.logsdon |
>Zachary.logsdon |
||
(One intermediate revision by the same user not shown) | |||
Line 29: | Line 29: | ||
} | } | ||
− | + | CP_main | |
{ | { | ||
// Set the initial game state | // Set the initial game state | ||
Line 43: | Line 43: | ||
* [[GSDP:GAM100/CProcessing|Main Page]] | * [[GSDP:GAM100/CProcessing|Main Page]] | ||
* [[GSDP:GAM100/CProcessing/Run()|Run()]] | * [[GSDP:GAM100/CProcessing/Run()|Run()]] | ||
+ | * [[GSDP:GAM100/CProcessing/CP_main|CP_main]] | ||
* [[GSDP:GAM100/CProcessing/Terminate()|Terminate()]] | * [[GSDP:GAM100/CProcessing/Terminate()|Terminate()]] | ||
* [[GSDP:GAM100/CProcessing/SetNextGameState()|SetNextGameState()]] | * [[GSDP:GAM100/CProcessing/SetNextGameState()|SetNextGameState()]] | ||
* [[GSDP:GAM100/CProcessing/SetNextGameStateForced()|SetNextGameStateForced()]] | * [[GSDP:GAM100/CProcessing/SetNextGameStateForced()|SetNextGameStateForced()]] |
Latest revision as of 08:41, 20 October 2019
SetNextGameState()
Description
This sets the next state for the program to enter. This will call the shutdown function of the current state if own exists. Calling SetNextGameState() on the same state you are currently in will have no effect, but calling SetNextGameStateForced() will restart the current state.
Parameters
SetNextGameState(FunctionPtr init, FunctionPtr update, FunctionPtr shutdown)
- init - (FunctionPtr) The name of the function called once when the state first begins. This can be NULL if no initialization is needed for your state.
- update - (FunctionPtr) The name of the function called every frame to update the state.
- shutdown - (FunctionPtr) The name of the function called when you leave a state. This occurs when you call SetNextGameState or SetNextGameStateForced() to change states. This can be NULL if no cleanup is needed for your state.
Example Usage
void init(void)
{
/* Set the size of the window */
size(500, 500);
}
void update(void)
{
/* Set the background color to black every frame */
background(color(0, 0, 0, 255));
/* Draw a rectangle at the mouse position */
rect(mouseX, mouseY, 50, 50);
}
CP_main
{
// Set the initial game state
SetNextGameState(init, update, NULL);
// Run the program
Run();
}