diff options
| author | raysan5 <[email protected]> | 2020-05-09 12:05:08 +0200 |
|---|---|---|
| committer | raysan5 <[email protected]> | 2020-05-09 12:05:08 +0200 |
| commit | cb3bdf09c64f7c6d77c5728814aa144b225b77ec (patch) | |
| tree | af78d9e9ddb62bb4d32ded3ff7f4fde19d1776c1 | |
| parent | 959447d8ed69e63b279bc5b72354c9d14a266e8f (diff) | |
| parent | 2d1cbe3cb392fe76948b7bbe61cee257a3fa2066 (diff) | |
| download | raylib-cb3bdf09c64f7c6d77c5728814aa144b225b77ec.tar.gz raylib-cb3bdf09c64f7c6d77c5728814aa144b225b77ec.zip | |
Merge branch 'master' of https://github.com/raysan5/raylib
| -rw-r--r-- | .gitignore | 16 | ||||
| -rw-r--r-- | src/CMakeLists.txt | 9 | ||||
| -rw-r--r-- | src/models.c | 16 |
3 files changed, 24 insertions, 17 deletions
@@ -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 |
