Compare commits
2 commits
f919b166df
...
23dd7ace18
Author | SHA1 | Date | |
---|---|---|---|
23dd7ace18 | |||
3822973d6a |
14 changed files with 491 additions and 159 deletions
116
.vscode/launch.json
vendored
116
.vscode/launch.json
vendored
|
@ -1,33 +1,91 @@
|
|||
{
|
||||
"configurations": [
|
||||
{
|
||||
"name": "(gdb) Launch gl.elf",
|
||||
"type": "cppdbg",
|
||||
"request": "launch",
|
||||
"program": "${workspaceFolder}/build/gl.elf",
|
||||
"args": [],
|
||||
"stopAtEntry": false,
|
||||
"cwd": "${workspaceFolder}",
|
||||
"environment": [],
|
||||
"externalConsole": false,
|
||||
"MIMode": "gdb",
|
||||
"miDebuggerPath": "/opt/toolchains/dc/sh-elf/bin/sh-elf-gdb",
|
||||
"miDebuggerServerAddress": "localhost:3263",
|
||||
"debugServerPath": "/usr/bin/flycast",
|
||||
"debugServerArgs": "${workspaceFolder}/build/gl.elf",
|
||||
"setupCommands": [
|
||||
{
|
||||
"description": "Enable pretty-printing for gdb",
|
||||
"text": "-enable-pretty-printing",
|
||||
"ignoreFailures": true
|
||||
},
|
||||
{
|
||||
"description": "Set SuperH architechture",
|
||||
"text": "set architecture sh4"
|
||||
}
|
||||
],
|
||||
"avoidWindowsConsoleRedirection": false,
|
||||
"internalConsoleOptions": "openOnSessionStart"
|
||||
}
|
||||
{
|
||||
"name": "(gdb) Launch gl.elf",
|
||||
"type": "cppdbg",
|
||||
"request": "launch",
|
||||
"program": "${workspaceFolder}/build/gl.elf",
|
||||
"args": [],
|
||||
"stopAtEntry": false,
|
||||
"cwd": "${workspaceFolder}",
|
||||
"environment": [],
|
||||
"externalConsole": false,
|
||||
"MIMode": "gdb",
|
||||
"miDebuggerPath": "/opt/toolchains/dc/sh-elf/bin/sh-elf-gdb",
|
||||
"miDebuggerServerAddress": "localhost:3263",
|
||||
"debugServerPath": "/usr/bin/flycast",
|
||||
"debugServerArgs": "${workspaceFolder}/build/gl.elf",
|
||||
"setupCommands": [
|
||||
{
|
||||
"description": "Enable pretty-printing for gdb",
|
||||
"text": "-enable-pretty-printing",
|
||||
"ignoreFailures": true
|
||||
},
|
||||
{
|
||||
"description": "Set SuperH architechture",
|
||||
"text": "set architecture sh4"
|
||||
}
|
||||
],
|
||||
"avoidWindowsConsoleRedirection": false,
|
||||
"internalConsoleOptions": "openOnSessionStart"
|
||||
},
|
||||
{
|
||||
"name": "(gdb) Launch cube.elf",
|
||||
"type": "cppdbg",
|
||||
"request": "launch",
|
||||
"program": "${workspaceFolder}/build/cube.elf",
|
||||
"args": [],
|
||||
"stopAtEntry": false,
|
||||
"cwd": "${workspaceFolder}",
|
||||
"environment": [],
|
||||
"externalConsole": false,
|
||||
"MIMode": "gdb",
|
||||
"miDebuggerPath": "/opt/toolchains/dc/sh-elf/bin/sh-elf-gdb",
|
||||
"miDebuggerServerAddress": "localhost:3263",
|
||||
"debugServerPath": "/usr/bin/flycast",
|
||||
"debugServerArgs": "${workspaceFolder}/build/cube.elf",
|
||||
"setupCommands": [
|
||||
{
|
||||
"description": "Enable pretty-printing for gdb",
|
||||
"text": "-enable-pretty-printing",
|
||||
"ignoreFailures": true
|
||||
},
|
||||
{
|
||||
"description": "Set SuperH architechture",
|
||||
"text": "set architecture sh4"
|
||||
}
|
||||
],
|
||||
"avoidWindowsConsoleRedirection": false,
|
||||
"internalConsoleOptions": "openOnSessionStart"
|
||||
},
|
||||
{
|
||||
"name": "(gdb, lxdream-nitro) Launch cube.elf",
|
||||
"type": "cppdbg",
|
||||
"request": "launch",
|
||||
"program": "${workspaceFolder}/build/cube.elf",
|
||||
"args": [],
|
||||
"stopAtEntry": false,
|
||||
"cwd": "${workspaceFolder}",
|
||||
"environment": [],
|
||||
"externalConsole": false,
|
||||
"MIMode": "gdb",
|
||||
"miDebuggerPath": "/opt/toolchains/dc/sh-elf/bin/sh-elf-gdb",
|
||||
"miDebuggerServerAddress": "localhost:3263",
|
||||
"debugServerPath": "/home/user/Downloads/lxdream-nitro/builddir/lxdream-nitro",
|
||||
"debugServerArgs": "-d -g 3263 -e ${workspaceFolder}/build/cube.elf",
|
||||
"setupCommands": [
|
||||
{
|
||||
"description": "Enable pretty-printing for gdb",
|
||||
"text": "-enable-pretty-printing",
|
||||
"ignoreFailures": true
|
||||
},
|
||||
{
|
||||
"description": "Set SuperH architechture",
|
||||
"text": "set architecture sh4"
|
||||
}
|
||||
],
|
||||
"avoidWindowsConsoleRedirection": false,
|
||||
"internalConsoleOptions": "openOnSessionStart"
|
||||
}
|
||||
]
|
||||
}
|
||||
|
|
145
cube.cc
Normal file
145
cube.cc
Normal file
|
@ -0,0 +1,145 @@
|
|||
#include <GL/gl.h>
|
||||
#include <GL/glext.h>
|
||||
#include <GL/glkos.h>
|
||||
#include <GL/glu.h>
|
||||
#include <stb_image/stb_image.h>
|
||||
#include <tiny_obj_loader.h>
|
||||
|
||||
#include <cstdio>
|
||||
#include "engine.hh"
|
||||
|
||||
class Cube : public Engine {
|
||||
unsigned int texture;
|
||||
tinyobj::ObjReader reader;
|
||||
|
||||
bool parseObj(std::string objFile, tinyobj::ObjReader& reader);
|
||||
void cube();
|
||||
void displayStuff();
|
||||
void gameLoop() override { displayStuff(); }
|
||||
void initScreen() override;
|
||||
void model();
|
||||
};
|
||||
|
||||
void Cube::model() {
|
||||
const tinyobj::attrib_t& attrib = reader.GetAttrib();
|
||||
auto& shapes = reader.GetShapes();
|
||||
angle += 1.0f;
|
||||
glRotatef(angle, 1.0f, 0.0f, 1.0f);
|
||||
|
||||
int drawCalls = 0;
|
||||
|
||||
for (size_t s = 0; s < shapes.size(); s++) {
|
||||
// Loop over faces(polygon)
|
||||
size_t index_offset = 0;
|
||||
for (size_t f = 0; f < shapes[s].mesh.num_face_vertices.size(); f++) {
|
||||
size_t fv = size_t(shapes[s].mesh.num_face_vertices[f]);
|
||||
|
||||
glBegin(GL_TRIANGLES);
|
||||
// Loop over vertices in the face.
|
||||
for (size_t v = 0; v < fv; v++) {
|
||||
// access to vertex
|
||||
tinyobj::index_t idx = shapes[s].mesh.indices[index_offset + v];
|
||||
tinyobj::real_t vx =
|
||||
attrib.vertices[3 * size_t(idx.vertex_index) + 0];
|
||||
tinyobj::real_t vy =
|
||||
attrib.vertices[3 * size_t(idx.vertex_index) + 1];
|
||||
tinyobj::real_t vz =
|
||||
attrib.vertices[3 * size_t(idx.vertex_index) + 2];
|
||||
glVertex3f(vx, vy, vz);
|
||||
drawCalls += 1;
|
||||
|
||||
|
||||
// Check if `normal_index` is zero or positive. negative = no
|
||||
// normal data
|
||||
if (idx.normal_index >= 0) {
|
||||
tinyobj::real_t nx =
|
||||
attrib.normals[3 * size_t(idx.normal_index) + 0];
|
||||
tinyobj::real_t ny =
|
||||
attrib.normals[3 * size_t(idx.normal_index) + 1];
|
||||
tinyobj::real_t nz =
|
||||
attrib.normals[3 * size_t(idx.normal_index) + 2];
|
||||
glNormal3f(nx, ny, nz);
|
||||
drawCalls += 1;
|
||||
}
|
||||
|
||||
// Check if `texcoord_index` is zero or positive. negative = no
|
||||
// texcoord data
|
||||
if (idx.texcoord_index >= 0) {
|
||||
tinyobj::real_t tx =
|
||||
attrib.texcoords[2 * size_t(idx.texcoord_index) + 0];
|
||||
tinyobj::real_t ty =
|
||||
attrib.texcoords[2 * size_t(idx.texcoord_index) + 1];
|
||||
glTexCoord2f(tx, ty);
|
||||
drawCalls += 1;
|
||||
}
|
||||
}
|
||||
index_offset += fv;
|
||||
|
||||
glEnd();
|
||||
}
|
||||
}
|
||||
printf("Draw Calls: %i\n", drawCalls);
|
||||
drawCalls = 0;
|
||||
|
||||
// glDrawArrays(GL_QUADS, 0, susSize);
|
||||
}
|
||||
|
||||
bool Cube::parseObj(std::string objFile, tinyobj::ObjReader& reader) {
|
||||
tinyobj::ObjReaderConfig readerConfig;
|
||||
readerConfig.mtl_search_path = "./";
|
||||
if (!reader.ParseFromFile(objFile, readerConfig)) {
|
||||
if (!reader.Error().empty()) {
|
||||
printf("TinyOBJReader: %s\n", reader.Error().c_str());
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
void Cube::displayStuff() {
|
||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||
glLoadIdentity();
|
||||
glTranslatef(0.0f, 0.0f, -5.0f);
|
||||
glRotatef(90, 0.0f, 1.0f, 0.5f);
|
||||
model();
|
||||
glKosSwapBuffers();
|
||||
}
|
||||
|
||||
void Cube::initScreen() {
|
||||
glKosInit();
|
||||
|
||||
glMatrixMode(GL_PROJECTION);
|
||||
glLoadIdentity();
|
||||
gluPerspective(45.0f, 640.0f / 480.0f, 0.1f, 100.0f);
|
||||
glMatrixMode(GL_MODELVIEW);
|
||||
glEnable(GL_TEXTURE_2D);
|
||||
glEnable(GL_DEPTH_TEST);
|
||||
glFrontFace(GL_CW);
|
||||
|
||||
glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
||||
|
||||
glGenTextures(1, &texture);
|
||||
glBindTexture(GL_TEXTURE_2D, texture);
|
||||
|
||||
int width, height, nr_channels;
|
||||
unsigned char* data =
|
||||
stbi_load("/rd/sanic.png", &width, &height, &nr_channels, 0);
|
||||
|
||||
if (data) {
|
||||
glTexImage2D(GL_TEXTURE_2D, 0, GL_RGBA, width, height, 0, GL_RGBA,
|
||||
GL_UNSIGNED_BYTE, data);
|
||||
glGenerateMipmap(GL_TEXTURE_2D);
|
||||
} else {
|
||||
printf("Texture failed to load.\n");
|
||||
}
|
||||
|
||||
stbi_image_free(data);
|
||||
|
||||
if (!parseObj("/rd/cube.obj", reader)) return;
|
||||
}
|
||||
|
||||
int main() {
|
||||
Cube engine;
|
||||
engine.initializeEngine();
|
||||
engine.initializeGameLoop();
|
||||
}
|
73
engine.cc
Normal file
73
engine.cc
Normal file
|
@ -0,0 +1,73 @@
|
|||
#define TINYOBJLOADER_IMPLEMENTATION
|
||||
|
||||
#include "engine.hh"
|
||||
|
||||
#include <GL/gl.h>
|
||||
#include <GL/glkos.h>
|
||||
|
||||
#include <cstdio>
|
||||
#include <functional>
|
||||
|
||||
void Engine::initScreen() {
|
||||
glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
|
||||
glViewport(0, 0, 640, 480);
|
||||
glMatrixMode(GL_MODELVIEW);
|
||||
glLoadIdentity();
|
||||
glOrtho(0, 640, 0, 480, -100, 100);
|
||||
glMatrixMode(GL_PROJECTION);
|
||||
glLoadIdentity();
|
||||
}
|
||||
|
||||
void Engine::printSystemInformation() {
|
||||
printf("GL_VENDOR: %s\n", glGetString(GL_VENDOR));
|
||||
printf("GL_RENDERER: %s\n", glGetString(GL_RENDERER));
|
||||
printf("GL_VERSION: %s\n", glGetString(GL_VERSION));
|
||||
printf("GL_EXTENSIONS: %s\n", glGetString(GL_EXTENSIONS));
|
||||
}
|
||||
|
||||
void Engine::initializeEngine() {
|
||||
glKosInit();
|
||||
initScreen();
|
||||
printSystemInformation();
|
||||
}
|
||||
|
||||
template <typename T>
|
||||
void Engine::deltaTimeLoop(T&& callback, struct timeval& beginningOfFrame,
|
||||
struct timeval& endOfFrame) {
|
||||
gettimeofday(&beginningOfFrame, 0);
|
||||
(this->*callback)();
|
||||
gettimeofday(&endOfFrame, 0);
|
||||
float time = ((float)(endOfFrame.tv_usec) * microSecond) -
|
||||
((float)(beginningOfFrame.tv_usec) * microSecond);
|
||||
if (time > 0.0f) {
|
||||
deltaTime = time;
|
||||
}
|
||||
}
|
||||
|
||||
void Engine::initializeGameLoop() {
|
||||
struct timeval beginningOfFrame, endOfFrame;
|
||||
|
||||
while (1) {
|
||||
deltaTimeLoop(&Engine::gameLoop, beginningOfFrame, endOfFrame);
|
||||
}
|
||||
}
|
||||
|
||||
void Engine::pressButton(cont_state_t* controller_state, int button,
|
||||
std::function<void()> callback) {
|
||||
if (controller_state->buttons & button) {
|
||||
if (!(buttonsPressed & button)) {
|
||||
buttonsPressed |= button;
|
||||
|
||||
callback();
|
||||
}
|
||||
} else if ((buttonsPressed & button) &&
|
||||
~(controller_state->buttons & button)) {
|
||||
buttonsPressed &= ~button;
|
||||
}
|
||||
}
|
||||
|
||||
void Engine::glVertex3fNormalized(float x, float y, float z) {
|
||||
constexpr int xSize = 640, ySize = 480;
|
||||
|
||||
glVertex3f(x * xSize, y * ySize, z);
|
||||
}
|
36
engine.hh
Normal file
36
engine.hh
Normal file
|
@ -0,0 +1,36 @@
|
|||
#ifndef ENGINE_HH
|
||||
#define ENGINE_HH
|
||||
|
||||
#include <kos.h>
|
||||
#include <sys/time.h>
|
||||
|
||||
#include <functional>
|
||||
|
||||
class Engine {
|
||||
protected:
|
||||
static constexpr float microSecond = 0.000001f;
|
||||
|
||||
float angle = 0;
|
||||
float deltaTime = 1.0 / 60.0;
|
||||
float speed = 5.0f;
|
||||
|
||||
bool thirtyfps;
|
||||
unsigned int buttonsPressed;
|
||||
|
||||
virtual void initScreen();
|
||||
void printSystemInformation();
|
||||
virtual void gameLoop(){};
|
||||
void pressButton(cont_state_t* controller_state, int button,
|
||||
std::function<void()> callback);
|
||||
void glVertex3fNormalized(float x, float y, float z);
|
||||
|
||||
private:
|
||||
template <typename T>
|
||||
void deltaTimeLoop(T&& callback, struct timeval& beginningOfFrame,
|
||||
struct timeval& endOfFrame);
|
||||
|
||||
public:
|
||||
void initializeEngine();
|
||||
void initializeGameLoop();
|
||||
};
|
||||
#endif
|
98
gl.cc
98
gl.cc
|
@ -1,53 +1,22 @@
|
|||
#include <GL/gl.h>
|
||||
#include <GL/glkos.h>
|
||||
#include <kos.h>
|
||||
#include <sys/time.h>
|
||||
|
||||
#include <algorithm>
|
||||
#include <cstdio>
|
||||
|
||||
const float microSecond = 0.000001f;
|
||||
#include "engine.hh"
|
||||
|
||||
float angle = 0;
|
||||
float deltaTime = 1.0 / 60.0;
|
||||
float speed = 5.0f;
|
||||
class Glcc : public Engine {
|
||||
void process_input();
|
||||
void displayStuff();
|
||||
|
||||
bool thirtyfps;
|
||||
uint32 buttonsPressed;
|
||||
|
||||
template <typename T>
|
||||
void pressButton(cont_state_t* controller_state, int button, T&& callback) {
|
||||
if (controller_state->buttons & button) {
|
||||
if (!(buttonsPressed & button)) {
|
||||
buttonsPressed |= button;
|
||||
|
||||
callback();
|
||||
}
|
||||
} else if ((buttonsPressed & button) &&
|
||||
~(controller_state->buttons & button)) {
|
||||
buttonsPressed &= ~button;
|
||||
void gameLoop() override {
|
||||
process_input();
|
||||
displayStuff();
|
||||
}
|
||||
}
|
||||
};
|
||||
|
||||
void initScreen() {
|
||||
glClearColor(0.0f, 0.0f, 0.0f, 0.0f);
|
||||
glViewport(0, 0, 640, 480);
|
||||
glMatrixMode(GL_MODELVIEW);
|
||||
glLoadIdentity();
|
||||
glOrtho(0, 640, 0, 480, -100, 100);
|
||||
glMatrixMode(GL_PROJECTION);
|
||||
glLoadIdentity();
|
||||
}
|
||||
|
||||
void glVertex3fNormalized(float x, float y, float z) {
|
||||
int xSize, ySize;
|
||||
xSize = 640;
|
||||
ySize = 480;
|
||||
|
||||
glVertex3f(x * xSize, y * ySize, z);
|
||||
}
|
||||
|
||||
void displayStuff() {
|
||||
void Glcc::displayStuff() {
|
||||
glClear(GL_COLOR_BUFFER_BIT);
|
||||
|
||||
// clang-format off
|
||||
|
@ -78,7 +47,7 @@ void displayStuff() {
|
|||
glKosSwapBuffers();
|
||||
}
|
||||
|
||||
void process_input() {
|
||||
void Glcc::process_input() {
|
||||
maple_device_t* controller;
|
||||
cont_state_t* controller_state;
|
||||
|
||||
|
@ -89,12 +58,15 @@ void process_input() {
|
|||
|
||||
if (!controller_state) {
|
||||
printf(
|
||||
"An error has occured while trying to read the controller.\n");
|
||||
"An error has occured while trying to read the "
|
||||
"controller.\n");
|
||||
}
|
||||
|
||||
pressButton(controller_state, CONT_DPAD_LEFT, []() { speed -= 1.0f; });
|
||||
pressButton(controller_state, CONT_DPAD_RIGHT, []() { speed += 1.0f; });
|
||||
pressButton(controller_state, CONT_A, []() { thirtyfps = !thirtyfps; });
|
||||
pressButton(controller_state, CONT_DPAD_LEFT, [&]() { speed -= 1.0f; });
|
||||
pressButton(controller_state, CONT_DPAD_RIGHT,
|
||||
[&]() { speed += 1.0f; });
|
||||
pressButton(controller_state, CONT_A,
|
||||
[&]() { thirtyfps = !thirtyfps; });
|
||||
|
||||
speed = std::clamp(speed, 1.0f, 10.0f);
|
||||
|
||||
|
@ -102,38 +74,8 @@ void process_input() {
|
|||
}
|
||||
}
|
||||
|
||||
void printSystemInformation() {
|
||||
printf("GL_VENDOR: %s\n", glGetString(GL_VENDOR));
|
||||
printf("GL_RENDERER: %s\n", glGetString(GL_RENDERER));
|
||||
printf("GL_VERSION: %s\n", glGetString(GL_VERSION));
|
||||
printf("GL_EXTENSIONS: %s\n", glGetString(GL_EXTENSIONS));
|
||||
}
|
||||
|
||||
template <typename T>
|
||||
void deltaTimeLoop(T&& callback, struct timeval& beginningOfFrame,
|
||||
struct timeval& endOfFrame) {
|
||||
gettimeofday(&beginningOfFrame, 0);
|
||||
callback();
|
||||
gettimeofday(&endOfFrame, 0);
|
||||
float time = ((float)(endOfFrame.tv_usec) * microSecond) -
|
||||
((float)(beginningOfFrame.tv_usec) * microSecond);
|
||||
if (time > 0.0f) {
|
||||
deltaTime = time;
|
||||
}
|
||||
}
|
||||
|
||||
void gameLoop() {
|
||||
process_input();
|
||||
displayStuff();
|
||||
}
|
||||
|
||||
int main() {
|
||||
glKosInit();
|
||||
initScreen();
|
||||
printSystemInformation();
|
||||
struct timeval beginningOfFrame, endOfFrame;
|
||||
|
||||
while (1) {
|
||||
deltaTimeLoop(gameLoop, beginningOfFrame, endOfFrame);
|
||||
}
|
||||
Glcc* engine = new Glcc;
|
||||
engine->initializeEngine();
|
||||
engine->initializeGameLoop();
|
||||
}
|
||||
|
|
50
hello.c
50
hello.c
|
@ -1,50 +0,0 @@
|
|||
#include <kos.h>
|
||||
|
||||
#include <GL/gl.h>
|
||||
#include <GL/glu.h>
|
||||
#include <GL/glkos.h>
|
||||
|
||||
void triangle() {
|
||||
// glClearColor(1.0f, 1.0f, 0.0f, 0.0f);
|
||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||
|
||||
glBegin(GL_TRIANGLES);
|
||||
glColor3f(1.0f, 0.0f, 0.0f);
|
||||
glVertex3f(-1.0f, -1.0f, 0.0f);
|
||||
|
||||
glColor3f(0.0f, 1.0f, 0.0f);
|
||||
glVertex3f(0.0f, 1.0f, 0.0f);
|
||||
|
||||
glColor3f(0.0f, 0.0f, 1.0f);
|
||||
glVertex3f(1.0f, -1.0f, 0.0f);
|
||||
glEnd();
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
maple_device_t *controller;
|
||||
|
||||
glKosInit();
|
||||
glMatrixMode(GL_PROJECTION);
|
||||
glLoadIdentity();
|
||||
glOrtho(0.0, 1.0, 0.0, 1.0, -1.0, 1.0);
|
||||
// gluPerspective(45.0f, 640.0f/480.0f, 0.1f, 100.0f);
|
||||
// glMatrixMode(GL_MODELVIEW);
|
||||
// glEnable(GL_TEXTURE_2D);
|
||||
// glEnable(GL_DEPTH_TEST);
|
||||
|
||||
// glFrontFace(GL_CW);
|
||||
// glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA);
|
||||
|
||||
glClearColor(0.3f, 0.4f, 0.5f, 1.0f);
|
||||
|
||||
while (1) {
|
||||
// glLoadIdentity();
|
||||
// glTranslatef(-5.0f, 0.0f, 0.0f);
|
||||
// glEnable(GL_CULL_FACE);
|
||||
triangle();
|
||||
|
||||
glKosSwapBuffers();
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
34
hello.cc
Normal file
34
hello.cc
Normal file
|
@ -0,0 +1,34 @@
|
|||
#include <GL/gl.h>
|
||||
#include <GL/glkos.h>
|
||||
#include "engine.hh"
|
||||
|
||||
class Hello : public Engine {
|
||||
void triangle();
|
||||
|
||||
void gameLoop() override {
|
||||
triangle();
|
||||
glKosSwapBuffers();
|
||||
}
|
||||
};
|
||||
|
||||
void Hello::triangle() {
|
||||
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||
|
||||
glBegin(GL_TRIANGLES);
|
||||
glColor3f(1.0f, 0.0f, 0.0f);
|
||||
glVertex3fNormalized(-1.0f, -1.0f, 0.0f);
|
||||
|
||||
glColor3f(0.0f, 1.0f, 0.0f);
|
||||
glVertex3fNormalized(0.0f, 1.0f, 0.0f);
|
||||
|
||||
glColor3f(0.0f, 0.0f, 1.0f);
|
||||
glVertex3fNormalized(1.0f, -1.0f, 0.0f);
|
||||
glEnd();
|
||||
}
|
||||
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
Hello* engine = new Hello;
|
||||
engine->initializeEngine();
|
||||
engine->initializeGameLoop();
|
||||
}
|
16
meson.build
16
meson.build
|
@ -9,12 +9,18 @@ kosportsinc = include_directories('/opt/toolchains/dc/kos-ports/include')
|
|||
|
||||
GL = cc.find_library('GL', required: true)
|
||||
math = cc.find_library('m', required: true)
|
||||
stb_image = cc.find_library('stb_image', required: true)
|
||||
subdir('romdisk')
|
||||
tinyobjloader = subproject('tinyobjloader')
|
||||
tinyobjloader_dep = tinyobjloader.get_variable('tinyobjloader_dep')
|
||||
# pcx = cc.find_library('pcx', required: true)
|
||||
# kosutils = cc.find_library('kosutils', required: true)
|
||||
|
||||
deps = [
|
||||
GL,
|
||||
math
|
||||
math,
|
||||
stb_image,
|
||||
tinyobjloader_dep
|
||||
]
|
||||
|
||||
incdirs = [
|
||||
|
@ -24,5 +30,11 @@ incdirs = [
|
|||
kosportsinc
|
||||
]
|
||||
|
||||
executable('hello.elf', ['hello.c'], dependencies: deps, include_directories: incdirs)
|
||||
engine = static_library('engine', ['engine.cc'], dependencies: deps, include_directories: incdirs)
|
||||
engine_dep = declare_dependency(link_with: engine, include_directories: incdirs)
|
||||
|
||||
deps += [engine_dep]
|
||||
|
||||
executable('hello.elf', ['hello.cc'], dependencies: deps, include_directories: incdirs)
|
||||
executable('gl.elf', ['gl.cc'], dependencies: deps, include_directories: incdirs)
|
||||
executable('cube.elf', ['cube.cc', romdsk_o], dependencies: deps, include_directories: incdirs)
|
||||
|
|
2
romdisk/cube.mtl
Normal file
2
romdisk/cube.mtl
Normal file
|
@ -0,0 +1,2 @@
|
|||
# Blender 4.0.2 MTL File: 'None'
|
||||
# www.blender.org
|
45
romdisk/cube.obj
Normal file
45
romdisk/cube.obj
Normal file
|
@ -0,0 +1,45 @@
|
|||
# Blender 4.0.2
|
||||
# www.blender.org
|
||||
mtllib cube.mtl
|
||||
o Cube
|
||||
v -1.000000 -1.000000 1.000000
|
||||
v -1.000000 1.000000 1.000000
|
||||
v -1.000000 -1.000000 -1.000000
|
||||
v -1.000000 1.000000 -1.000000
|
||||
v 1.000000 -1.000000 1.000000
|
||||
v 1.000000 1.000000 1.000000
|
||||
v 1.000000 -1.000000 -1.000000
|
||||
v 1.000000 1.000000 -1.000000
|
||||
vn -1.0000 -0.0000 -0.0000
|
||||
vn -0.0000 -0.0000 -1.0000
|
||||
vn 1.0000 -0.0000 -0.0000
|
||||
vn -0.0000 -0.0000 1.0000
|
||||
vn -0.0000 -1.0000 -0.0000
|
||||
vn -0.0000 1.0000 -0.0000
|
||||
vt 0.625000 0.000000
|
||||
vt 0.375000 0.250000
|
||||
vt 0.375000 0.000000
|
||||
vt 0.625000 0.250000
|
||||
vt 0.375000 0.500000
|
||||
vt 0.625000 0.500000
|
||||
vt 0.375000 0.750000
|
||||
vt 0.625000 0.750000
|
||||
vt 0.375000 1.000000
|
||||
vt 0.125000 0.750000
|
||||
vt 0.125000 0.500000
|
||||
vt 0.875000 0.500000
|
||||
vt 0.625000 1.000000
|
||||
vt 0.875000 0.750000
|
||||
s 0
|
||||
f 2/1/1 3/2/1 1/3/1
|
||||
f 4/4/2 7/5/2 3/2/2
|
||||
f 8/6/3 5/7/3 7/5/3
|
||||
f 6/8/4 1/9/4 5/7/4
|
||||
f 7/5/5 1/10/5 3/11/5
|
||||
f 4/12/6 6/8/6 8/6/6
|
||||
f 2/1/1 4/4/1 3/2/1
|
||||
f 4/4/2 8/6/2 7/5/2
|
||||
f 8/6/3 6/8/3 5/7/3
|
||||
f 6/8/4 2/13/4 1/9/4
|
||||
f 7/5/5 5/7/5 1/10/5
|
||||
f 4/12/6 2/14/6 6/8/6
|
24
romdisk/meson.build
Normal file
24
romdisk/meson.build
Normal file
|
@ -0,0 +1,24 @@
|
|||
romdiskcomp = find_program('/opt/toolchains/dc/kos/utils/genromfs/genromfs')
|
||||
bin2o = find_program('/opt/toolchains/dc/kos/utils/bin2o/bin2o')
|
||||
cc = find_program('/opt/toolchains/dc/sh-elf/bin/sh-elf-gcc')
|
||||
kos_libs =['-L/opt/toolchains/dc/kos/lib/dreamcast','-L/opt/toolchains/dc/kos/addons/lib/dreamcast','-L/opt/toolchains/dc/kos/../kos-ports/lib']
|
||||
|
||||
romdisk_path = join_paths(meson.current_source_dir())
|
||||
|
||||
romdisk_img = custom_target('romdisk.img',
|
||||
output : 'romdisk.img',
|
||||
build_always_stale: true,
|
||||
command: [
|
||||
romdiskcomp, '-f', '@OUTPUT@', '-d', romdisk_path, '-v', '-x', '.svn', '-x', '.keepme', '-x', 'meson.build'
|
||||
])
|
||||
|
||||
romdsk = custom_target('romdisk_tmp.o',
|
||||
output : 'romdisk_tmp.o',
|
||||
input: [romdisk_img],
|
||||
command: [
|
||||
bin2o, '@INPUT@', 'romdisk', '@OUTPUT@'
|
||||
])
|
||||
|
||||
romdsk_o = custom_target('romdisk.o', output: 'romdisk.o', input: [romdsk], command: [
|
||||
cc, '-o', '@OUTPUT@', '-r', '@INPUT@', '-Wl,--whole-archive', kos_libs, '-lromdiskbase'
|
||||
])
|
BIN
romdisk/sanic.png
Normal file
BIN
romdisk/sanic.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 44 KiB |
3
subprojects/.gitignore
vendored
Normal file
3
subprojects/.gitignore
vendored
Normal file
|
@ -0,0 +1,3 @@
|
|||
*
|
||||
!*.wrap
|
||||
!.gitignore
|
8
subprojects/tinyobjloader.wrap
Normal file
8
subprojects/tinyobjloader.wrap
Normal file
|
@ -0,0 +1,8 @@
|
|||
[wrap-git]
|
||||
url = https://github.com/tinyobjloader/tinyobjloader
|
||||
revision = cab4ad7254cbf7eaaafdb73d272f99e92f166df8
|
||||
depth = 1
|
||||
method = cmake
|
||||
|
||||
[provide]
|
||||
tinyobjloader = tinyobjloader_dep
|
Loading…
Reference in a new issue