123 lines
5.4 KiB
C
123 lines
5.4 KiB
C
/*
|
|
WELCOME raylib EXAMPLES CONTRIBUTOR!
|
|
|
|
This is a basic template to anyone ready to contribute with some code example for the library,
|
|
here there are some guidelines on how to create an example to be included in raylib
|
|
|
|
1. File naming: <module>_<description> - Lower case filename, words separated by underscore,
|
|
no more than 3-4 words in total to describe the example. <module> referes to the primary
|
|
raylib module the example is more related with (code, shapes, textures, models, shaders, raudio).
|
|
i.e: core_input_multitouch, shapes_lines_bezier, shaders_palette_switch
|
|
|
|
2. Follow below template structure, example info should list the module, the short description
|
|
and the author of the example, twitter or github info could be also provided for the author.
|
|
Short description should also be used on the title of the window.
|
|
|
|
3. Code should be organized by sections:[Initialization]- [Update] - [Draw] - [De-Initialization]
|
|
Place your code between the dotted lines for every section, please don't mix update logic with drawing
|
|
and remember to unload all loaded resources.
|
|
|
|
4. Code should follow raylib conventions: https://github.com/raysan5/raylib/wiki/raylib-coding-conventions
|
|
Try to be very organized, using line-breaks appropiately.
|
|
|
|
5. Add comments to the specific parts of code the example is focus on.
|
|
Don't abuse with comments, try to be clear and impersonal on the comments.
|
|
|
|
6. Try to keep the example simple, under 300 code lines if possible. Try to avoid external dependencies.
|
|
Try to avoid defining functions outside the main(). Example should be as self-contained as possible.
|
|
|
|
7. About external resources, they should be placed in a [resources] folder and those resources
|
|
should be open and free for use and distribution. Avoid propietary content.
|
|
|
|
8. Try to keep the example simple but with a creative touch.
|
|
Simple but beautiful examples are more appealing to users!
|
|
|
|
9. In case of additional information is required, just come to raylib Discord channel: example-contributions
|
|
|
|
10. Have fun!
|
|
|
|
The following files should be updated when adding a new example, it's planned to create some
|
|
script to automatize this process but not available yet.
|
|
|
|
- raylib/examples/<category>/<category>_example_name.c
|
|
- raylib/examples/<category>/<category>_example_name.png
|
|
- raylib/examples/<category>/resources/*.*
|
|
- raylib/examples/Makefile
|
|
- raylib/examples/Makefile.Web
|
|
- raylib/examples/README.md
|
|
- raylib/projects/VS2022/examples/<category>_example_name.vcxproj
|
|
- raylib/projects/VS2022/raylib.sln
|
|
- raylib.com/common/examples.js
|
|
- raylib.com/examples/<category>/<category>_example_name.html
|
|
- raylib.com/examples/<category>/<category>_example_name.data
|
|
- raylib.com/examples/<category>/<category>_example_name.wasm
|
|
- raylib.com/examples/<category>/<category>_example_name.js
|
|
*/
|
|
|
|
/*******************************************************************************************
|
|
*
|
|
* raylib [core] example - Basic window
|
|
*
|
|
* Example originally created with raylib 4.5, last time updated with raylib 4.5
|
|
*
|
|
* Example contributed by <user_name> (@<user_github>) and reviewed by Ramon Santamaria (@raysan5)
|
|
*
|
|
* Example licensed under an unmodified zlib/libpng license, which is an OSI-certified,
|
|
* BSD-like license that allows static linking with closed source software
|
|
*
|
|
* Copyright (c) 2023 <user_name> (@<user_github>)
|
|
*
|
|
********************************************************************************************/
|
|
|
|
#include "raylib.h"
|
|
|
|
//------------------------------------------------------------------------------------
|
|
// Program main entry point
|
|
//------------------------------------------------------------------------------------
|
|
int main(void)
|
|
{
|
|
// Initialization
|
|
//--------------------------------------------------------------------------------------
|
|
const int screenWidth = 800;
|
|
const int screenHeight = 450;
|
|
|
|
InitWindow(screenWidth, screenHeight, "raylib [core] example - basic window");
|
|
|
|
// TODO: Load resources / Initialize variables at this point
|
|
|
|
SetTargetFPS(60);
|
|
//--------------------------------------------------------------------------------------
|
|
|
|
// Main game loop
|
|
while (!WindowShouldClose()) // Detect window close button or ESC key
|
|
{
|
|
// Update
|
|
//----------------------------------------------------------------------------------
|
|
// TODO: Update variables / Implement example logic at this point
|
|
//----------------------------------------------------------------------------------
|
|
|
|
// Draw
|
|
//----------------------------------------------------------------------------------
|
|
BeginDrawing();
|
|
|
|
ClearBackground(RAYWHITE);
|
|
|
|
// TODO: Draw everything that requires to be drawn at this point:
|
|
|
|
DrawText("Congrats! You created your first window!", 190, 200, 20, LIGHTGRAY); // Example
|
|
|
|
EndDrawing();
|
|
//----------------------------------------------------------------------------------
|
|
}
|
|
|
|
// De-Initialization
|
|
//--------------------------------------------------------------------------------------
|
|
|
|
// TODO: Unload all loaded resources at this point
|
|
|
|
CloseWindow(); // Close window and OpenGL context
|
|
//--------------------------------------------------------------------------------------
|
|
|
|
return 0;
|
|
}
|