diff --git a/.gitignore b/.gitignore index 4459c9e53..2a23619ef 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 aba877e77..74170e61b 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 00d3b5165..482c647b3 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