Add the files.
Start with a main.cpp and CMakeLists.txt files:
main.cpp
#include <smk/Color.hpp>
#include <smk/Shape.hpp>
#include <smk/Window.hpp>
int main() {
circle.SetPosition(320,240);
while (!window.input().IsKeyPressed(GLFW_KEY_ESCAPE)) {
window.PoolEvents();
window.Draw(circle);
window.Display();
window.LimitFrameRate(60 );
}
return 0;
}
static Transformable Circle(float radius)
Return a circle.
A window. You can draw objects on the window.
const glm::vec4 Black
Black.
CMakeLists.txt
cmake_minimum_required (VERSION 3.11)
include(FetchContent)
FetchContent_Declare(smk GIT_REPOSITORY https://github.com/ArthurSonzogni/smk.git)
FetchContent_GetProperties(smk)
if(NOT smk_POPULATED)
FetchContent_Populate(smk)
add_subdirectory(${smk_SOURCE_DIR} ${smk_BINARY_DIR} EXCLUDE_FROM_ALL)
endif()
project(Example
LANGUAGES CXX
VERSION 0.1.0
)
add_executable(main main.cpp)
target_link_libraries(main smk)
Build for the desktop.
mkdir build
cd build
cmake ..
make -j
./main
Build for the Web.
mkdir build
cd build
emcmake cmake ..
make -j
Then you will need to import the generated "main.js" into an html file like this one:
<canvas id="canvas" oncontextmenu="event.preventDefault()">
Loading...
</canvas>
<script>
let Module = {
print: console.log;
printerr: console.err
canvas: document.getElementById('canvas')
};
</script>
<script async src="main.js"></script>
Your C++ file will have to define its main loop function that will get called on each frame:
emscripten_set_main_loop(&MainLoop, 0, 1);