summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorraysan5 <[email protected]>2020-05-09 12:05:08 +0200
committerraysan5 <[email protected]>2020-05-09 12:05:08 +0200
commitcb3bdf09c64f7c6d77c5728814aa144b225b77ec (patch)
treeaf78d9e9ddb62bb4d32ded3ff7f4fde19d1776c1
parent959447d8ed69e63b279bc5b72354c9d14a266e8f (diff)
parent2d1cbe3cb392fe76948b7bbe61cee257a3fa2066 (diff)
downloadraylib-cb3bdf09c64f7c6d77c5728814aa144b225b77ec.tar.gz
raylib-cb3bdf09c64f7c6d77c5728814aa144b225b77ec.zip
Merge branch 'master' of https://github.com/raysan5/raylib
-rw-r--r--.gitignore16
-rw-r--r--src/CMakeLists.txt9
-rw-r--r--src/models.c16
3 files changed, 24 insertions, 17 deletions
diff --git a/.gitignore b/.gitignore
index 4459c9e5..2a23619e 100644
--- a/.gitignore
+++ b/.gitignore
@@ -34,13 +34,10 @@ Thumbs.db
[Bb]in
[Dd]ebug/
-[Dd]ebug.win32/
-[Dd]ebug.DLL/
*.sbr
*.sdf
obj/
[R]elease/
-[Rr]elease.win32/
_ReSharper*/
[Tt]est[Rr]esult*
ipch/
@@ -62,7 +59,6 @@ examples/*
!examples/*/
# Unignore all examples files with extension
!examples/*.c
-!examples/*.lua
!examples/*.png
# Unignore examples Makefile
!examples/Makefile
@@ -70,17 +66,6 @@ examples/*
!examples/raylib_compile_execute.bat
!examples/raylib_makefile_example.bat
-# Ignore all games files
-games/*
-# Unignore all games dirs
-!games/*/
-# Unignore all games files with extension
-!games/*.c
-!games/*.png
-# Unignore games makefile
-!games/Makefile
-!games/Makefile.Android
-
# Ignore files build by xcode
*.mode*v*
*.pbxuser
@@ -112,7 +97,6 @@ build
# Unignore These makefiles...
!examples/CMakeLists.txt
-!games/CMakeLists.txt
# Ignore GNU global tags
GPATH
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index aba877e7..74170e61 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -117,6 +117,15 @@ elseif(${PLATFORM} MATCHES "Raspberry Pi")
set(PLATFORM_CPP "PLATFORM_RPI")
set(GRAPHICS "GRAPHICS_API_OPENGL_ES2")
+ add_definitions(-D_DEFAULT_SOURCE)
+
+ find_library(GLESV2 brcmGLESv2 HINTS /opt/vc/lib)
+ find_library(EGL brcmEGL HINTS /opt/vc/lib)
+ find_library(BCMHOST bcm_host HINTS /opt/vc/lib)
+ include_directories(/opt/vc/include /opt/vc/include/interface/vmcs_host/linux /opt/vc/include/interface/vcos/pthreads)
+ link_directories(/opt/vc/lib)
+ set(LIBS_PRIVATE ${GLESV2} ${EGL} ${BCMHOST} pthread rt m dl)
+
endif()
if (${OPENGL_VERSION})
diff --git a/src/models.c b/src/models.c
index 00d3b516..482c647b 100644
--- a/src/models.c
+++ b/src/models.c
@@ -3050,6 +3050,7 @@ static Model LoadIQM(const char *fileName)
#define BONE_NAME_LENGTH 32 // BoneInfo name string length
#define MESH_NAME_LENGTH 32 // Mesh name string length
+ #define MATERIAL_NAME_LENGTH 32 // Material name string length
// IQM file structs
//-----------------------------------------------------------------------------------
@@ -3182,12 +3183,25 @@ static Model LoadIQM(const char *fileName)
model.meshCount = iqm.num_meshes;
model.meshes = RL_CALLOC(model.meshCount, sizeof(Mesh));
+ model.materialCount = model.meshCount;
+ model.materials = (Material *)RL_CALLOC(model.materialCount, sizeof(Material));
+ model.meshMaterial = (int *)RL_CALLOC(model.meshCount, sizeof(int));
+
char name[MESH_NAME_LENGTH] = { 0 };
+ char material[MATERIAL_NAME_LENGTH] = { 0 };
for (int i = 0; i < model.meshCount; i++)
{
fseek(iqmFile, iqm.ofs_text + imesh[i].name, SEEK_SET);
- fread(name, sizeof(char)*MESH_NAME_LENGTH, 1, iqmFile); // Mesh name not used...
+ fread(name, sizeof(char)*MESH_NAME_LENGTH, 1, iqmFile);
+
+ fseek(iqmFile, iqm.ofs_text + imesh[i].material, SEEK_SET);
+ fread(material, sizeof(char)*MATERIAL_NAME_LENGTH, 1, iqmFile);
+
+ model.materials[i] = LoadMaterialDefault();
+
+ TRACELOG(LOG_DEBUG, "MODEL: [%s] mesh name (%s), material (%s)", fileName, name, material);
+
model.meshes[i].vertexCount = imesh[i].num_vertexes;
model.meshes[i].vertices = RL_CALLOC(model.meshes[i].vertexCount*3, sizeof(float)); // Default vertex positions