mirror of
https://github.com/minetest/irrlicht.git
synced 2025-07-04 17:20:25 +02:00
Compare commits
2 Commits
Author | SHA1 | Date | |
---|---|---|---|
275e152523 | |||
4ca90e3dfd |
78
.github/workflows/build.yml
vendored
78
.github/workflows/build.yml
vendored
@ -8,23 +8,22 @@ on:
|
|||||||
jobs:
|
jobs:
|
||||||
|
|
||||||
linux-gl:
|
linux-gl:
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-latest
|
||||||
|
container:
|
||||||
|
image: ubuntu:bionic
|
||||||
|
env: { LANG: "C.UTF-8" }
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- name: Install deps
|
- name: Install deps
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update
|
apt-get update
|
||||||
sudo apt-get install g++ cmake libxi-dev libgl1-mesa-dev libpng-dev libjpeg-dev zlib1g-dev -qyy
|
apt-get install g++ cmake libxi-dev libgl1-mesa-dev libpng-dev libjpeg-dev zlib1g-dev -qyy
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
cmake . -DUSE_SDL2=OFF
|
cmake .
|
||||||
make VERBOSE=1 -j2
|
make VERBOSE=1 -j2
|
||||||
|
|
||||||
- name: Test
|
|
||||||
run: |
|
|
||||||
ctest --output-on-failure
|
|
||||||
|
|
||||||
- name: Package
|
- name: Package
|
||||||
run: |
|
run: |
|
||||||
make DESTDIR=$PWD/_install install
|
make DESTDIR=$PWD/_install install
|
||||||
@ -36,18 +35,20 @@ jobs:
|
|||||||
path: ./irrlicht-linux.tar.gz
|
path: ./irrlicht-linux.tar.gz
|
||||||
|
|
||||||
linux-gles:
|
linux-gles:
|
||||||
# Xvfb test is broken on 20.04 for unknown reasons (not our bug)
|
runs-on: ubuntu-latest
|
||||||
runs-on: ubuntu-22.04
|
container:
|
||||||
|
image: ubuntu:bionic
|
||||||
|
env: { LANG: "C.UTF-8" }
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- name: Install deps
|
- name: Install deps
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update
|
apt-get update
|
||||||
sudo apt-get install g++ cmake libxi-dev libgles2-mesa-dev libpng-dev libjpeg-dev zlib1g-dev xvfb -qyy
|
apt-get install g++ cmake libxi-dev libgles2-mesa-dev libpng-dev libjpeg-dev zlib1g-dev xvfb -qyy
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
cmake . -DBUILD_EXAMPLES=1 -DUSE_SDL2=OFF -DENABLE_OPENGL=OFF -DENABLE_GLES2=ON
|
cmake . -DBUILD_EXAMPLES=1 -DENABLE_OPENGL=OFF -DENABLE_GLES2=ON
|
||||||
make -j2
|
make -j2
|
||||||
|
|
||||||
- name: Test (headless)
|
- name: Test (headless)
|
||||||
@ -61,13 +62,16 @@ jobs:
|
|||||||
LIBGL_ALWAYS_SOFTWARE=true xvfb-run ./AutomatedTest ogles2
|
LIBGL_ALWAYS_SOFTWARE=true xvfb-run ./AutomatedTest ogles2
|
||||||
|
|
||||||
linux-sdl:
|
linux-sdl:
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-latest
|
||||||
|
container:
|
||||||
|
image: ubuntu:jammy
|
||||||
|
env: { LANG: "C.UTF-8" }
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- name: Install deps
|
- name: Install deps
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update
|
apt-get update
|
||||||
sudo apt-get install g++ cmake libsdl2-dev libpng-dev libjpeg-dev zlib1g-dev -qyy
|
apt-get install g++ cmake libsdl2-dev libpng-dev libjpeg-dev zlib1g-dev -qyy
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
@ -80,14 +84,16 @@ jobs:
|
|||||||
./AutomatedTest null
|
./AutomatedTest null
|
||||||
|
|
||||||
linux-sdl-gl3:
|
linux-sdl-gl3:
|
||||||
# Xvfb test is broken on 20.04 for unknown reasons (not our bug)
|
runs-on: ubuntu-latest
|
||||||
runs-on: ubuntu-22.04
|
container:
|
||||||
|
image: ubuntu:jammy
|
||||||
|
env: { LANG: "C.UTF-8" }
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- name: Install deps
|
- name: Install deps
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update
|
apt-get update
|
||||||
sudo apt-get install g++ cmake libsdl2-dev libpng-dev libjpeg-dev zlib1g-dev xvfb -qyy
|
apt-get install g++ cmake libsdl2-dev libpng-dev libjpeg-dev zlib1g-dev xvfb -qyy
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
@ -105,13 +111,16 @@ jobs:
|
|||||||
LIBGL_ALWAYS_SOFTWARE=true xvfb-run ./AutomatedTest opengl3
|
LIBGL_ALWAYS_SOFTWARE=true xvfb-run ./AutomatedTest opengl3
|
||||||
|
|
||||||
linux-sdl-gles2:
|
linux-sdl-gles2:
|
||||||
runs-on: ubuntu-20.04
|
runs-on: ubuntu-latest
|
||||||
|
container:
|
||||||
|
image: ubuntu:jammy
|
||||||
|
env: { LANG: "C.UTF-8" }
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- name: Install deps
|
- name: Install deps
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update
|
apt-get update
|
||||||
sudo apt-get install g++ cmake libsdl2-dev libpng-dev libjpeg-dev zlib1g-dev xvfb -qyy
|
apt-get install g++ cmake libsdl2-dev libpng-dev libjpeg-dev zlib1g-dev xvfb -qyy
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
@ -130,7 +139,7 @@ jobs:
|
|||||||
|
|
||||||
mingw:
|
mingw:
|
||||||
name: "MinGW ${{matrix.config.variant}}${{matrix.config.extras}}"
|
name: "MinGW ${{matrix.config.variant}}${{matrix.config.extras}}"
|
||||||
runs-on: ubuntu-22.04
|
runs-on: ubuntu-20.04
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
@ -144,7 +153,8 @@ jobs:
|
|||||||
- name: Install compiler
|
- name: Install compiler
|
||||||
run: |
|
run: |
|
||||||
sudo apt-get update && sudo apt-get install cmake -qyy
|
sudo apt-get update && sudo apt-get install cmake -qyy
|
||||||
./scripts/ci-get-mingw.sh ${{matrix.config.arch}}
|
wget http://minetest.kitsunemimi.pw/mingw-w64-${{matrix.config.arch}}_11.2.0_ubuntu20.04.tar.xz -O mingw.tar.xz
|
||||||
|
sudo tar -xaf mingw.tar.xz -C /usr
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
@ -177,26 +187,12 @@ jobs:
|
|||||||
run: |
|
run: |
|
||||||
./bin/OSX/AutomatedTest null
|
./bin/OSX/AutomatedTest null
|
||||||
|
|
||||||
macos-sdl:
|
|
||||||
runs-on: macos-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v3
|
|
||||||
- name: Install deps
|
|
||||||
run: |
|
|
||||||
brew update
|
|
||||||
brew install cmake libpng jpeg sdl2
|
|
||||||
|
|
||||||
- name: Build
|
|
||||||
run: |
|
|
||||||
cmake . -DCMAKE_FIND_FRAMEWORK=LAST -DBUILD_EXAMPLES=1 -DUSE_SDL2=1
|
|
||||||
make -j3
|
|
||||||
|
|
||||||
msvc:
|
msvc:
|
||||||
name: VS 2019 ${{ matrix.config.arch }} ${{ matrix.sdl.label }}
|
name: VS 2019 ${{ matrix.config.arch }} ${{ matrix.sdl.label }}
|
||||||
runs-on: windows-2019
|
runs-on: windows-2019
|
||||||
env:
|
env:
|
||||||
VCPKG_VERSION: 8eb57355a4ffb410a2e94c07b4dca2dffbee8e50
|
VCPKG_VERSION: 14e7bb4ae24616ec54ff6b2f6ef4e8659434ea44
|
||||||
# 2023.10.19
|
# 2022.05.10
|
||||||
vcpkg_packages: zlib libpng libjpeg-turbo opengl-registry
|
vcpkg_packages: zlib libpng libjpeg-turbo opengl-registry
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
|
1
.gitignore
vendored
1
.gitignore
vendored
@ -5,7 +5,6 @@ install_manifest.txt
|
|||||||
IrrlichtMtConfig.cmake
|
IrrlichtMtConfig.cmake
|
||||||
IrrlichtMtConfigVersion.cmake
|
IrrlichtMtConfigVersion.cmake
|
||||||
IrrlichtMtTargets.cmake
|
IrrlichtMtTargets.cmake
|
||||||
CTestTestfile.cmake
|
|
||||||
Makefile
|
Makefile
|
||||||
libs/*
|
libs/*
|
||||||
*.so*
|
*.so*
|
||||||
|
@ -1,6 +1,13 @@
|
|||||||
cmake_minimum_required(VERSION 3.12)
|
cmake_minimum_required(VERSION 3.5)
|
||||||
|
|
||||||
set(IRRLICHTMT_REVISION 14)
|
# >=3.9 enables IPO; >=3.11 prefers GLVND
|
||||||
|
if(${CMAKE_VERSION} VERSION_LESS 3.11)
|
||||||
|
cmake_policy(VERSION ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION})
|
||||||
|
else()
|
||||||
|
cmake_policy(VERSION 3.11)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set(IRRLICHTMT_REVISION 12)
|
||||||
|
|
||||||
project(Irrlicht
|
project(Irrlicht
|
||||||
VERSION 1.9.0.${IRRLICHTMT_REVISION}
|
VERSION 1.9.0.${IRRLICHTMT_REVISION}
|
||||||
@ -9,9 +16,6 @@ project(Irrlicht
|
|||||||
|
|
||||||
message(STATUS "*** Building IrrlichtMt ${PROJECT_VERSION} ***")
|
message(STATUS "*** Building IrrlichtMt ${PROJECT_VERSION} ***")
|
||||||
|
|
||||||
set(CMAKE_CXX_STANDARD 17)
|
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
|
||||||
|
|
||||||
include(GNUInstallDirs)
|
include(GNUInstallDirs)
|
||||||
|
|
||||||
if(ANDROID)
|
if(ANDROID)
|
||||||
@ -34,9 +38,7 @@ if(NOT CMAKE_BUILD_TYPE)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
|
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake")
|
||||||
enable_testing()
|
|
||||||
add_subdirectory(source/Irrlicht)
|
add_subdirectory(source/Irrlicht)
|
||||||
add_subdirectory(test)
|
|
||||||
|
|
||||||
option(BUILD_EXAMPLES "Build example applications" FALSE)
|
option(BUILD_EXAMPLES "Build example applications" FALSE)
|
||||||
if(BUILD_EXAMPLES)
|
if(BUILD_EXAMPLES)
|
||||||
|
26
LICENSE
26
LICENSE
@ -1,26 +0,0 @@
|
|||||||
Copyright (C) 2002-2012 Nikolaus Gebhardt
|
|
||||||
|
|
||||||
This software is provided 'as-is', without any express or implied
|
|
||||||
warranty. In no event will the authors be held liable for any damages
|
|
||||||
arising from the use of this software.
|
|
||||||
|
|
||||||
Permission is granted to anyone to use this software for any purpose,
|
|
||||||
including commercial applications, and to alter it and redistribute it
|
|
||||||
freely, subject to the following restrictions:
|
|
||||||
|
|
||||||
1. The origin of this software must not be misrepresented; you must not
|
|
||||||
claim that you wrote the original software. If you use this software
|
|
||||||
in a product, an acknowledgment in the product documentation would be
|
|
||||||
appreciated but is not required.
|
|
||||||
2. Altered source versions must be plainly marked as such, and must not be
|
|
||||||
misrepresented as being the original software.
|
|
||||||
3. This notice may not be removed or altered from any source distribution.
|
|
||||||
|
|
||||||
Please note that the Irrlicht Engine is based in part on the work of the
|
|
||||||
Independent JPEG Group, the zlib, libPng and aesGladman. This means that if you use
|
|
||||||
the Irrlicht Engine in your product, you must acknowledge somewhere in your
|
|
||||||
documentation that you've used the IJPG code. It would also be nice to mention
|
|
||||||
that you use the Irrlicht Engine, the zlib, libPng and aesGladman. See the
|
|
||||||
corresponding license files for further informations. It is also possible to disable
|
|
||||||
usage of those additional libraries by defines in the IrrCompileConfig.h header and
|
|
||||||
recompiling the engine.
|
|
@ -1,8 +1,9 @@
|
|||||||
IrrlichtMt version 1.9
|
IrrlichtMt version 1.9
|
||||||
======================
|
======================
|
||||||
|
|
||||||
IrrlichtMt is the 3D engine of [Minetest](https://github.com/minetest).
|
The Irrlicht Engine is an open source realtime 3D engine written in C++.
|
||||||
It is based on the [Irrlicht Engine](https://irrlicht.sourceforge.io/) but is now developed independently.
|
|
||||||
|
This is a fork by the [Minetest](https://github.com/minetest) developers that was stripped-down and customized specifically for use in Minetest.
|
||||||
It is intentionally not compatible to upstream and is planned to be eventually absorbed into Minetest.
|
It is intentionally not compatible to upstream and is planned to be eventually absorbed into Minetest.
|
||||||
|
|
||||||
Build
|
Build
|
||||||
|
4
bin/Linux/readme.txt
Normal file
4
bin/Linux/readme.txt
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
If you wish to compile the engine in linux yourself,
|
||||||
|
goto the \source directory. Run a 'make' in the subfolder 'Irrlicht'.
|
||||||
|
After this, you should be able to make all example applications in \examples.
|
||||||
|
Then just start an X Server and run them, from the directory where they are.
|
1
bin/OSX/readme.txt
Normal file
1
bin/OSX/readme.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
If you want to compile only the Irrlicht Engine you should use XCode project available at source/Irrlicht/ directory. You can also use examples/BuildAllExamples.xcworkspace file to build the Irrlicht Engine + all examples.
|
BIN
bin/Win32-VisualStudio/irrlicht.ico
Normal file
BIN
bin/Win32-VisualStudio/irrlicht.ico
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.2 KiB |
25
bin/Win32-VisualStudio/readme.txt
Normal file
25
bin/Win32-VisualStudio/readme.txt
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
The Win32-VisualStudio version is currently (Irrlicht 1.8) compiled with VS 2010 using the Windows 7.1 SDK as platform toolset.
|
||||||
|
You might get the necessary Windows Platform SDK here: http://msdn.microsoft.com/en-us/windows/bb980924.aspx
|
||||||
|
|
||||||
|
To link to that Irrlicht.dll you need to set platform toolset in your VS version to the same target or re-compile the Irrlicht.dll using another platform toolset.
|
||||||
|
|
||||||
|
To re-compile Irrlicht for Win32-VisualStudio:
|
||||||
|
There are several project files for different VS versions in source/Irrlicht.
|
||||||
|
Irrlicht10.0.sln is for VS 2010
|
||||||
|
Irrlicht11.0.sln is for VS 2012
|
||||||
|
Irrlicht12.0.sln is for VS 2013
|
||||||
|
|
||||||
|
To compile Irrlicht + all examples and all tools check the BuildAllExamples_*.sln files in the examples folder.
|
||||||
|
|
||||||
|
For newer VS versions you have update one of those projects (VS usually can do that automatically when you open an older solution file).
|
||||||
|
|
||||||
|
Currently each of those solutions does set the platform toolset "Windows 7.1 SDK" (to be compatible to each other).
|
||||||
|
You might want to change that in the project settings and set it to your current version.
|
||||||
|
Make sure you use the same platform toolset in your application and in the engine.
|
||||||
|
Also when compiling examples each example has to use the same platform toolset as was used for the engine.
|
||||||
|
|
||||||
|
Platform should be Win32
|
||||||
|
Configuration is by default "Release"
|
||||||
|
But you can also chose "Debug" if you want Irrlicht with Debug information.
|
||||||
|
Static builds are possible but you have to additionally set the _IRR_STATIC_LIB_ define in the application when linking to a static Irrlicht.lib
|
||||||
|
|
BIN
bin/Win32-gcc/irrlicht.ico
Normal file
BIN
bin/Win32-gcc/irrlicht.ico
Normal file
Binary file not shown.
After Width: | Height: | Size: 2.2 KiB |
16
bin/Win32-gcc/readme.txt
Normal file
16
bin/Win32-gcc/readme.txt
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
If you wish to compile Irrlicht for Win32-gcc you have several choices.
|
||||||
|
|
||||||
|
1. You can work from within a MinGW shell.
|
||||||
|
Go to the folder source/Irrlicht and run the Makefile with:
|
||||||
|
make win32
|
||||||
|
Examples can be build by going into the folder of the example (for example examples/01.HelloWorld) and running the Makefile with:
|
||||||
|
make all_win32
|
||||||
|
|
||||||
|
2. Use the Code::Blocks IDE
|
||||||
|
There is a project file called Irrlicht-gcc.cbp in source/Irrlicht to compile just the engine.
|
||||||
|
Be sure to select a Windows target like "Win32 - release - accurate math - dll"
|
||||||
|
|
||||||
|
There is also Code::Blocks workspace file in the examples folder called BuildAllExamples.workspace
|
||||||
|
Again be sure to select a Windows target like "Win32 - release - accurate math - dll"
|
||||||
|
This workspace allows you to compile the engine together with all examples and tools.
|
||||||
|
|
1
bin/emscripten/readme.txt
Normal file
1
bin/emscripten/readme.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
If you wish to compile Irrlicht for emscripten please check the documenation in examples/01.HelloWorld_emscripten.
|
27
build.sh
Executable file
27
build.sh
Executable file
@ -0,0 +1,27 @@
|
|||||||
|
#!/bin/bash -e
|
||||||
|
args=(-DBUILD_EXAMPLES=ON -DENABLE_OPENGL=OFF -DBUILD_SHARED_LIBS=OFF)
|
||||||
|
|
||||||
|
export CC=afl-clang-fast
|
||||||
|
export CXX=afl-clang-fast++
|
||||||
|
export LD=$CXX
|
||||||
|
unset AFL_USE_ASAN
|
||||||
|
if ! grep -Fq '/afl-' build2/CMakeCache.txt; then
|
||||||
|
rm -rf build2
|
||||||
|
cmake -S . -B build2 "${args[@]}"
|
||||||
|
fi
|
||||||
|
nice make -C build2 clean
|
||||||
|
nice make -C build2 -j10
|
||||||
|
for f in build2/bin/Linux/*; do
|
||||||
|
ln -snfv "../../$f" "bin/Linux/${f##*/}_noasan"
|
||||||
|
done
|
||||||
|
|
||||||
|
export CC=afl-clang-lto
|
||||||
|
export CXX=afl-clang-lto++
|
||||||
|
export LD=$CXX
|
||||||
|
export AFL_USE_ASAN=1
|
||||||
|
if ! grep -Fq '/afl-' CMakeCache.txt; then
|
||||||
|
rm -f CMakeCache.txt
|
||||||
|
cmake . "${args[@]}"
|
||||||
|
fi
|
||||||
|
nice make clean
|
||||||
|
nice make -j10
|
26
doc/irrlicht-license.txt
Normal file
26
doc/irrlicht-license.txt
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
Copyright (C) 2002-2012 Nikolaus Gebhardt
|
||||||
|
|
||||||
|
This software is provided 'as-is', without any express or implied
|
||||||
|
warranty. In no event will the authors be held liable for any damages
|
||||||
|
arising from the use of this software.
|
||||||
|
|
||||||
|
Permission is granted to anyone to use this software for any purpose,
|
||||||
|
including commercial applications, and to alter it and redistribute it
|
||||||
|
freely, subject to the following restrictions:
|
||||||
|
|
||||||
|
1. The origin of this software must not be misrepresented; you must not
|
||||||
|
claim that you wrote the original software. If you use this software
|
||||||
|
in a product, an acknowledgment in the product documentation would be
|
||||||
|
appreciated but is not required.
|
||||||
|
2. Altered source versions must be plainly marked as such, and must not be
|
||||||
|
misrepresented as being the original software.
|
||||||
|
3. This notice may not be removed or altered from any source distribution.
|
||||||
|
|
||||||
|
Please note that the Irrlicht Engine is based in part on the work of the
|
||||||
|
Independent JPEG Group, the zlib, libPng and aesGladman. This means that if you use
|
||||||
|
the Irrlicht Engine in your product, you must acknowledge somewhere in your
|
||||||
|
documentation that you've used the IJPG code. It would also be nice to mention
|
||||||
|
that you use the Irrlicht Engine, the zlib, libPng and aesGladman. See the
|
||||||
|
corresponding license files for further informations. It is also possible to disable
|
||||||
|
usage of those additional libraries by defines in the IrrCompileConfig.h header and
|
||||||
|
recompiling the engine.
|
63
doc/release_checklist.txt
Normal file
63
doc/release_checklist.txt
Normal file
@ -0,0 +1,63 @@
|
|||||||
|
Checklist for Irrlicht developers doing releases.
|
||||||
|
|
||||||
|
Note: Generally the more platforms, compilers, settings you can test the better. Ask for help for platforms which you don't own.
|
||||||
|
|
||||||
|
- PRE-BUILD TESTS:
|
||||||
|
- - Run tests in the tests folder
|
||||||
|
- - Compile and run examples.
|
||||||
|
- - Compile and run the tools. Note that some tools are in the buildall-examples VS project files on Windows,
|
||||||
|
but on Linux command line you have to compile them individually.
|
||||||
|
|
||||||
|
- VERSION UPDATES:
|
||||||
|
- - check IRRLICHT_SDK_VERSION (in IrrCompileConfig.h)
|
||||||
|
- - check version number in the Makefile
|
||||||
|
- - update readme.txt (version number, supported compilers)
|
||||||
|
- - Add new release information (date+version-number) in changes.txt
|
||||||
|
- - go through folders if other .txt files still make sense (things change and updating those files tends to be forgotten)
|
||||||
|
|
||||||
|
- DOCUMENTATION UPDATES:
|
||||||
|
- - run makedocumentation.sh in scripts\doc\irrlicht
|
||||||
|
- - run maketutorial.sh in scripts\doc\irrlicht (commit changed tutorial.html's)
|
||||||
|
|
||||||
|
- BUILDING THE RELEASE
|
||||||
|
(TBD - should we still release dll's? Newer and older VS builds are no longer compatible anyway)
|
||||||
|
- - run a clean build for buildAllExamples in the examples folder with the
|
||||||
|
target compiler for 32-bit and for release (old VS compiler - so far VS2010)
|
||||||
|
- - when possible compile the dll for MinGW on Windows (in release and with -s for smaller size)
|
||||||
|
- - when possible compile the dll for 64 bit (again with Visual Studio and release)
|
||||||
|
- - create a target directory, like irrlicht-1.8.1 for example
|
||||||
|
- - svn export to the target directory
|
||||||
|
- - copy the subfolders of doctemp into the doc folder of the target directory
|
||||||
|
careful, this should only be one(!) subfolder (we ended up with copies before, maybe Windows/Linux builds use different names?)
|
||||||
|
- - copy all .exe files (except test.exe) from bin\Win32-VisualStudio (.pdb's are not necessary)
|
||||||
|
- - copy Irrlicht.dll from bin\Win32-visualstudio
|
||||||
|
- - copy the files in lib\Win32-visualstudio
|
||||||
|
- - copy Irrlicht.dll from bin\Win64-VisualStudio
|
||||||
|
- - copy the files in lib\Win64-visualstudio
|
||||||
|
- - copy Irrlicht.dll from bin\Win32-gcc
|
||||||
|
- - copy the files in lib\Win32-gcc
|
||||||
|
- - remove the tests folder
|
||||||
|
- - remove scripts folder (if the release comes with docs, if you do a release
|
||||||
|
without docs for smaller filesizes then the script folder has to stay in).
|
||||||
|
- - create a zip file
|
||||||
|
- - figure out how to fix unix access right for shell-scripts in the zip file (my
|
||||||
|
trick so far is: unzip in Linux, set +x for all .sh files, zip again)
|
||||||
|
|
||||||
|
RELEASING:
|
||||||
|
- - upload the zip-file somewhere, then download it again on all platforms and do
|
||||||
|
another quick test with that file (do examples still run, can you compile)
|
||||||
|
- - give the link to the zip out on the mailinglist for others to look at
|
||||||
|
- - Upload new documentation (the content of doc/html) to: web.sourceforge.net
|
||||||
|
(sftp protocol, user and passwd are your sourceforge account, the folder
|
||||||
|
might not be shown - but you can still cd into it!):
|
||||||
|
/home/project-web/i/ir/irrlicht/htdocs
|
||||||
|
Best create first a folder with a new name, copy stuff in there, test (just
|
||||||
|
check the website), rename old folder and give new folder the "docu" name.
|
||||||
|
Then you can delete the old folder if you want.
|
||||||
|
- - upload the zip by logging in to sourceforge and using the "Files" menu (needs
|
||||||
|
admin privileges and it's the 'Files' menu between 'Summary' and 'Reviews').
|
||||||
|
The target is in one of the Irrlicht SDK subfolders. Then click the "i" beside
|
||||||
|
the file and "select all" to make it the active download.
|
||||||
|
- - write a forum post, tell everyone in facebook, reddit, your friends...
|
||||||
|
- - login to wordpress at http://irrlicht.sourceforge.net/wp-login.php, update the
|
||||||
|
downloads section and write a release post.
|
2891
doc/upgrade-guide.txt
Normal file
2891
doc/upgrade-guide.txt
Normal file
File diff suppressed because it is too large
Load Diff
@ -168,32 +168,22 @@ static void test_methods()
|
|||||||
|
|
||||||
static void test_conv()
|
static void test_conv()
|
||||||
{
|
{
|
||||||
// locale-independent
|
// assumes Unicode and UTF-8 locale
|
||||||
|
setlocale(LC_CTYPE, "");
|
||||||
|
|
||||||
stringw out;
|
stringw out;
|
||||||
utf8ToWString(out, "†††");
|
multibyteToWString(out, "†††");
|
||||||
UASSERTEQ(out.size(), 3);
|
UASSERTEQ(out.size(), 3);
|
||||||
for (int i = 0; i < 3; i++)
|
for (int i = 0; i < 3; i++)
|
||||||
UASSERTEQ(static_cast<u16>(out[i]), 0x2020);
|
UASSERTEQ(static_cast<u16>(out[i]), 0x2020);
|
||||||
|
|
||||||
stringc out2;
|
stringc out2;
|
||||||
wStringToUTF8(out2, L"†††");
|
wStringToMultibyte(out2, L"†††");
|
||||||
UASSERTEQ(out2.size(), 9);
|
UASSERTEQ(out2.size(), 9);
|
||||||
for (int i = 0; i < 3; i++) {
|
for (int i = 0; i < 3; i++) {
|
||||||
UASSERTEQ(static_cast<u8>(out2[3*i]), 0xe2);
|
UASSERTEQ(static_cast<u8>(out2[3*i]), 0xe2);
|
||||||
UASSERTEQ(static_cast<u8>(out2[3*i+1]), 0x80);
|
UASSERTEQ(static_cast<u8>(out2[3*i+1]), 0x80);
|
||||||
UASSERTEQ(static_cast<u8>(out2[3*i+2]), 0xa0);
|
UASSERTEQ(static_cast<u8>(out2[3*i+2]), 0xa0);
|
||||||
}
|
}
|
||||||
|
|
||||||
// locale-dependent
|
|
||||||
if (!setlocale(LC_CTYPE, "C.UTF-8"))
|
|
||||||
setlocale(LC_CTYPE, "UTF-8"); // macOS
|
|
||||||
|
|
||||||
stringw out3;
|
|
||||||
multibyteToWString(out3, "†††");
|
|
||||||
UASSERTEQ(out3.size(), 3);
|
|
||||||
for (int i = 0; i < 3; i++)
|
|
||||||
UASSERTEQ(static_cast<u16>(out3[i]), 0x2020);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_irr_string()
|
void test_irr_string()
|
||||||
|
@ -1,7 +1,11 @@
|
|||||||
|
set(CMAKE_CXX_STANDARD 17)
|
||||||
|
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
||||||
|
|
||||||
set(IRREXAMPLES
|
set(IRREXAMPLES
|
||||||
# removed
|
LoadTexture
|
||||||
|
LoadMesh
|
||||||
)
|
)
|
||||||
if(UNIX)
|
if(FALSE)
|
||||||
list(APPEND IRREXAMPLES AutomatedTest)
|
list(APPEND IRREXAMPLES AutomatedTest)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
44
examples/LoadMesh/main.cpp
Normal file
44
examples/LoadMesh/main.cpp
Normal file
@ -0,0 +1,44 @@
|
|||||||
|
#include <irrlicht.h>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
using namespace irr;
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
if (argc < 2)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
SIrrlichtCreationParameters p;
|
||||||
|
p.DriverType = video::EDT_NULL;
|
||||||
|
p.WindowSize = core::dimension2du(640, 480);
|
||||||
|
p.LoggingLevel = ELL_DEBUG;
|
||||||
|
|
||||||
|
auto *device = createDeviceEx(p);
|
||||||
|
if (!device)
|
||||||
|
return 1;
|
||||||
|
auto *smgr = device->getSceneManager();
|
||||||
|
|
||||||
|
while (__AFL_LOOP(10000)) {
|
||||||
|
auto *mfile = device->getFileSystem()->createAndOpenFile(argv[1]);
|
||||||
|
if (!mfile)
|
||||||
|
continue;
|
||||||
|
scene::IAnimatedMesh *mesh;
|
||||||
|
// Irrlicht matches on file extension so we have to do this by hand
|
||||||
|
for (u32 i = 0; i < smgr->getMeshLoaderCount(); i++) {
|
||||||
|
mfile->seek(0);
|
||||||
|
mesh = smgr->getMeshLoader(i)->createMesh(mfile);
|
||||||
|
if (mesh) {
|
||||||
|
core::stringc msg("Loaded using loader #");
|
||||||
|
msg += core::stringc(i);
|
||||||
|
device->getLogger()->log(msg.c_str(), ELL_DEBUG);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (mesh)
|
||||||
|
mesh->drop();
|
||||||
|
mfile->drop();
|
||||||
|
}
|
||||||
|
|
||||||
|
device->drop();
|
||||||
|
return 0;
|
||||||
|
}
|
29
examples/LoadTexture/main.cpp
Normal file
29
examples/LoadTexture/main.cpp
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
#include <irrlicht.h>
|
||||||
|
#include <iostream>
|
||||||
|
|
||||||
|
using namespace irr;
|
||||||
|
|
||||||
|
int main(int argc, char *argv[])
|
||||||
|
{
|
||||||
|
if (argc < 2)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
SIrrlichtCreationParameters p;
|
||||||
|
p.DriverType = video::EDT_NULL;
|
||||||
|
p.WindowSize = core::dimension2du(640, 480);
|
||||||
|
p.LoggingLevel = ELL_DEBUG;
|
||||||
|
|
||||||
|
auto *device = createDeviceEx(p);
|
||||||
|
if (!device)
|
||||||
|
return 1;
|
||||||
|
auto *driver = device->getVideoDriver();
|
||||||
|
|
||||||
|
while (__AFL_LOOP(10000)) {
|
||||||
|
auto *tex = driver->getTexture(argv[1]);
|
||||||
|
if (tex)
|
||||||
|
driver->removeTexture(tex);
|
||||||
|
}
|
||||||
|
|
||||||
|
device->drop();
|
||||||
|
return 0;
|
||||||
|
}
|
226
include/CIndexBuffer.h
Normal file
226
include/CIndexBuffer.h
Normal file
@ -0,0 +1,226 @@
|
|||||||
|
// Copyright (C) 2008-2012 Nikolaus Gebhardt
|
||||||
|
// This file is part of the "Irrlicht Engine".
|
||||||
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
|
#ifndef __C_INDEX_BUFFER_H_INCLUDED__
|
||||||
|
#define __C_INDEX_BUFFER_H_INCLUDED__
|
||||||
|
|
||||||
|
#include "IIndexBuffer.h"
|
||||||
|
|
||||||
|
namespace irr
|
||||||
|
{
|
||||||
|
namespace scene
|
||||||
|
{
|
||||||
|
|
||||||
|
class CIndexBuffer : public IIndexBuffer
|
||||||
|
{
|
||||||
|
|
||||||
|
class IIndexList
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual ~IIndexList(){};
|
||||||
|
|
||||||
|
virtual u32 stride() const =0;
|
||||||
|
virtual u32 size() const =0;
|
||||||
|
virtual void push_back(const u32 &element) =0;
|
||||||
|
virtual u32 operator [](u32 index) const =0;
|
||||||
|
virtual u32 getLast() =0;
|
||||||
|
virtual void setValue(u32 index, u32 value) =0;
|
||||||
|
virtual void set_used(u32 usedNow) =0;
|
||||||
|
virtual void reallocate(u32 new_size) =0;
|
||||||
|
virtual u32 allocated_size() const =0;
|
||||||
|
virtual void* pointer() =0;
|
||||||
|
virtual video::E_INDEX_TYPE getType() const =0;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
class CSpecificIndexList : public IIndexList
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
core::array<T> Indices;
|
||||||
|
|
||||||
|
u32 stride() const override {return sizeof(T);}
|
||||||
|
|
||||||
|
u32 size() const override {return Indices.size();}
|
||||||
|
|
||||||
|
void push_back(const u32 &element) override
|
||||||
|
{
|
||||||
|
// push const ref due to compiler problem with gcc 4.6, big endian
|
||||||
|
Indices.push_back((const T&)element);
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 operator [](u32 index) const override
|
||||||
|
{
|
||||||
|
return (u32)(Indices[index]);
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 getLast() override {return (u32)Indices.getLast();}
|
||||||
|
|
||||||
|
void setValue(u32 index, u32 value) override
|
||||||
|
{
|
||||||
|
Indices[index]=(T)value;
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_used(u32 usedNow) override
|
||||||
|
{
|
||||||
|
Indices.set_used(usedNow);
|
||||||
|
}
|
||||||
|
|
||||||
|
void reallocate(u32 new_size) override
|
||||||
|
{
|
||||||
|
Indices.reallocate(new_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 allocated_size() const override
|
||||||
|
{
|
||||||
|
return Indices.allocated_size();
|
||||||
|
}
|
||||||
|
|
||||||
|
void* pointer() override {return Indices.pointer();}
|
||||||
|
|
||||||
|
video::E_INDEX_TYPE getType() const override
|
||||||
|
{
|
||||||
|
if (sizeof(T)==sizeof(u16))
|
||||||
|
return video::EIT_16BIT;
|
||||||
|
else
|
||||||
|
return video::EIT_32BIT;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public:
|
||||||
|
IIndexList *Indices;
|
||||||
|
|
||||||
|
CIndexBuffer(video::E_INDEX_TYPE IndexType) :Indices(0), MappingHint(EHM_NEVER), ChangedID(1)
|
||||||
|
{
|
||||||
|
setType(IndexType);
|
||||||
|
}
|
||||||
|
|
||||||
|
CIndexBuffer(const IIndexBuffer &IndexBufferCopy) :Indices(0), MappingHint(EHM_NEVER), ChangedID(1)
|
||||||
|
{
|
||||||
|
setType(IndexBufferCopy.getType());
|
||||||
|
reallocate(IndexBufferCopy.size());
|
||||||
|
|
||||||
|
for (u32 n=0;n<IndexBufferCopy.size();++n)
|
||||||
|
push_back(IndexBufferCopy[n]);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~CIndexBuffer()
|
||||||
|
{
|
||||||
|
delete Indices;
|
||||||
|
}
|
||||||
|
|
||||||
|
//virtual void setType(video::E_INDEX_TYPE IndexType);
|
||||||
|
void setType(video::E_INDEX_TYPE IndexType) override
|
||||||
|
{
|
||||||
|
IIndexList *NewIndices=0;
|
||||||
|
|
||||||
|
switch (IndexType)
|
||||||
|
{
|
||||||
|
case video::EIT_16BIT:
|
||||||
|
{
|
||||||
|
NewIndices=new CSpecificIndexList<u16>;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case video::EIT_32BIT:
|
||||||
|
{
|
||||||
|
NewIndices=new CSpecificIndexList<u32>;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Indices)
|
||||||
|
{
|
||||||
|
NewIndices->reallocate( Indices->size() );
|
||||||
|
|
||||||
|
for(u32 n=0;n<Indices->size();++n)
|
||||||
|
NewIndices->push_back((*Indices)[n]);
|
||||||
|
|
||||||
|
delete Indices;
|
||||||
|
}
|
||||||
|
|
||||||
|
Indices=NewIndices;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* getData() override {return Indices->pointer();}
|
||||||
|
|
||||||
|
video::E_INDEX_TYPE getType() const override {return Indices->getType();}
|
||||||
|
|
||||||
|
u32 stride() const override {return Indices->stride();}
|
||||||
|
|
||||||
|
u32 size() const override
|
||||||
|
{
|
||||||
|
return Indices->size();
|
||||||
|
}
|
||||||
|
|
||||||
|
void push_back(const u32 &element) override
|
||||||
|
{
|
||||||
|
Indices->push_back(element);
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 operator [](u32 index) const override
|
||||||
|
{
|
||||||
|
return (*Indices)[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 getLast() override
|
||||||
|
{
|
||||||
|
return Indices->getLast();
|
||||||
|
}
|
||||||
|
|
||||||
|
void setValue(u32 index, u32 value) override
|
||||||
|
{
|
||||||
|
Indices->setValue(index, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_used(u32 usedNow) override
|
||||||
|
{
|
||||||
|
Indices->set_used(usedNow);
|
||||||
|
}
|
||||||
|
|
||||||
|
void reallocate(u32 new_size) override
|
||||||
|
{
|
||||||
|
Indices->reallocate(new_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 allocated_size() const override
|
||||||
|
{
|
||||||
|
return Indices->allocated_size();
|
||||||
|
}
|
||||||
|
|
||||||
|
void* pointer() override
|
||||||
|
{
|
||||||
|
return Indices->pointer();
|
||||||
|
}
|
||||||
|
|
||||||
|
//! get the current hardware mapping hint
|
||||||
|
E_HARDWARE_MAPPING getHardwareMappingHint() const override
|
||||||
|
{
|
||||||
|
return MappingHint;
|
||||||
|
}
|
||||||
|
|
||||||
|
//! set the hardware mapping hint, for driver
|
||||||
|
void setHardwareMappingHint( E_HARDWARE_MAPPING NewMappingHint ) override
|
||||||
|
{
|
||||||
|
MappingHint=NewMappingHint;
|
||||||
|
}
|
||||||
|
|
||||||
|
//! flags the mesh as changed, reloads hardware buffers
|
||||||
|
void setDirty() override
|
||||||
|
{
|
||||||
|
++ChangedID;
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Get the currently used ID for identification of changes.
|
||||||
|
/** This shouldn't be used for anything outside the VideoDriver. */
|
||||||
|
u32 getChangedID() const override {return ChangedID;}
|
||||||
|
|
||||||
|
E_HARDWARE_MAPPING MappingHint;
|
||||||
|
u32 ChangedID;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
} // end namespace scene
|
||||||
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
213
include/CVertexBuffer.h
Normal file
213
include/CVertexBuffer.h
Normal file
@ -0,0 +1,213 @@
|
|||||||
|
// Copyright (C) 2008-2012 Nikolaus Gebhardt
|
||||||
|
// This file is part of the "Irrlicht Engine".
|
||||||
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
|
#ifndef __C_VERTEX_BUFFER_H_INCLUDED__
|
||||||
|
#define __C_VERTEX_BUFFER_H_INCLUDED__
|
||||||
|
|
||||||
|
#include "IVertexBuffer.h"
|
||||||
|
|
||||||
|
|
||||||
|
namespace irr
|
||||||
|
{
|
||||||
|
namespace scene
|
||||||
|
{
|
||||||
|
|
||||||
|
class CVertexBuffer : public IVertexBuffer
|
||||||
|
{
|
||||||
|
class IVertexList
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
virtual ~IVertexList(){};
|
||||||
|
|
||||||
|
virtual u32 stride() const =0;
|
||||||
|
|
||||||
|
virtual u32 size() const =0;
|
||||||
|
|
||||||
|
virtual void push_back (const video::S3DVertex &element) =0;
|
||||||
|
virtual video::S3DVertex& operator [](const u32 index) const =0;
|
||||||
|
virtual video::S3DVertex& getLast() =0;
|
||||||
|
virtual void set_used(u32 usedNow) =0;
|
||||||
|
virtual void reallocate(u32 new_size) =0;
|
||||||
|
virtual u32 allocated_size() const =0;
|
||||||
|
virtual video::S3DVertex* pointer() =0;
|
||||||
|
virtual video::E_VERTEX_TYPE getType() const =0;
|
||||||
|
};
|
||||||
|
|
||||||
|
template <class T>
|
||||||
|
class CSpecificVertexList : public IVertexList
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
core::array<T> Vertices;
|
||||||
|
|
||||||
|
u32 stride() const override {return sizeof(T);}
|
||||||
|
|
||||||
|
u32 size() const override {return Vertices.size();}
|
||||||
|
|
||||||
|
void push_back (const video::S3DVertex &element) override
|
||||||
|
{Vertices.push_back((T&)element);}
|
||||||
|
|
||||||
|
video::S3DVertex& operator [](const u32 index) const override
|
||||||
|
{return (video::S3DVertex&)Vertices[index];}
|
||||||
|
|
||||||
|
video::S3DVertex& getLast() override
|
||||||
|
{return (video::S3DVertex&)Vertices.getLast();}
|
||||||
|
|
||||||
|
void set_used(u32 usedNow) override
|
||||||
|
{Vertices.set_used(usedNow);}
|
||||||
|
|
||||||
|
void reallocate(u32 new_size) override
|
||||||
|
{Vertices.reallocate(new_size);}
|
||||||
|
|
||||||
|
u32 allocated_size() const override
|
||||||
|
{
|
||||||
|
return Vertices.allocated_size();
|
||||||
|
}
|
||||||
|
|
||||||
|
video::S3DVertex* pointer() override {return Vertices.pointer();}
|
||||||
|
|
||||||
|
video::E_VERTEX_TYPE getType() const override {return T::getType();}
|
||||||
|
};
|
||||||
|
|
||||||
|
public:
|
||||||
|
IVertexList *Vertices;
|
||||||
|
|
||||||
|
CVertexBuffer(video::E_VERTEX_TYPE vertexType) : Vertices(0),
|
||||||
|
MappingHint(EHM_NEVER), ChangedID(1)
|
||||||
|
{
|
||||||
|
CVertexBuffer::setType(vertexType);
|
||||||
|
}
|
||||||
|
|
||||||
|
CVertexBuffer(const IVertexBuffer &VertexBufferCopy) :
|
||||||
|
Vertices(0), MappingHint(EHM_NEVER),
|
||||||
|
ChangedID(1)
|
||||||
|
{
|
||||||
|
CVertexBuffer::setType(VertexBufferCopy.getType());
|
||||||
|
CVertexBuffer::reallocate(VertexBufferCopy.size());
|
||||||
|
|
||||||
|
for (u32 n=0;n<VertexBufferCopy.size();++n)
|
||||||
|
CVertexBuffer::push_back(VertexBufferCopy[n]);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual ~CVertexBuffer()
|
||||||
|
{
|
||||||
|
delete Vertices;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void setType(video::E_VERTEX_TYPE vertexType) override
|
||||||
|
{
|
||||||
|
if ( Vertices && Vertices->getType() == vertexType )
|
||||||
|
return;
|
||||||
|
|
||||||
|
IVertexList *NewVertices=0;
|
||||||
|
|
||||||
|
switch (vertexType)
|
||||||
|
{
|
||||||
|
case video::EVT_STANDARD:
|
||||||
|
{
|
||||||
|
NewVertices=new CSpecificVertexList<video::S3DVertex>;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case video::EVT_2TCOORDS:
|
||||||
|
{
|
||||||
|
NewVertices=new CSpecificVertexList<video::S3DVertex2TCoords>;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case video::EVT_TANGENTS:
|
||||||
|
{
|
||||||
|
NewVertices=new CSpecificVertexList<video::S3DVertexTangents>;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (Vertices)
|
||||||
|
{
|
||||||
|
NewVertices->reallocate( Vertices->size() );
|
||||||
|
|
||||||
|
for(u32 n=0;n<Vertices->size();++n)
|
||||||
|
NewVertices->push_back((*Vertices)[n]);
|
||||||
|
|
||||||
|
delete Vertices;
|
||||||
|
}
|
||||||
|
|
||||||
|
Vertices=NewVertices;
|
||||||
|
}
|
||||||
|
|
||||||
|
void* getData() override {return Vertices->pointer();}
|
||||||
|
|
||||||
|
video::E_VERTEX_TYPE getType() const override {return Vertices->getType();}
|
||||||
|
|
||||||
|
u32 stride() const override {return Vertices->stride();}
|
||||||
|
|
||||||
|
u32 size() const override
|
||||||
|
{
|
||||||
|
return Vertices->size();
|
||||||
|
}
|
||||||
|
|
||||||
|
void push_back (const video::S3DVertex &element) override
|
||||||
|
{
|
||||||
|
Vertices->push_back(element);
|
||||||
|
}
|
||||||
|
|
||||||
|
video::S3DVertex& operator [](const u32 index) const override
|
||||||
|
{
|
||||||
|
return (*Vertices)[index];
|
||||||
|
}
|
||||||
|
|
||||||
|
video::S3DVertex& getLast() override
|
||||||
|
{
|
||||||
|
return Vertices->getLast();
|
||||||
|
}
|
||||||
|
|
||||||
|
void set_used(u32 usedNow) override
|
||||||
|
{
|
||||||
|
Vertices->set_used(usedNow);
|
||||||
|
}
|
||||||
|
|
||||||
|
void reallocate(u32 new_size) override
|
||||||
|
{
|
||||||
|
Vertices->reallocate(new_size);
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 allocated_size() const override
|
||||||
|
{
|
||||||
|
return Vertices->allocated_size();
|
||||||
|
}
|
||||||
|
|
||||||
|
video::S3DVertex* pointer() override
|
||||||
|
{
|
||||||
|
return Vertices->pointer();
|
||||||
|
}
|
||||||
|
|
||||||
|
//! get the current hardware mapping hint
|
||||||
|
E_HARDWARE_MAPPING getHardwareMappingHint() const override
|
||||||
|
{
|
||||||
|
return MappingHint;
|
||||||
|
}
|
||||||
|
|
||||||
|
//! set the hardware mapping hint, for driver
|
||||||
|
void setHardwareMappingHint( E_HARDWARE_MAPPING NewMappingHint ) override
|
||||||
|
{
|
||||||
|
MappingHint=NewMappingHint;
|
||||||
|
}
|
||||||
|
|
||||||
|
//! flags the mesh as changed, reloads hardware buffers
|
||||||
|
void setDirty() override
|
||||||
|
{
|
||||||
|
++ChangedID;
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Get the currently used ID for identification of changes.
|
||||||
|
/** This shouldn't be used for anything outside the VideoDriver. */
|
||||||
|
u32 getChangedID() const override {return ChangedID;}
|
||||||
|
|
||||||
|
E_HARDWARE_MAPPING MappingHint;
|
||||||
|
u32 ChangedID;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
} // end namespace scene
|
||||||
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -121,6 +121,21 @@ namespace video
|
|||||||
//! Support for texture coord transformation via texture matrix
|
//! Support for texture coord transformation via texture matrix
|
||||||
EVDF_TEXTURE_MATRIX,
|
EVDF_TEXTURE_MATRIX,
|
||||||
|
|
||||||
|
//! Support for DXTn compressed textures.
|
||||||
|
EVDF_TEXTURE_COMPRESSED_DXT,
|
||||||
|
|
||||||
|
//! Support for PVRTC compressed textures.
|
||||||
|
EVDF_TEXTURE_COMPRESSED_PVRTC,
|
||||||
|
|
||||||
|
//! Support for PVRTC2 compressed textures.
|
||||||
|
EVDF_TEXTURE_COMPRESSED_PVRTC2,
|
||||||
|
|
||||||
|
//! Support for ETC1 compressed textures.
|
||||||
|
EVDF_TEXTURE_COMPRESSED_ETC1,
|
||||||
|
|
||||||
|
//! Support for ETC2 compressed textures.
|
||||||
|
EVDF_TEXTURE_COMPRESSED_ETC2,
|
||||||
|
|
||||||
//! Support for cube map textures.
|
//! Support for cube map textures.
|
||||||
EVDF_TEXTURE_CUBEMAP,
|
EVDF_TEXTURE_CUBEMAP,
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_I_CONTEXT_MANAGER_H_INCLUDED__
|
||||||
|
#define __IRR_I_CONTEXT_MANAGER_H_INCLUDED__
|
||||||
|
|
||||||
#include "SExposedVideoData.h"
|
#include "SExposedVideoData.h"
|
||||||
#include "SIrrCreationParameters.h"
|
#include "SIrrCreationParameters.h"
|
||||||
@ -59,3 +60,4 @@ namespace video
|
|||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
@ -26,7 +26,7 @@ namespace gui
|
|||||||
ECI_HELP, // Arrow and question mark
|
ECI_HELP, // Arrow and question mark
|
||||||
ECI_IBEAM, // typical text-selection cursor
|
ECI_IBEAM, // typical text-selection cursor
|
||||||
ECI_NO, // should not click icon
|
ECI_NO, // should not click icon
|
||||||
ECI_WAIT, // hourglass
|
ECI_WAIT, // hourclass
|
||||||
ECI_SIZEALL, // arrow in all directions
|
ECI_SIZEALL, // arrow in all directions
|
||||||
ECI_SIZENESW, // resizes in direction north-east or south-west
|
ECI_SIZENESW, // resizes in direction north-east or south-west
|
||||||
ECI_SIZENWSE, // resizes in direction north-west or south-east
|
ECI_SIZENWSE, // resizes in direction north-west or south-east
|
||||||
|
@ -263,10 +263,6 @@ namespace irr
|
|||||||
//! A checkbox has changed its check state.
|
//! A checkbox has changed its check state.
|
||||||
EGET_CHECKBOX_CHANGED,
|
EGET_CHECKBOX_CHANGED,
|
||||||
|
|
||||||
//! A listbox would like to open.
|
|
||||||
/** You can prevent the listbox from opening by absorbing the event. */
|
|
||||||
EGET_LISTBOX_OPENED,
|
|
||||||
|
|
||||||
//! A new item in a listbox was selected.
|
//! A new item in a listbox was selected.
|
||||||
/** NOTE: You also get this event currently when the same item was clicked again after more than 500 ms. */
|
/** NOTE: You also get this event currently when the same item was clicked again after more than 500 ms. */
|
||||||
EGET_LISTBOX_CHANGED,
|
EGET_LISTBOX_CHANGED,
|
||||||
|
@ -52,10 +52,6 @@ namespace gui
|
|||||||
//! Sets the selected item. Set this to -1 if no item should be selected
|
//! Sets the selected item. Set this to -1 if no item should be selected
|
||||||
virtual void setSelected(s32 idx) = 0;
|
virtual void setSelected(s32 idx) = 0;
|
||||||
|
|
||||||
//! Sets the selected item and emits a change event.
|
|
||||||
/** Set this to -1 if no item should be selected */
|
|
||||||
virtual void setAndSendSelected(s32 idx) = 0;
|
|
||||||
|
|
||||||
//! Sets text justification of the text area
|
//! Sets text justification of the text area
|
||||||
/** \param horizontal: EGUIA_UPPERLEFT for left justified (default),
|
/** \param horizontal: EGUIA_UPPERLEFT for left justified (default),
|
||||||
EGUIA_LOWERRIGHT for right justified, or EGUIA_CENTER for centered text.
|
EGUIA_LOWERRIGHT for right justified, or EGUIA_CENTER for centered text.
|
||||||
|
103
include/IImage.h
103
include/IImage.h
@ -362,6 +362,28 @@ public:
|
|||||||
return 24;
|
return 24;
|
||||||
case ECF_A8R8G8B8:
|
case ECF_A8R8G8B8:
|
||||||
return 32;
|
return 32;
|
||||||
|
case ECF_DXT1:
|
||||||
|
return 16;
|
||||||
|
case ECF_DXT2:
|
||||||
|
case ECF_DXT3:
|
||||||
|
case ECF_DXT4:
|
||||||
|
case ECF_DXT5:
|
||||||
|
return 32;
|
||||||
|
case ECF_PVRTC_RGB2:
|
||||||
|
return 12;
|
||||||
|
case ECF_PVRTC_ARGB2:
|
||||||
|
case ECF_PVRTC2_ARGB2:
|
||||||
|
return 16;
|
||||||
|
case ECF_PVRTC_RGB4:
|
||||||
|
return 24;
|
||||||
|
case ECF_PVRTC_ARGB4:
|
||||||
|
case ECF_PVRTC2_ARGB4:
|
||||||
|
return 32;
|
||||||
|
case ECF_ETC1:
|
||||||
|
case ECF_ETC2_RGB:
|
||||||
|
return 24;
|
||||||
|
case ECF_ETC2_ARGB:
|
||||||
|
return 32;
|
||||||
case ECF_D16:
|
case ECF_D16:
|
||||||
return 16;
|
return 16;
|
||||||
case ECF_D32:
|
case ECF_D32:
|
||||||
@ -396,17 +418,74 @@ public:
|
|||||||
//! calculate image data size in bytes for selected format, width and height.
|
//! calculate image data size in bytes for selected format, width and height.
|
||||||
static u32 getDataSizeFromFormat(ECOLOR_FORMAT format, u32 width, u32 height)
|
static u32 getDataSizeFromFormat(ECOLOR_FORMAT format, u32 width, u32 height)
|
||||||
{
|
{
|
||||||
// non-compressed formats
|
u32 imageSize = 0;
|
||||||
u32 imageSize = getBitsPerPixelFromFormat(format) / 8 * width;
|
|
||||||
imageSize *= height;
|
switch (format)
|
||||||
|
{
|
||||||
|
case ECF_DXT1:
|
||||||
|
imageSize = ((width + 3) / 4) * ((height + 3) / 4) * 8;
|
||||||
|
break;
|
||||||
|
case ECF_DXT2:
|
||||||
|
case ECF_DXT3:
|
||||||
|
case ECF_DXT4:
|
||||||
|
case ECF_DXT5:
|
||||||
|
imageSize = ((width + 3) / 4) * ((height + 3) / 4) * 16;
|
||||||
|
break;
|
||||||
|
case ECF_PVRTC_RGB2:
|
||||||
|
case ECF_PVRTC_ARGB2:
|
||||||
|
imageSize = (core::max_<u32>(width, 16) * core::max_<u32>(height, 8) * 2 + 7) / 8;
|
||||||
|
break;
|
||||||
|
case ECF_PVRTC_RGB4:
|
||||||
|
case ECF_PVRTC_ARGB4:
|
||||||
|
imageSize = (core::max_<u32>(width, 8) * core::max_<u32>(height, 8) * 4 + 7) / 8;
|
||||||
|
break;
|
||||||
|
case ECF_PVRTC2_ARGB2:
|
||||||
|
imageSize = core::ceil32(width / 8.0f) * core::ceil32(height / 4.0f) * 8;
|
||||||
|
break;
|
||||||
|
case ECF_PVRTC2_ARGB4:
|
||||||
|
case ECF_ETC1:
|
||||||
|
case ECF_ETC2_RGB:
|
||||||
|
imageSize = core::ceil32(width / 4.0f) * core::ceil32(height / 4.0f) * 8;
|
||||||
|
break;
|
||||||
|
case ECF_ETC2_ARGB:
|
||||||
|
imageSize = core::ceil32(width / 4.0f) * core::ceil32(height / 4.0f) * 16;
|
||||||
|
break;
|
||||||
|
default: // uncompressed formats
|
||||||
|
imageSize = getBitsPerPixelFromFormat(format) / 8 * width;
|
||||||
|
imageSize *= height;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
return imageSize;
|
return imageSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Define to check for all compressed image formats cases in a switch
|
||||||
|
#define IRR_CASE_IIMAGE_COMPRESSED_FORMAT\
|
||||||
|
case ECF_DXT1:\
|
||||||
|
case ECF_DXT2:\
|
||||||
|
case ECF_DXT3:\
|
||||||
|
case ECF_DXT4:\
|
||||||
|
case ECF_DXT5:\
|
||||||
|
case ECF_PVRTC_RGB2:\
|
||||||
|
case ECF_PVRTC_ARGB2:\
|
||||||
|
case ECF_PVRTC2_ARGB2:\
|
||||||
|
case ECF_PVRTC_RGB4:\
|
||||||
|
case ECF_PVRTC_ARGB4:\
|
||||||
|
case ECF_PVRTC2_ARGB4:\
|
||||||
|
case ECF_ETC1:\
|
||||||
|
case ECF_ETC2_RGB:\
|
||||||
|
case ECF_ETC2_ARGB:
|
||||||
|
|
||||||
//! check if this is compressed color format
|
//! check if this is compressed color format
|
||||||
static bool isCompressedFormat(const ECOLOR_FORMAT format)
|
static bool isCompressedFormat(const ECOLOR_FORMAT format)
|
||||||
{
|
{
|
||||||
return false;
|
switch(format)
|
||||||
|
{
|
||||||
|
IRR_CASE_IIMAGE_COMPRESSED_FORMAT
|
||||||
|
return true;
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//! check if the color format is only viable for depth/stencil textures
|
//! check if the color format is only viable for depth/stencil textures
|
||||||
@ -444,6 +523,22 @@ public:
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(PATCH_SUPERTUX_8_0_1_with_1_9_0)
|
||||||
|
static bool isRenderTargetOnlyFormat(const ECOLOR_FORMAT format)
|
||||||
|
{
|
||||||
|
switch (format)
|
||||||
|
{
|
||||||
|
case ECF_A1R5G5B5:
|
||||||
|
case ECF_R5G6B5:
|
||||||
|
case ECF_R8G8B8:
|
||||||
|
case ECF_A8R8G8B8:
|
||||||
|
return false;
|
||||||
|
default:
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
ECOLOR_FORMAT Format;
|
ECOLOR_FORMAT Format;
|
||||||
core::dimension2d<u32> Size;
|
core::dimension2d<u32> Size;
|
||||||
|
@ -19,7 +19,7 @@ enum ELOG_LEVEL
|
|||||||
//! Used for printing information helpful in debugging
|
//! Used for printing information helpful in debugging
|
||||||
ELL_DEBUG,
|
ELL_DEBUG,
|
||||||
|
|
||||||
//! Useful information to print. For example hardware info or something started/stopped.
|
//! Useful information to print. For example hardware infos or something started/stopped.
|
||||||
ELL_INFORMATION,
|
ELL_INFORMATION,
|
||||||
|
|
||||||
//! Warnings that something isn't as expected and can cause oddities
|
//! Warnings that something isn't as expected and can cause oddities
|
||||||
|
@ -38,11 +38,30 @@ public:
|
|||||||
const SMaterial& lastMaterial,
|
const SMaterial& lastMaterial,
|
||||||
bool resetAllRenderstates) = 0;
|
bool resetAllRenderstates) = 0;
|
||||||
|
|
||||||
//! Return an index constant for the vertex shader based on a uniform variable name.
|
//! Return an index constant for the vertex shader based on a name.
|
||||||
virtual s32 getVertexShaderConstantID(const c8* name) = 0;
|
virtual s32 getVertexShaderConstantID(const c8* name) = 0;
|
||||||
|
|
||||||
//! Sets a value for a vertex shader uniform variable.
|
//! Sets a constant for the vertex shader based on a name.
|
||||||
/** \param index Index of the variable (as received from getVertexShaderConstantID)
|
/** This can be used if you used a high level shader language like GLSL
|
||||||
|
or HLSL to create a shader. Example: If you created a shader which has
|
||||||
|
variables named 'mWorldViewProj' (containing the WorldViewProjection
|
||||||
|
matrix) and another one named 'fTime' containing one float, you can set
|
||||||
|
them in your IShaderConstantSetCallBack derived class like this:
|
||||||
|
\code
|
||||||
|
virtual void OnSetConstants(video::IMaterialRendererServices* services, s32 userData)
|
||||||
|
{
|
||||||
|
video::IVideoDriver* driver = services->getVideoDriver();
|
||||||
|
|
||||||
|
f32 time = (f32)os::Timer::getTime()/100000.0f;
|
||||||
|
services->setVertexShaderConstant("fTime", &time, 1);
|
||||||
|
|
||||||
|
core::matrix4 worldViewProj(driver->getTransform(video::ETS_PROJECTION));
|
||||||
|
worldViewProj *= driver->getTransform(video::ETS_VIEW);
|
||||||
|
worldViewProj *= driver->getTransform(video::ETS_WORLD);
|
||||||
|
services->setVertexShaderConstant("mWorldViewProj", worldViewProj.M, 16);
|
||||||
|
}
|
||||||
|
\endcode
|
||||||
|
\param index Index of the variable
|
||||||
\param floats Pointer to array of floats
|
\param floats Pointer to array of floats
|
||||||
\param count Amount of floats in array.
|
\param count Amount of floats in array.
|
||||||
\return True if successful.
|
\return True if successful.
|
||||||
@ -66,14 +85,14 @@ public:
|
|||||||
\param constantAmount: Amount of registers to be set. One register consists of 4 floats. */
|
\param constantAmount: Amount of registers to be set. One register consists of 4 floats. */
|
||||||
virtual void setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) = 0;
|
virtual void setVertexShaderConstant(const f32* data, s32 startRegister, s32 constantAmount=1) = 0;
|
||||||
|
|
||||||
//! Return an index constant for the pixel shader for the given uniform variable name
|
//! Return an index constant for the pixel shader based on a name.
|
||||||
virtual s32 getPixelShaderConstantID(const c8* name) = 0;
|
virtual s32 getPixelShaderConstantID(const c8* name) = 0;
|
||||||
|
|
||||||
//! Sets a value for the given pixel shader uniform variable
|
//! Sets a constant for the pixel shader based on a name.
|
||||||
/** This can be used if you used a high level shader language like GLSL
|
/** This can be used if you used a high level shader language like GLSL
|
||||||
or HLSL to create a shader. See setVertexShaderConstant() for an
|
or HLSL to create a shader. See setVertexShaderConstant() for an
|
||||||
example on how to use this.
|
example on how to use this.
|
||||||
\param index Index of the variable (as received from getPixelShaderConstantID)
|
\param index Index of the variable
|
||||||
\param floats Pointer to array of floats
|
\param floats Pointer to array of floats
|
||||||
\param count Amount of floats in array.
|
\param count Amount of floats in array.
|
||||||
\return True if successful. */
|
\return True if successful. */
|
||||||
|
@ -2,7 +2,9 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_I_MESH_WRITER_H_INCLUDED__
|
||||||
|
#define __IRR_I_MESH_WRITER_H_INCLUDED__
|
||||||
|
|
||||||
#include "IReferenceCounted.h"
|
#include "IReferenceCounted.h"
|
||||||
#include "EMeshWriterEnums.h"
|
#include "EMeshWriterEnums.h"
|
||||||
|
|
||||||
@ -52,4 +54,5 @@ namespace scene
|
|||||||
} // end namespace
|
} // end namespace
|
||||||
} // end namespace
|
} // end namespace
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -11,11 +11,11 @@
|
|||||||
namespace irr
|
namespace irr
|
||||||
{
|
{
|
||||||
|
|
||||||
//! The OSOperator provides OS-specific methods and information.
|
//! The Operating system operator provides operation system specific methods and information.
|
||||||
class IOSOperator : public virtual IReferenceCounted
|
class IOSOperator : public virtual IReferenceCounted
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
//! Get the current OS version as string.
|
//! Get the current operation system version as string.
|
||||||
virtual const core::stringc& getOperatingSystemVersion() const = 0;
|
virtual const core::stringc& getOperatingSystemVersion() const = 0;
|
||||||
|
|
||||||
//! Copies text to the clipboard
|
//! Copies text to the clipboard
|
||||||
|
@ -130,7 +130,7 @@ namespace scene
|
|||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
//! Get pointer to an animatable mesh. Loads the file if not loaded already.
|
//! Get pointer to an animateable mesh. Loads the file if not loaded already.
|
||||||
/**
|
/**
|
||||||
* If you want to remove a loaded mesh from the cache again, use removeMesh().
|
* If you want to remove a loaded mesh from the cache again, use removeMesh().
|
||||||
* Currently there are the following mesh formats supported:
|
* Currently there are the following mesh formats supported:
|
||||||
@ -509,7 +509,7 @@ namespace scene
|
|||||||
|
|
||||||
//! Clear all nodes which are currently registered for rendering
|
//! Clear all nodes which are currently registered for rendering
|
||||||
/** Usually you don't have to care about this as drawAll will clear nodes
|
/** Usually you don't have to care about this as drawAll will clear nodes
|
||||||
after rendering them. But sometimes you might have to manually reset this.
|
after rendering them. But sometimes you might have to manully reset this.
|
||||||
For example when you deleted nodes between registering and rendering. */
|
For example when you deleted nodes between registering and rendering. */
|
||||||
virtual void clearAllRegisteredNodesForRendering() = 0;
|
virtual void clearAllRegisteredNodesForRendering() = 0;
|
||||||
|
|
||||||
|
@ -15,7 +15,6 @@
|
|||||||
#include "matrix4.h"
|
#include "matrix4.h"
|
||||||
#include "IAttributes.h"
|
#include "IAttributes.h"
|
||||||
#include <list>
|
#include <list>
|
||||||
#include <optional>
|
|
||||||
|
|
||||||
namespace irr
|
namespace irr
|
||||||
{
|
{
|
||||||
@ -66,7 +65,7 @@ namespace scene
|
|||||||
|
|
||||||
//! This method is called just before the rendering process of the whole scene.
|
//! This method is called just before the rendering process of the whole scene.
|
||||||
/** Nodes may register themselves in the render pipeline during this call,
|
/** Nodes may register themselves in the render pipeline during this call,
|
||||||
precalculate the geometry which should be rendered, and prevent their
|
precalculate the geometry which should be renderered, and prevent their
|
||||||
children from being able to register themselves if they are clipped by simply
|
children from being able to register themselves if they are clipped by simply
|
||||||
not calling their OnRegisterSceneNode method.
|
not calling their OnRegisterSceneNode method.
|
||||||
If you are implementing your own scene node, you should overwrite this method
|
If you are implementing your own scene node, you should overwrite this method
|
||||||
@ -276,31 +275,31 @@ namespace scene
|
|||||||
|
|
||||||
child->grab();
|
child->grab();
|
||||||
child->remove(); // remove from old parent
|
child->remove(); // remove from old parent
|
||||||
// Note: This iterator is not invalidated until we erase it.
|
Children.push_back(child);
|
||||||
child->ThisIterator = Children.insert(Children.end(), child);
|
|
||||||
child->Parent = this;
|
child->Parent = this;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//! Removes a child from this scene node.
|
//! Removes a child from this scene node.
|
||||||
/**
|
/** If found in the children list, the child pointer is also
|
||||||
|
dropped and might be deleted if no other grab exists.
|
||||||
\param child A pointer to the child which shall be removed.
|
\param child A pointer to the child which shall be removed.
|
||||||
\return True if the child was removed, and false if not,
|
\return True if the child was removed, and false if not,
|
||||||
e.g. because it belongs to a different parent or no parent. */
|
e.g. because it couldn't be found in the children list. */
|
||||||
virtual bool removeChild(ISceneNode* child)
|
virtual bool removeChild(ISceneNode* child)
|
||||||
{
|
{
|
||||||
if (child->Parent != this)
|
ISceneNodeList::iterator it = Children.begin();
|
||||||
return false;
|
for (; it != Children.end(); ++it)
|
||||||
|
if ((*it) == child)
|
||||||
|
{
|
||||||
|
(*it)->Parent = 0;
|
||||||
|
(*it)->drop();
|
||||||
|
Children.erase(it);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
// The iterator must be set since the parent is not null.
|
return false;
|
||||||
_IRR_DEBUG_BREAK_IF(!child->ThisIterator.has_value());
|
|
||||||
auto it = *child->ThisIterator;
|
|
||||||
child->ThisIterator = std::nullopt;
|
|
||||||
child->Parent = nullptr;
|
|
||||||
child->drop();
|
|
||||||
Children.erase(it);
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -310,11 +309,13 @@ namespace scene
|
|||||||
*/
|
*/
|
||||||
virtual void removeAll()
|
virtual void removeAll()
|
||||||
{
|
{
|
||||||
for (auto &child : Children) {
|
ISceneNodeList::iterator it = Children.begin();
|
||||||
child->Parent = nullptr;
|
for (; it != Children.end(); ++it)
|
||||||
child->ThisIterator = std::nullopt;
|
{
|
||||||
child->drop();
|
(*it)->Parent = 0;
|
||||||
|
(*it)->drop();
|
||||||
}
|
}
|
||||||
|
|
||||||
Children.clear();
|
Children.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -507,8 +508,10 @@ namespace scene
|
|||||||
grab();
|
grab();
|
||||||
remove();
|
remove();
|
||||||
|
|
||||||
if (newParent)
|
Parent = newParent;
|
||||||
newParent->addChild(this);
|
|
||||||
|
if (Parent)
|
||||||
|
Parent->addChild(this);
|
||||||
|
|
||||||
drop();
|
drop();
|
||||||
}
|
}
|
||||||
@ -615,15 +618,12 @@ namespace scene
|
|||||||
//! Relative scale of the scene node.
|
//! Relative scale of the scene node.
|
||||||
core::vector3df RelativeScale;
|
core::vector3df RelativeScale;
|
||||||
|
|
||||||
//! List of all children of this node
|
|
||||||
std::list<ISceneNode*> Children;
|
|
||||||
|
|
||||||
//! Iterator pointing to this node in the parent's child list.
|
|
||||||
std::optional<ISceneNodeList::iterator> ThisIterator;
|
|
||||||
|
|
||||||
//! Pointer to the parent
|
//! Pointer to the parent
|
||||||
ISceneNode* Parent;
|
ISceneNode* Parent;
|
||||||
|
|
||||||
|
//! List of all children of this node
|
||||||
|
std::list<ISceneNode*> Children;
|
||||||
|
|
||||||
//! Pointer to the scene manager
|
//! Pointer to the scene manager
|
||||||
ISceneManager* SceneManager;
|
ISceneManager* SceneManager;
|
||||||
|
|
||||||
|
@ -292,6 +292,11 @@ public:
|
|||||||
{
|
{
|
||||||
case ECF_A8R8G8B8:
|
case ECF_A8R8G8B8:
|
||||||
case ECF_A1R5G5B5:
|
case ECF_A1R5G5B5:
|
||||||
|
case ECF_DXT1:
|
||||||
|
case ECF_DXT2:
|
||||||
|
case ECF_DXT3:
|
||||||
|
case ECF_DXT4:
|
||||||
|
case ECF_DXT5:
|
||||||
case ECF_A16B16G16R16F:
|
case ECF_A16B16G16R16F:
|
||||||
case ECF_A32B32G32R32F:
|
case ECF_A32B32G32R32F:
|
||||||
status = true;
|
status = true;
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_I_VIDEO_DRIVER_H_INCLUDED__
|
||||||
|
#define __IRR_I_VIDEO_DRIVER_H_INCLUDED__
|
||||||
|
|
||||||
#include "rect.h"
|
#include "rect.h"
|
||||||
#include "SColor.h"
|
#include "SColor.h"
|
||||||
@ -1046,7 +1047,7 @@ namespace video
|
|||||||
E_MATERIAL_TYPE enum or a value which was returned by
|
E_MATERIAL_TYPE enum or a value which was returned by
|
||||||
addMaterialRenderer().
|
addMaterialRenderer().
|
||||||
\return String with the name of the renderer, or 0 if not
|
\return String with the name of the renderer, or 0 if not
|
||||||
existing */
|
exisiting */
|
||||||
virtual const c8* getMaterialRendererName(u32 idx) const =0;
|
virtual const c8* getMaterialRendererName(u32 idx) const =0;
|
||||||
|
|
||||||
//! Sets the name of a material renderer.
|
//! Sets the name of a material renderer.
|
||||||
@ -1210,3 +1211,4 @@ namespace video
|
|||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
|
||||||
|
#endif
|
||||||
|
@ -2,11 +2,12 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_COMPILE_CONFIG_H_INCLUDED__
|
||||||
|
#define __IRR_COMPILE_CONFIG_H_INCLUDED__
|
||||||
|
|
||||||
//! Identifies the IrrlichtMt fork customized for the Minetest engine
|
//! Identifies the IrrlichtMt fork customized for the Minetest engine
|
||||||
#define IRRLICHT_VERSION_MT_REVISION 14
|
#define IRRLICHT_VERSION_MT_REVISION 12
|
||||||
#define IRRLICHT_VERSION_MT "mt14"
|
#define IRRLICHT_VERSION_MT "mt12"
|
||||||
|
|
||||||
//! Irrlicht SDK Version
|
//! Irrlicht SDK Version
|
||||||
#define IRRLICHT_VERSION_MAJOR 1
|
#define IRRLICHT_VERSION_MAJOR 1
|
||||||
@ -28,3 +29,5 @@
|
|||||||
#ifndef IRRLICHT_API
|
#ifndef IRRLICHT_API
|
||||||
#define IRRLICHT_API
|
#define IRRLICHT_API
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#endif // __IRR_COMPILE_CONFIG_H_INCLUDED__
|
||||||
|
@ -76,17 +76,13 @@ namespace irr
|
|||||||
virtual bool run() = 0;
|
virtual bool run() = 0;
|
||||||
|
|
||||||
//! Cause the device to temporarily pause execution and let other processes run.
|
//! Cause the device to temporarily pause execution and let other processes run.
|
||||||
/** This should bring down processor usage without major performance loss for Irrlicht.
|
/** This should bring down processor usage without major
|
||||||
But this is system dependent, so there's a chance your thread won't get control back quickly.
|
performance loss for Irrlicht */
|
||||||
*/
|
|
||||||
virtual void yield() = 0;
|
virtual void yield() = 0;
|
||||||
|
|
||||||
//! Pause execution and let other processes to run for a specified amount of time.
|
//! Pause execution and let other processes to run for a specified amount of time.
|
||||||
/** It may not wait the full given time, as sleep may be interrupted and also may wait longer on some OS.
|
/** It may not wait the full given time, as sleep may be interrupted
|
||||||
\param timeMs: Time to sleep for in milliseconds. Note that the OS can round up this number.
|
\param timeMs: Time to sleep for in milliseconds.
|
||||||
On Windows you usually get at least 15ms sleep time minium for any value > 0.
|
|
||||||
So if you call this in your main loop you can't get more than 65 FPS anymore in your game.
|
|
||||||
On most Linux systems it's relatively exact, but also no guarantee.
|
|
||||||
\param pauseTimer: If true, pauses the device timer while sleeping
|
\param pauseTimer: If true, pauses the device timer while sleeping
|
||||||
*/
|
*/
|
||||||
virtual void sleep(u32 timeMs, bool pauseTimer=false) = 0;
|
virtual void sleep(u32 timeMs, bool pauseTimer=false) = 0;
|
||||||
@ -177,10 +173,6 @@ namespace irr
|
|||||||
/** \return True if window is fullscreen. */
|
/** \return True if window is fullscreen. */
|
||||||
virtual bool isFullscreen() const = 0;
|
virtual bool isFullscreen() const = 0;
|
||||||
|
|
||||||
//! Checks if the window could possibly be visible.
|
|
||||||
//! Currently, this only returns false when the app is paused on Android.
|
|
||||||
virtual bool isWindowVisible() const { return true; };
|
|
||||||
|
|
||||||
//! Get the current color format of the window
|
//! Get the current color format of the window
|
||||||
/** \return Color format of the window. */
|
/** \return Color format of the window. */
|
||||||
virtual video::ECOLOR_FORMAT getColorFormat() const = 0;
|
virtual video::ECOLOR_FORMAT getColorFormat() const = 0;
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_KEY_CODES_H_INCLUDED__
|
||||||
|
#define __IRR_KEY_CODES_H_INCLUDED__
|
||||||
|
|
||||||
namespace irr
|
namespace irr
|
||||||
{
|
{
|
||||||
@ -89,7 +90,7 @@ namespace irr
|
|||||||
KEY_KEY_X = 0x58, // X key
|
KEY_KEY_X = 0x58, // X key
|
||||||
KEY_KEY_Y = 0x59, // Y key
|
KEY_KEY_Y = 0x59, // Y key
|
||||||
KEY_KEY_Z = 0x5A, // Z key
|
KEY_KEY_Z = 0x5A, // Z key
|
||||||
KEY_LWIN = 0x5B, // Left Windows key (Microsoft Natural keyboard)
|
KEY_LWIN = 0x5B, // Left Windows key (Microsoft<EFBFBD> Natural<EFBFBD> keyboard)
|
||||||
KEY_RWIN = 0x5C, // Right Windows key (Natural keyboard)
|
KEY_RWIN = 0x5C, // Right Windows key (Natural keyboard)
|
||||||
KEY_APPS = 0x5D, // Applications key (Natural keyboard)
|
KEY_APPS = 0x5D, // Applications key (Natural keyboard)
|
||||||
KEY_SLEEP = 0x5F, // Computer Sleep key
|
KEY_SLEEP = 0x5F, // Computer Sleep key
|
||||||
@ -184,4 +185,5 @@ namespace irr
|
|||||||
|
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -37,6 +37,50 @@ namespace video
|
|||||||
//! Warning: This tends to be BGRA in memory (it's ARGB on file, but with usual big-endian memory it's flipped)
|
//! Warning: This tends to be BGRA in memory (it's ARGB on file, but with usual big-endian memory it's flipped)
|
||||||
ECF_A8R8G8B8,
|
ECF_A8R8G8B8,
|
||||||
|
|
||||||
|
/** Compressed image formats. **/
|
||||||
|
|
||||||
|
//! DXT1 color format.
|
||||||
|
ECF_DXT1,
|
||||||
|
|
||||||
|
//! DXT2 color format.
|
||||||
|
ECF_DXT2,
|
||||||
|
|
||||||
|
//! DXT3 color format.
|
||||||
|
ECF_DXT3,
|
||||||
|
|
||||||
|
//! DXT4 color format.
|
||||||
|
ECF_DXT4,
|
||||||
|
|
||||||
|
//! DXT5 color format.
|
||||||
|
ECF_DXT5,
|
||||||
|
|
||||||
|
//! PVRTC RGB 2bpp.
|
||||||
|
ECF_PVRTC_RGB2,
|
||||||
|
|
||||||
|
//! PVRTC ARGB 2bpp.
|
||||||
|
ECF_PVRTC_ARGB2,
|
||||||
|
|
||||||
|
//! PVRTC RGB 4bpp.
|
||||||
|
ECF_PVRTC_RGB4,
|
||||||
|
|
||||||
|
//! PVRTC ARGB 4bpp.
|
||||||
|
ECF_PVRTC_ARGB4,
|
||||||
|
|
||||||
|
//! PVRTC2 ARGB 2bpp.
|
||||||
|
ECF_PVRTC2_ARGB2,
|
||||||
|
|
||||||
|
//! PVRTC2 ARGB 4bpp.
|
||||||
|
ECF_PVRTC2_ARGB4,
|
||||||
|
|
||||||
|
//! ETC1 RGB.
|
||||||
|
ECF_ETC1,
|
||||||
|
|
||||||
|
//! ETC2 RGB.
|
||||||
|
ECF_ETC2_RGB,
|
||||||
|
|
||||||
|
//! ETC2 ARGB.
|
||||||
|
ECF_ETC2_ARGB,
|
||||||
|
|
||||||
/** The following formats may only be used for render target textures. */
|
/** The following formats may only be used for render target textures. */
|
||||||
|
|
||||||
/** Floating point formats. */
|
/** Floating point formats. */
|
||||||
@ -95,6 +139,20 @@ namespace video
|
|||||||
"R5G6B5",
|
"R5G6B5",
|
||||||
"R8G8B8",
|
"R8G8B8",
|
||||||
"A8R8G8B8",
|
"A8R8G8B8",
|
||||||
|
"DXT1",
|
||||||
|
"DXT2",
|
||||||
|
"DXT3",
|
||||||
|
"DXT4",
|
||||||
|
"DXT5",
|
||||||
|
"PVRTC_RGB2",
|
||||||
|
"PVRTC_ARGB2",
|
||||||
|
"PVRTC_RGB4",
|
||||||
|
"PVRTC_ARGB4",
|
||||||
|
"PVRTC2_ARGB2",
|
||||||
|
"PVRTC2_ARGB4",
|
||||||
|
"ETC1",
|
||||||
|
"ETC2_RGB",
|
||||||
|
"ETC2_ARGB",
|
||||||
"R16F",
|
"R16F",
|
||||||
"G16R16F",
|
"G16R16F",
|
||||||
"A16B16G16R16F",
|
"A16B16G16R16F",
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_AABBOX_3D_H_INCLUDED__
|
||||||
|
#define __IRR_AABBOX_3D_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrMath.h"
|
#include "irrMath.h"
|
||||||
#include "plane3d.h"
|
#include "plane3d.h"
|
||||||
@ -363,3 +364,6 @@ class aabbox3d
|
|||||||
|
|
||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_CORE_UTIL_H_INCLUDED__
|
||||||
|
#define __IRR_CORE_UTIL_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrString.h"
|
#include "irrString.h"
|
||||||
#include "path.h"
|
#include "path.h"
|
||||||
@ -201,3 +202,4 @@ inline bool isupper(s32 c) { return c >= 'A' && c <= 'Z'; }
|
|||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_DIMENSION2D_H_INCLUDED__
|
||||||
|
#define __IRR_DIMENSION2D_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrTypes.h"
|
#include "irrTypes.h"
|
||||||
#include "irrMath.h" // for irr::core::equals()
|
#include "irrMath.h" // for irr::core::equals()
|
||||||
@ -219,4 +220,5 @@ namespace core
|
|||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,7 +2,9 @@
|
|||||||
// This file is part of the "Irrlicht Engine" and the "irrXML" project.
|
// This file is part of the "Irrlicht Engine" and the "irrXML" project.
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h and irrXML.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h and irrXML.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_ARRAY_H_INCLUDED__
|
||||||
|
#define __IRR_ARRAY_H_INCLUDED__
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <iterator>
|
#include <iterator>
|
||||||
#include <vector>
|
#include <vector>
|
||||||
@ -241,7 +243,7 @@ public:
|
|||||||
/** \return Size of elements in the array which are actually occupied. */
|
/** \return Size of elements in the array which are actually occupied. */
|
||||||
u32 size() const
|
u32 size() const
|
||||||
{
|
{
|
||||||
return static_cast<u32>(m_data.size());
|
return m_data.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -317,7 +319,7 @@ public:
|
|||||||
// *it = first element in [first, last) that is >= element, or last if not found.
|
// *it = first element in [first, last) that is >= element, or last if not found.
|
||||||
if (*it < element || element < *it)
|
if (*it < element || element < *it)
|
||||||
return -1;
|
return -1;
|
||||||
return static_cast<u32>(it - m_data.begin());
|
return it - m_data.begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -335,8 +337,8 @@ public:
|
|||||||
auto iters = std::equal_range(m_data.begin(), m_data.end(), element);
|
auto iters = std::equal_range(m_data.begin(), m_data.end(), element);
|
||||||
if (iters.first == iters.second)
|
if (iters.first == iters.second)
|
||||||
return -1;
|
return -1;
|
||||||
last = static_cast<s32>((iters.second - m_data.begin()) - 1);
|
last = (iters.second - m_data.begin()) - 1;
|
||||||
return static_cast<s32>(iters.first - m_data.begin());
|
return iters.first - m_data.begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -351,7 +353,7 @@ public:
|
|||||||
auto it = std::find(m_data.begin(), m_data.end(), element);
|
auto it = std::find(m_data.begin(), m_data.end(), element);
|
||||||
if (it == m_data.end())
|
if (it == m_data.end())
|
||||||
return -1;
|
return -1;
|
||||||
return static_cast<u32>(it - m_data.begin());
|
return it - m_data.begin();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -436,4 +438,5 @@ private:
|
|||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,14 +2,14 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_MATH_H_INCLUDED__
|
||||||
|
#define __IRR_MATH_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrTypes.h"
|
#include "irrTypes.h"
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include <float.h>
|
#include <float.h>
|
||||||
#include <stdlib.h> // for abs() etc.
|
#include <stdlib.h> // for abs() etc.
|
||||||
#include <limits.h> // For INT_MAX / UINT_MAX
|
#include <limits.h> // For INT_MAX / UINT_MAX
|
||||||
#include <type_traits>
|
|
||||||
|
|
||||||
namespace irr
|
namespace irr
|
||||||
{
|
{
|
||||||
@ -18,6 +18,9 @@ namespace core
|
|||||||
|
|
||||||
//! Rounding error constant often used when comparing f32 values.
|
//! Rounding error constant often used when comparing f32 values.
|
||||||
|
|
||||||
|
const s32 ROUNDING_ERROR_S32 = 0;
|
||||||
|
|
||||||
|
const s64 ROUNDING_ERROR_S64 = 0;
|
||||||
const f32 ROUNDING_ERROR_f32 = 0.000001f;
|
const f32 ROUNDING_ERROR_f32 = 0.000001f;
|
||||||
const f64 ROUNDING_ERROR_f64 = 0.00000001;
|
const f64 ROUNDING_ERROR_f64 = 0.00000001;
|
||||||
|
|
||||||
@ -168,6 +171,30 @@ namespace core
|
|||||||
return ROUNDING_ERROR_f64;
|
return ROUNDING_ERROR_f64;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <>
|
||||||
|
inline s32 roundingError()
|
||||||
|
{
|
||||||
|
return ROUNDING_ERROR_S32;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <>
|
||||||
|
inline u32 roundingError()
|
||||||
|
{
|
||||||
|
return ROUNDING_ERROR_S32;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <>
|
||||||
|
inline s64 roundingError()
|
||||||
|
{
|
||||||
|
return ROUNDING_ERROR_S64;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <>
|
||||||
|
inline u64 roundingError()
|
||||||
|
{
|
||||||
|
return ROUNDING_ERROR_S64;
|
||||||
|
}
|
||||||
|
|
||||||
template <class T>
|
template <class T>
|
||||||
inline T relativeErrorFactor()
|
inline T relativeErrorFactor()
|
||||||
{
|
{
|
||||||
@ -186,20 +213,14 @@ namespace core
|
|||||||
return 8;
|
return 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
//! returns if a equals b, for types without rounding errors
|
|
||||||
template <class T, std::enable_if_t<std::is_integral<T>::value, bool> = true>
|
|
||||||
inline bool equals(const T a, const T b)
|
|
||||||
{
|
|
||||||
return a == b;
|
|
||||||
}
|
|
||||||
|
|
||||||
//! returns if a equals b, taking possible rounding errors into account
|
//! returns if a equals b, taking possible rounding errors into account
|
||||||
template <class T, std::enable_if_t<std::is_floating_point<T>::value, bool> = true>
|
template <class T>
|
||||||
inline bool equals(const T a, const T b, const T tolerance = roundingError<T>())
|
inline bool equals(const T a, const T b, const T tolerance = roundingError<T>())
|
||||||
{
|
{
|
||||||
return abs(a - b) <= tolerance;
|
return (a + tolerance >= b) && (a - tolerance <= b);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//! returns if a equals b, taking relative error in form of factor
|
//! returns if a equals b, taking relative error in form of factor
|
||||||
//! this particular function does not involve any division.
|
//! this particular function does not involve any division.
|
||||||
template <class T>
|
template <class T>
|
||||||
@ -458,3 +479,4 @@ namespace core
|
|||||||
using irr::core::IR;
|
using irr::core::IR;
|
||||||
using irr::core::FR;
|
using irr::core::FR;
|
||||||
|
|
||||||
|
#endif
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine" and the "irrXML" project.
|
// This file is part of the "Irrlicht Engine" and the "irrXML" project.
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h and irrXML.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h and irrXML.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_STRING_H_INCLUDED__
|
||||||
|
#define __IRR_STRING_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrTypes.h"
|
#include "irrTypes.h"
|
||||||
#include <string>
|
#include <string>
|
||||||
@ -10,8 +11,6 @@
|
|||||||
#include <cstdio>
|
#include <cstdio>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
#include <cwchar>
|
#include <cwchar>
|
||||||
#include <codecvt>
|
|
||||||
#include <locale>
|
|
||||||
|
|
||||||
namespace irr
|
namespace irr
|
||||||
{
|
{
|
||||||
@ -36,13 +35,8 @@ outside the string class for explicit use.
|
|||||||
// forward declarations
|
// forward declarations
|
||||||
template <typename T>
|
template <typename T>
|
||||||
class string;
|
class string;
|
||||||
|
static size_t multibyteToWString(string<wchar_t>& destination, const char* source, u32 sourceSize);
|
||||||
//! Typedef for character strings
|
static size_t wStringToMultibyte(string<c8>& destination, const wchar_t* source, u32 sourceSize);
|
||||||
typedef string<c8> stringc;
|
|
||||||
|
|
||||||
//! Typedef for wide character strings
|
|
||||||
typedef string<wchar_t> stringw;
|
|
||||||
|
|
||||||
|
|
||||||
//! Returns a character converted to lower case
|
//! Returns a character converted to lower case
|
||||||
static inline u32 locale_lower ( u32 x )
|
static inline u32 locale_lower ( u32 x )
|
||||||
@ -266,7 +260,7 @@ public:
|
|||||||
the trailing NUL. */
|
the trailing NUL. */
|
||||||
u32 size() const
|
u32 size() const
|
||||||
{
|
{
|
||||||
return static_cast<u32>(str.size());
|
return str.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
//! Informs if the string is empty or not.
|
//! Informs if the string is empty or not.
|
||||||
@ -834,7 +828,7 @@ public:
|
|||||||
if (!delimiter)
|
if (!delimiter)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
const u32 oldSize=static_cast<u32>(ret.size());
|
const u32 oldSize=ret.size();
|
||||||
|
|
||||||
u32 tokenStartIdx = 0;
|
u32 tokenStartIdx = 0;
|
||||||
for (u32 i=0; i<size()+1; ++i)
|
for (u32 i=0; i<size()+1; ++i)
|
||||||
@ -862,14 +856,11 @@ public:
|
|||||||
else if (!ignoreEmptyTokens)
|
else if (!ignoreEmptyTokens)
|
||||||
ret.push_back(string<T>());
|
ret.push_back(string<T>());
|
||||||
|
|
||||||
return static_cast<u32>(ret.size()-oldSize);
|
return ret.size()-oldSize;
|
||||||
}
|
}
|
||||||
|
|
||||||
// This function should not be used and is only kept for "CGUIFileOpenDialog::pathToStringW".
|
friend size_t multibyteToWString(string<wchar_t>& destination, const char* source, u32 sourceSize);
|
||||||
friend size_t multibyteToWString(stringw& destination, const stringc &source);
|
friend size_t wStringToMultibyte(string<c8>& destination, const wchar_t* source, u32 sourceSize);
|
||||||
|
|
||||||
friend size_t utf8ToWString(stringw &destination, const char *source);
|
|
||||||
friend size_t wStringToUTF8(stringc &destination, const wchar_t *source);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
@ -888,10 +879,10 @@ private:
|
|||||||
return len;
|
return len;
|
||||||
}
|
}
|
||||||
static inline u32 calclen(const char* p) {
|
static inline u32 calclen(const char* p) {
|
||||||
return static_cast<u32>(strlen(p));
|
return strlen(p);
|
||||||
}
|
}
|
||||||
static inline u32 calclen(const wchar_t* p) {
|
static inline u32 calclen(const wchar_t* p) {
|
||||||
return static_cast<u32>(wcslen(p));
|
return wcslen(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
//! strcmp wrapper
|
//! strcmp wrapper
|
||||||
@ -922,18 +913,38 @@ private:
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
//! Typedef for character strings
|
||||||
|
typedef string<c8> stringc;
|
||||||
|
|
||||||
|
//! Typedef for wide character strings
|
||||||
|
typedef string<wchar_t> stringw;
|
||||||
|
|
||||||
//! Convert multibyte string to wide-character string
|
//! Convert multibyte string to wide-character string
|
||||||
/** Wrapper around mbstowcs from standard library, but directly using Irrlicht string class.
|
/** Wrapper around mbstowcs from standard library, but directly using Irrlicht string class.
|
||||||
What the function does exactly depends on the LC_CTYPE of the current c locale.
|
What the function does exactly depends on the LC_CTYPE of the current c locale.
|
||||||
\param destination Wide-character string receiving the converted source
|
\param destination Wide-character string receiving the converted source
|
||||||
\param source multibyte string
|
\param source multibyte string
|
||||||
\return The number of wide characters written to destination, not including the eventual terminating null character or -1 when conversion failed
|
\return The number of wide characters written to destination, not including the eventual terminating null character or -1 when conversion failed */
|
||||||
|
static inline size_t multibyteToWString(string<wchar_t>& destination, const core::string<c8>& source)
|
||||||
This function should not be used and is only kept for "CGUIFileOpenDialog::pathToStringW". */
|
|
||||||
inline size_t multibyteToWString(stringw& destination, const core::stringc& source)
|
|
||||||
{
|
{
|
||||||
u32 sourceSize = source.size();
|
return multibyteToWString(destination, source.c_str(), (u32)source.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Convert multibyte string to wide-character string
|
||||||
|
/** Wrapper around mbstowcs from standard library, but directly writing to Irrlicht string class.
|
||||||
|
What the function does exactly depends on the LC_CTYPE of the current c locale.
|
||||||
|
\param destination Wide-character string receiving the converted source
|
||||||
|
\param source multibyte string
|
||||||
|
\return The number of wide characters written to destination, not including the eventual terminating null character or -1 when conversion failed. */
|
||||||
|
static inline size_t multibyteToWString(string<wchar_t>& destination, const char* source)
|
||||||
|
{
|
||||||
|
const u32 s = source ? (u32)strlen(source) : 0;
|
||||||
|
return multibyteToWString(destination, source, s);
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Internally used by the other multibyteToWString functions
|
||||||
|
static size_t multibyteToWString(string<wchar_t>& destination, const char* source, u32 sourceSize)
|
||||||
|
{
|
||||||
if ( sourceSize )
|
if ( sourceSize )
|
||||||
{
|
{
|
||||||
destination.str.resize(sourceSize+1);
|
destination.str.resize(sourceSize+1);
|
||||||
@ -941,7 +952,53 @@ inline size_t multibyteToWString(stringw& destination, const core::stringc& sour
|
|||||||
#pragma warning(push)
|
#pragma warning(push)
|
||||||
#pragma warning(disable: 4996) // 'mbstowcs': This function or variable may be unsafe. Consider using mbstowcs_s instead.
|
#pragma warning(disable: 4996) // 'mbstowcs': This function or variable may be unsafe. Consider using mbstowcs_s instead.
|
||||||
#endif
|
#endif
|
||||||
const size_t written = mbstowcs(&destination[0], source.c_str(), (size_t)sourceSize);
|
const size_t written = mbstowcs(&destination[0], source, (size_t)sourceSize);
|
||||||
|
#if defined(_MSC_VER)
|
||||||
|
#pragma warning(pop)
|
||||||
|
#endif
|
||||||
|
if ( written != (size_t)-1 )
|
||||||
|
{
|
||||||
|
destination.str.resize(written);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Likely character which got converted until the invalid character was encountered are in destination now.
|
||||||
|
// And it seems even 0-terminated, but I found no documentation anywhere that this (the 0-termination) is guaranteed :-(
|
||||||
|
destination.clear();
|
||||||
|
}
|
||||||
|
return written;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
destination.clear();
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Same as multibyteToWString, but the other way around
|
||||||
|
static inline size_t wStringToMultibyte(string<c8>& destination, const core::string<wchar_t>& source)
|
||||||
|
{
|
||||||
|
return wStringToMultibyte(destination, source.c_str(), (u32)source.size());
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Same as multibyteToWString, but the other way around
|
||||||
|
static inline size_t wStringToMultibyte(string<c8>& destination, const wchar_t* source)
|
||||||
|
{
|
||||||
|
const u32 s = source ? (u32)wcslen(source) : 0;
|
||||||
|
return wStringToMultibyte(destination, source, s);
|
||||||
|
}
|
||||||
|
|
||||||
|
//! Same as multibyteToWString, but the other way around
|
||||||
|
static size_t wStringToMultibyte(string<c8>& destination, const wchar_t* source, u32 sourceSize)
|
||||||
|
{
|
||||||
|
if ( sourceSize )
|
||||||
|
{
|
||||||
|
destination.str.resize(sizeof(wchar_t)*sourceSize+1);
|
||||||
|
#if defined(_MSC_VER)
|
||||||
|
#pragma warning(push)
|
||||||
|
#pragma warning(disable: 4996) // 'wcstombs': This function or variable may be unsafe. Consider using wcstombs_s instead.
|
||||||
|
#endif
|
||||||
|
const size_t written = wcstombs(&destination[0], source, destination.size());
|
||||||
#if defined(_MSC_VER)
|
#if defined(_MSC_VER)
|
||||||
#pragma warning(pop)
|
#pragma warning(pop)
|
||||||
#endif
|
#endif
|
||||||
@ -965,32 +1022,8 @@ inline size_t multibyteToWString(stringw& destination, const core::stringc& sour
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
inline size_t utf8ToWString(stringw &destination, const char *source)
|
|
||||||
{
|
|
||||||
std::wstring_convert<std::codecvt_utf8<wchar_t>> conv;
|
|
||||||
destination = conv.from_bytes(source);
|
|
||||||
return destination.size();
|
|
||||||
}
|
|
||||||
|
|
||||||
inline size_t utf8ToWString(stringw &destination, const stringc &source)
|
|
||||||
{
|
|
||||||
return utf8ToWString(destination, source.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
inline size_t wStringToUTF8(stringc &destination, const wchar_t *source)
|
|
||||||
{
|
|
||||||
std::wstring_convert<std::codecvt_utf8<wchar_t>> conv;
|
|
||||||
destination = conv.to_bytes(source);
|
|
||||||
return destination.size();
|
|
||||||
}
|
|
||||||
|
|
||||||
inline size_t wStringToUTF8(stringc &destination, const stringw &source)
|
|
||||||
{
|
|
||||||
return wStringToUTF8(destination, source.c_str());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_TYPES_H_INCLUDED__
|
||||||
|
#define __IRR_TYPES_H_INCLUDED__
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
|
|
||||||
@ -119,3 +120,4 @@ code like 'code', but some generate warnings so we use this macro here */
|
|||||||
((irr::u32)(irr::u8)(c0) | ((irr::u32)(irr::u8)(c1) << 8) | \
|
((irr::u32)(irr::u8)(c0) | ((irr::u32)(irr::u8)(c1) << 8) | \
|
||||||
((irr::u32)(irr::u8)(c2) << 16) | ((irr::u32)(irr::u8)(c3) << 24 ))
|
((irr::u32)(irr::u8)(c2) << 16) | ((irr::u32)(irr::u8)(c3) << 24 ))
|
||||||
|
|
||||||
|
#endif // __IRR_TYPES_H_INCLUDED__
|
||||||
|
3611
include/irrUString.h
Normal file
3611
include/irrUString.h
Normal file
File diff suppressed because it is too large
Load Diff
@ -30,8 +30,10 @@
|
|||||||
#define __IRRLICHT_H_INCLUDED__
|
#define __IRRLICHT_H_INCLUDED__
|
||||||
|
|
||||||
#include "aabbox3d.h"
|
#include "aabbox3d.h"
|
||||||
|
#include "CIndexBuffer.h"
|
||||||
#include "CMeshBuffer.h"
|
#include "CMeshBuffer.h"
|
||||||
#include "coreutil.h"
|
#include "coreutil.h"
|
||||||
|
#include "CVertexBuffer.h"
|
||||||
#include "dimension2d.h"
|
#include "dimension2d.h"
|
||||||
#include "ECullingTypes.h"
|
#include "ECullingTypes.h"
|
||||||
#include "EDebugSceneTypes.h"
|
#include "EDebugSceneTypes.h"
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_LINE_2D_H_INCLUDED__
|
||||||
|
#define __IRR_LINE_2D_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrTypes.h"
|
#include "irrTypes.h"
|
||||||
#include "vector2d.h"
|
#include "vector2d.h"
|
||||||
@ -65,7 +66,7 @@ class line2d
|
|||||||
vector2d<T> getVector() const { return vector2d<T>( end.X - start.X, end.Y - start.Y); }
|
vector2d<T> getVector() const { return vector2d<T>( end.X - start.X, end.Y - start.Y); }
|
||||||
|
|
||||||
/*! Check if this segment intersects another segment,
|
/*! Check if this segment intersects another segment,
|
||||||
or if segments are coincident (colinear). */
|
or if segments are coincindent (colinear). */
|
||||||
bool intersectAsSegments( const line2d<T>& other) const
|
bool intersectAsSegments( const line2d<T>& other) const
|
||||||
{
|
{
|
||||||
// Taken from:
|
// Taken from:
|
||||||
@ -82,7 +83,7 @@ class line2d
|
|||||||
if (o1 != o2 && o3 != o4)
|
if (o1 != o2 && o3 != o4)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
// Special Cases to check if segments are colinear
|
// Special Cases to check if segments are coolinear
|
||||||
if (o1 == 0 && other.start.isBetweenPoints( start, end)) return true;
|
if (o1 == 0 && other.start.isBetweenPoints( start, end)) return true;
|
||||||
if (o2 == 0 && other.end.isBetweenPoints( start, end)) return true;
|
if (o2 == 0 && other.end.isBetweenPoints( start, end)) return true;
|
||||||
if (o3 == 0 && start.isBetweenPoints( other.start, other.end)) return true;
|
if (o3 == 0 && start.isBetweenPoints( other.start, other.end)) return true;
|
||||||
@ -354,4 +355,5 @@ class line2d
|
|||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_LINE_3D_H_INCLUDED__
|
||||||
|
#define __IRR_LINE_3D_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrTypes.h"
|
#include "irrTypes.h"
|
||||||
#include "vector3d.h"
|
#include "vector3d.h"
|
||||||
@ -139,4 +140,5 @@ class line3d
|
|||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_MATRIX_H_INCLUDED__
|
||||||
|
#define __IRR_MATRIX_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrMath.h"
|
#include "irrMath.h"
|
||||||
#include "vector3d.h"
|
#include "vector3d.h"
|
||||||
@ -2056,7 +2057,7 @@ namespace core
|
|||||||
core::vector3df v(vs);
|
core::vector3df v(vs);
|
||||||
v.normalize();
|
v.normalize();
|
||||||
|
|
||||||
// cosine angle
|
// cosinus angle
|
||||||
T ca = f.dotProduct(t);
|
T ca = f.dotProduct(t);
|
||||||
|
|
||||||
core::vector3df vt(v * (1 - ca));
|
core::vector3df vt(v * (1 - ca));
|
||||||
@ -2117,7 +2118,7 @@ namespace core
|
|||||||
// axis multiplication by sin
|
// axis multiplication by sin
|
||||||
const core::vector3df vs = look.crossProduct(from);
|
const core::vector3df vs = look.crossProduct(from);
|
||||||
|
|
||||||
// cosine angle
|
// cosinus angle
|
||||||
const f32 ca = from.dotProduct(look);
|
const f32 ca = from.dotProduct(look);
|
||||||
|
|
||||||
core::vector3df vt(up * (1.f - ca));
|
core::vector3df vt(up * (1.f - ca));
|
||||||
@ -2362,4 +2363,5 @@ namespace core
|
|||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -11,7 +11,7 @@
|
|||||||
#include <KHR/khrplatform.h>
|
#include <KHR/khrplatform.h>
|
||||||
|
|
||||||
#ifndef APIENTRY
|
#ifndef APIENTRY
|
||||||
#define APIENTRY KHRONOS_APIENTRY
|
#define APIENTRY
|
||||||
#endif
|
#endif
|
||||||
#ifndef APIENTRYP
|
#ifndef APIENTRYP
|
||||||
#define APIENTRYP APIENTRY *
|
#define APIENTRYP APIENTRY *
|
||||||
@ -705,6 +705,7 @@ private:
|
|||||||
typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSINDIRECTCOUNTPROC_MT) (GLenum mode, const void * indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride);
|
typedef void (APIENTRYP PFNGLMULTIDRAWARRAYSINDIRECTCOUNTPROC_MT) (GLenum mode, const void * indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride);
|
||||||
typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSINDIRECTCOUNTPROC_MT) (GLenum mode, GLenum type, const void * indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride);
|
typedef void (APIENTRYP PFNGLMULTIDRAWELEMENTSINDIRECTCOUNTPROC_MT) (GLenum mode, GLenum type, const void * indirect, GLintptr drawcount, GLsizei maxdrawcount, GLsizei stride);
|
||||||
typedef void (APIENTRYP PFNGLPOLYGONOFFSETCLAMPPROC_MT) (GLfloat factor, GLfloat units, GLfloat clamp);
|
typedef void (APIENTRYP PFNGLPOLYGONOFFSETCLAMPPROC_MT) (GLfloat factor, GLfloat units, GLfloat clamp);
|
||||||
|
typedef void (APIENTRYP PFNGLGENPERFMONITORSEXPROC_MT) (GLsizei n, GLuint * monitors);
|
||||||
typedef void (APIENTRYP PFNGLPRIMITIVEBOUNDINGBOXPROC_MT) (GLfloat minX, GLfloat minY, GLfloat minZ, GLfloat minW, GLfloat maxX, GLfloat maxY, GLfloat maxZ, GLfloat maxW);
|
typedef void (APIENTRYP PFNGLPRIMITIVEBOUNDINGBOXPROC_MT) (GLfloat minX, GLfloat minY, GLfloat minZ, GLfloat minW, GLfloat maxX, GLfloat maxY, GLfloat maxZ, GLfloat maxW);
|
||||||
typedef GLuint64 (APIENTRYP PFNGLGETTEXTUREHANDLEPROC_MT) (GLuint texture);
|
typedef GLuint64 (APIENTRYP PFNGLGETTEXTUREHANDLEPROC_MT) (GLuint texture);
|
||||||
typedef GLuint64 (APIENTRYP PFNGLGETTEXTURESAMPLERHANDLEPROC_MT) (GLuint texture, GLuint sampler);
|
typedef GLuint64 (APIENTRYP PFNGLGETTEXTURESAMPLERHANDLEPROC_MT) (GLuint texture, GLuint sampler);
|
||||||
@ -780,9 +781,9 @@ public:
|
|||||||
// Call this once after creating the context.
|
// Call this once after creating the context.
|
||||||
void LoadAllProcedures(irr::video::IContextManager *cmgr);
|
void LoadAllProcedures(irr::video::IContextManager *cmgr);
|
||||||
// Check if an extension is supported.
|
// Check if an extension is supported.
|
||||||
inline bool IsExtensionPresent(const std::string &ext) const
|
inline bool IsExtensionPresent(const std::string &ext)
|
||||||
{
|
{
|
||||||
return extensions.count(ext) > 0;
|
return extensions.find(ext) != extensions.end();
|
||||||
}
|
}
|
||||||
|
|
||||||
PFNGLCULLFACEPROC_MT CullFace = NULL;
|
PFNGLCULLFACEPROC_MT CullFace = NULL;
|
||||||
@ -1435,6 +1436,7 @@ public:
|
|||||||
PFNGLMULTIDRAWARRAYSINDIRECTCOUNTPROC_MT MultiDrawArraysIndirectCount = NULL;
|
PFNGLMULTIDRAWARRAYSINDIRECTCOUNTPROC_MT MultiDrawArraysIndirectCount = NULL;
|
||||||
PFNGLMULTIDRAWELEMENTSINDIRECTCOUNTPROC_MT MultiDrawElementsIndirectCount = NULL;
|
PFNGLMULTIDRAWELEMENTSINDIRECTCOUNTPROC_MT MultiDrawElementsIndirectCount = NULL;
|
||||||
PFNGLPOLYGONOFFSETCLAMPPROC_MT PolygonOffsetClamp = NULL;
|
PFNGLPOLYGONOFFSETCLAMPPROC_MT PolygonOffsetClamp = NULL;
|
||||||
|
PFNGLGENPERFMONITORSEXPROC_MT GenPerfMonitorsEX = NULL;
|
||||||
PFNGLPRIMITIVEBOUNDINGBOXPROC_MT PrimitiveBoundingBox = NULL;
|
PFNGLPRIMITIVEBOUNDINGBOXPROC_MT PrimitiveBoundingBox = NULL;
|
||||||
PFNGLGETTEXTUREHANDLEPROC_MT GetTextureHandle = NULL;
|
PFNGLGETTEXTUREHANDLEPROC_MT GetTextureHandle = NULL;
|
||||||
PFNGLGETTEXTURESAMPLERHANDLEPROC_MT GetTextureSamplerHandle = NULL;
|
PFNGLGETTEXTURESAMPLERHANDLEPROC_MT GetTextureSamplerHandle = NULL;
|
||||||
@ -3018,16 +3020,6 @@ public:
|
|||||||
static constexpr const GLenum TEXTURE_SRGB_DECODE = 0x8A48;
|
static constexpr const GLenum TEXTURE_SRGB_DECODE = 0x8A48;
|
||||||
static constexpr const GLenum DECODE = 0x8A49;
|
static constexpr const GLenum DECODE = 0x8A49;
|
||||||
static constexpr const GLenum SKIP_DECODE = 0x8A4A;
|
static constexpr const GLenum SKIP_DECODE = 0x8A4A;
|
||||||
static constexpr const GLenum ALPHA8 = 0x803C;
|
|
||||||
static constexpr const GLenum LUMINANCE8 = 0x8040;
|
|
||||||
static constexpr const GLenum LUMINANCE8_ALPHA8 = 0x8045;
|
|
||||||
static constexpr const GLenum ALPHA32F = 0x8816;
|
|
||||||
static constexpr const GLenum LUMINANCE32F = 0x8818;
|
|
||||||
static constexpr const GLenum LUMINANCE_ALPHA32F = 0x8819;
|
|
||||||
static constexpr const GLenum ALPHA16F = 0x881C;
|
|
||||||
static constexpr const GLenum LUMINANCE16F = 0x881E;
|
|
||||||
static constexpr const GLenum LUMINANCE_ALPHA16F = 0x881F;
|
|
||||||
static constexpr const GLenum BGRA8 = 0x93A1;
|
|
||||||
static constexpr const GLenum INCLUSIVE = 0x8F10;
|
static constexpr const GLenum INCLUSIVE = 0x8F10;
|
||||||
static constexpr const GLenum EXCLUSIVE = 0x8F11;
|
static constexpr const GLenum EXCLUSIVE = 0x8F11;
|
||||||
static constexpr const GLenum WINDOW_RECTANGLE = 0x8F12;
|
static constexpr const GLenum WINDOW_RECTANGLE = 0x8F12;
|
||||||
@ -3052,7 +3044,10 @@ public:
|
|||||||
static constexpr const GLenum GEOMETRY_LINKED_VERTICES_OUT = 0x8916;
|
static constexpr const GLenum GEOMETRY_LINKED_VERTICES_OUT = 0x8916;
|
||||||
static constexpr const GLenum GEOMETRY_LINKED_INPUT_TYPE = 0x8917;
|
static constexpr const GLenum GEOMETRY_LINKED_INPUT_TYPE = 0x8917;
|
||||||
static constexpr const GLenum GEOMETRY_LINKED_OUTPUT_TYPE = 0x8918;
|
static constexpr const GLenum GEOMETRY_LINKED_OUTPUT_TYPE = 0x8918;
|
||||||
|
static constexpr const GLenum ALPHA8 = 0x803C;
|
||||||
static constexpr const GLenum LUMINANCE4_ALPHA4 = 0x8043;
|
static constexpr const GLenum LUMINANCE4_ALPHA4 = 0x8043;
|
||||||
|
static constexpr const GLenum LUMINANCE8_ALPHA8 = 0x8045;
|
||||||
|
static constexpr const GLenum LUMINANCE8 = 0x8040;
|
||||||
static constexpr const GLenum FRAMEBUFFER_ATTACHMENT_TEXTURE_3D_ZOFFSET = 0x8CD4;
|
static constexpr const GLenum FRAMEBUFFER_ATTACHMENT_TEXTURE_3D_ZOFFSET = 0x8CD4;
|
||||||
static constexpr const GLenum COMPRESSED_RGBA_ASTC_3x3x3 = 0x93C0;
|
static constexpr const GLenum COMPRESSED_RGBA_ASTC_3x3x3 = 0x93C0;
|
||||||
static constexpr const GLenum COMPRESSED_RGBA_ASTC_4x3x3 = 0x93C1;
|
static constexpr const GLenum COMPRESSED_RGBA_ASTC_4x3x3 = 0x93C1;
|
||||||
@ -3075,6 +3070,7 @@ public:
|
|||||||
static constexpr const GLenum COMPRESSED_SRGB8_ALPHA8_ASTC_6x6x5 = 0x93E8;
|
static constexpr const GLenum COMPRESSED_SRGB8_ALPHA8_ASTC_6x6x5 = 0x93E8;
|
||||||
static constexpr const GLenum COMPRESSED_SRGB8_ALPHA8_ASTC_6x6x6 = 0x93E9;
|
static constexpr const GLenum COMPRESSED_SRGB8_ALPHA8_ASTC_6x6x6 = 0x93E9;
|
||||||
static constexpr const GLenum INT_10_10_10_2 = 0x8DF7;
|
static constexpr const GLenum INT_10_10_10_2 = 0x8DF7;
|
||||||
|
static constexpr const GLenum BGRA8 = 0x93A1;
|
||||||
static constexpr const GLenum MALI_PROGRAM_BINARY_ARM = 0x8F61;
|
static constexpr const GLenum MALI_PROGRAM_BINARY_ARM = 0x8F61;
|
||||||
static constexpr const GLenum MALI_SHADER_BINARY_ARM = 0x8F60;
|
static constexpr const GLenum MALI_SHADER_BINARY_ARM = 0x8F60;
|
||||||
static constexpr const GLenum FETCH_PER_SAMPLE_ARM = 0x8F65;
|
static constexpr const GLenum FETCH_PER_SAMPLE_ARM = 0x8F65;
|
||||||
@ -3084,37 +3080,8 @@ public:
|
|||||||
static constexpr const GLenum SMAPHS_PROGRAM_BINARY_DMP = 0x9252;
|
static constexpr const GLenum SMAPHS_PROGRAM_BINARY_DMP = 0x9252;
|
||||||
static constexpr const GLenum DMP_PROGRAM_BINARY_DMP = 0x9253;
|
static constexpr const GLenum DMP_PROGRAM_BINARY_DMP = 0x9253;
|
||||||
static constexpr const GLenum SHADER_BINARY_DMP = 0x9250;
|
static constexpr const GLenum SHADER_BINARY_DMP = 0x9250;
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION = 0x96C0;
|
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_NONE = 0x96C1;
|
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_DEFAULT = 0x96C2;
|
|
||||||
static constexpr const GLenum SAMPLER_EXTERNAL_2D_Y2Y = 0x8BE7;
|
static constexpr const GLenum SAMPLER_EXTERNAL_2D_Y2Y = 0x8BE7;
|
||||||
static constexpr const GLenum GPU_DISJOINT = 0x8FBB;
|
static constexpr const GLenum GPU_DISJOINT = 0x8FBB;
|
||||||
static constexpr const GLenum SHADING_RATE_1X1_PIXELS = 0x96A6;
|
|
||||||
static constexpr const GLenum SHADING_RATE_1X2_PIXELS = 0x96A7;
|
|
||||||
static constexpr const GLenum SHADING_RATE_2X1_PIXELS = 0x96A8;
|
|
||||||
static constexpr const GLenum SHADING_RATE_2X2_PIXELS = 0x96A9;
|
|
||||||
static constexpr const GLenum SHADING_RATE_1X4_PIXELS = 0x96AA;
|
|
||||||
static constexpr const GLenum SHADING_RATE_4X1_PIXELS = 0x96AB;
|
|
||||||
static constexpr const GLenum SHADING_RATE_4X2_PIXELS = 0x96AC;
|
|
||||||
static constexpr const GLenum SHADING_RATE_2X4_PIXELS = 0x96AD;
|
|
||||||
static constexpr const GLenum SHADING_RATE_4X4_PIXELS = 0x96AE;
|
|
||||||
static constexpr const GLenum SHADING_RATE = 0x96D0;
|
|
||||||
static constexpr const GLenum SHADING_RATE_ATTACHMENT = 0x96D1;
|
|
||||||
static constexpr const GLenum FRAGMENT_SHADING_RATE_COMBINER_OP_KEEP = 0x96D2;
|
|
||||||
static constexpr const GLenum FRAGMENT_SHADING_RATE_COMBINER_OP_REPLACE = 0x96D3;
|
|
||||||
static constexpr const GLenum FRAGMENT_SHADING_RATE_COMBINER_OP_MIN = 0x96D4;
|
|
||||||
static constexpr const GLenum FRAGMENT_SHADING_RATE_COMBINER_OP_MAX = 0x96D5;
|
|
||||||
static constexpr const GLenum FRAGMENT_SHADING_RATE_COMBINER_OP_MUL = 0x96D6;
|
|
||||||
static constexpr const GLenum MIN_FRAGMENT_SHADING_RATE_ATTACHMENT_TEXEL_WIDTH = 0x96D7;
|
|
||||||
static constexpr const GLenum MAX_FRAGMENT_SHADING_RATE_ATTACHMENT_TEXEL_WIDTH = 0x96D8;
|
|
||||||
static constexpr const GLenum MIN_FRAGMENT_SHADING_RATE_ATTACHMENT_TEXEL_HEIGHT = 0x96D9;
|
|
||||||
static constexpr const GLenum MAX_FRAGMENT_SHADING_RATE_ATTACHMENT_TEXEL_HEIGHT = 0x96DA;
|
|
||||||
static constexpr const GLenum MAX_FRAGMENT_SHADING_RATE_ATTACHMENT_TEXEL_ASPECT_RATIO = 0x96DB;
|
|
||||||
static constexpr const GLenum MAX_FRAGMENT_SHADING_RATE_ATTACHMENT_LAYERS = 0x96DC;
|
|
||||||
static constexpr const GLenum FRAGMENT_SHADING_RATE_WITH_SHADER_DEPTH_STENCIL_WRITES_SUPPORTED = 0x96DD;
|
|
||||||
static constexpr const GLenum FRAGMENT_SHADING_RATE_WITH_SAMPLE_MASK_SUPPORTED = 0x96DE;
|
|
||||||
static constexpr const GLenum FRAGMENT_SHADING_RATE_ATTACHMENT_WITH_DEFAULT_FRAMEBUFFER_SUPPORTED = 0x96DF;
|
|
||||||
static constexpr const GLenum FRAGMENT_SHADING_RATE_NON_TRIVIAL_COMBINERS_SUPPORTED = 0x8F6F;
|
|
||||||
static constexpr const GLenum TEXTURE_TILING = 0x9580;
|
static constexpr const GLenum TEXTURE_TILING = 0x9580;
|
||||||
static constexpr const GLenum DEDICATED_MEMORY_OBJECT = 0x9581;
|
static constexpr const GLenum DEDICATED_MEMORY_OBJECT = 0x9581;
|
||||||
static constexpr const GLenum PROTECTED_MEMORY_OBJECT = 0x959B;
|
static constexpr const GLenum PROTECTED_MEMORY_OBJECT = 0x959B;
|
||||||
@ -3169,19 +3136,12 @@ public:
|
|||||||
static constexpr const GLenum COMPRESSED_SRGB_ALPHA_S3TC_DXT3 = 0x8C4E;
|
static constexpr const GLenum COMPRESSED_SRGB_ALPHA_S3TC_DXT3 = 0x8C4E;
|
||||||
static constexpr const GLenum COMPRESSED_SRGB_ALPHA_S3TC_DXT5 = 0x8C4F;
|
static constexpr const GLenum COMPRESSED_SRGB_ALPHA_S3TC_DXT5 = 0x8C4F;
|
||||||
static constexpr const GLenum TEXTURE_FORMAT_SRGB_OVERRIDE = 0x8FBF;
|
static constexpr const GLenum TEXTURE_FORMAT_SRGB_OVERRIDE = 0x8FBF;
|
||||||
static constexpr const GLenum NUM_SURFACE_COMPRESSION_FIXED_RATES = 0x8F6E;
|
static constexpr const GLenum ALPHA32F = 0x8816;
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_1BPC = 0x96C4;
|
static constexpr const GLenum LUMINANCE32F = 0x8818;
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_2BPC = 0x96C5;
|
static constexpr const GLenum LUMINANCE_ALPHA32F = 0x8819;
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_3BPC = 0x96C6;
|
static constexpr const GLenum ALPHA16F = 0x881C;
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_4BPC = 0x96C7;
|
static constexpr const GLenum LUMINANCE16F = 0x881E;
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_5BPC = 0x96C8;
|
static constexpr const GLenum LUMINANCE_ALPHA16F = 0x881F;
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_6BPC = 0x96C9;
|
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_7BPC = 0x96CA;
|
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_8BPC = 0x96CB;
|
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_9BPC = 0x96CC;
|
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_10BPC = 0x96CD;
|
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_11BPC = 0x96CE;
|
|
||||||
static constexpr const GLenum SURFACE_COMPRESSION_FIXED_RATE_12BPC = 0x96CF;
|
|
||||||
static constexpr const GLenum GCCSO_SHADER_BINARY_FJ = 0x9260;
|
static constexpr const GLenum GCCSO_SHADER_BINARY_FJ = 0x9260;
|
||||||
static constexpr const GLenum STATE_RESTORE = 0x8BDC;
|
static constexpr const GLenum STATE_RESTORE = 0x8BDC;
|
||||||
static constexpr const GLenum SHADER_BINARY_VIV = 0x8FC4;
|
static constexpr const GLenum SHADER_BINARY_VIV = 0x8FC4;
|
||||||
@ -3191,5 +3151,5 @@ public:
|
|||||||
static constexpr const GLenum NONE = 0;
|
static constexpr const GLenum NONE = 0;
|
||||||
};
|
};
|
||||||
|
|
||||||
// Global GL procedures object.
|
//Global GL procedures object.
|
||||||
IRRLICHT_API extern OpenGLProcedures GL;
|
IRRLICHT_API extern OpenGLProcedures GL;
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine" and the "irrXML" project.
|
// This file is part of the "Irrlicht Engine" and the "irrXML" project.
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_PATH_H_INCLUDED__
|
||||||
|
#define __IRR_PATH_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrString.h"
|
#include "irrString.h"
|
||||||
|
|
||||||
@ -86,3 +87,4 @@ private:
|
|||||||
} // io
|
} // io
|
||||||
} // irr
|
} // irr
|
||||||
|
|
||||||
|
#endif // __IRR_PATH_H_INCLUDED__
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_PLANE_3D_H_INCLUDED__
|
||||||
|
#define __IRR_PLANE_3D_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrMath.h"
|
#include "irrMath.h"
|
||||||
#include "vector3d.h"
|
#include "vector3d.h"
|
||||||
@ -240,4 +241,5 @@ typedef plane3d<s32> plane3di;
|
|||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -5,7 +5,8 @@
|
|||||||
//! As of Irrlicht 1.6, position2d is a synonym for vector2d.
|
//! As of Irrlicht 1.6, position2d is a synonym for vector2d.
|
||||||
/** You should consider position2d to be deprecated, and use vector2d by preference. */
|
/** You should consider position2d to be deprecated, and use vector2d by preference. */
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_POSITION_H_INCLUDED__
|
||||||
|
#define __IRR_POSITION_H_INCLUDED__
|
||||||
|
|
||||||
#include "vector2d.h"
|
#include "vector2d.h"
|
||||||
|
|
||||||
@ -27,4 +28,5 @@ typedef vector2d<s32> position2di;
|
|||||||
// ...and use a #define to catch the rest, for (e.g.) position2d<f64>
|
// ...and use a #define to catch the rest, for (e.g.) position2d<f64>
|
||||||
#define position2d vector2d
|
#define position2d vector2d
|
||||||
|
|
||||||
|
#endif // __IRR_POSITION_H_INCLUDED__
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_QUATERNION_H_INCLUDED__
|
||||||
|
#define __IRR_QUATERNION_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrTypes.h"
|
#include "irrTypes.h"
|
||||||
#include "irrMath.h"
|
#include "irrMath.h"
|
||||||
@ -719,8 +720,6 @@ inline core::quaternion& quaternion::makeIdentity()
|
|||||||
inline core::quaternion& quaternion::rotationFromTo(const vector3df& from, const vector3df& to)
|
inline core::quaternion& quaternion::rotationFromTo(const vector3df& from, const vector3df& to)
|
||||||
{
|
{
|
||||||
// Based on Stan Melax's article in Game Programming Gems
|
// Based on Stan Melax's article in Game Programming Gems
|
||||||
// Optimized by Robert Eisele: https://raw.org/proof/quaternion-from-two-vectors
|
|
||||||
|
|
||||||
// Copy, since cannot modify local
|
// Copy, since cannot modify local
|
||||||
vector3df v0 = from;
|
vector3df v0 = from;
|
||||||
vector3df v1 = to;
|
vector3df v1 = to;
|
||||||
@ -745,12 +744,15 @@ inline core::quaternion& quaternion::rotationFromTo(const vector3df& from, const
|
|||||||
return set(axis.X, axis.Y, axis.Z, 0).normalize();
|
return set(axis.X, axis.Y, axis.Z, 0).normalize();
|
||||||
}
|
}
|
||||||
|
|
||||||
const vector3df c = v0.crossProduct(v1);
|
const f32 s = sqrtf( (1+d)*2 ); // optimize inv_sqrt
|
||||||
return set(c.X, c.Y, c.Z, 1 + d).normalize();
|
const f32 invs = 1.f / s;
|
||||||
|
const vector3df c = v0.crossProduct(v1)*invs;
|
||||||
|
return set(c.X, c.Y, c.Z, s * 0.5f).normalize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_RECT_H_INCLUDED__
|
||||||
|
#define __IRR_RECT_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrTypes.h"
|
#include "irrTypes.h"
|
||||||
#include "dimension2d.h"
|
#include "dimension2d.h"
|
||||||
@ -283,4 +284,5 @@ namespace core
|
|||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_TRIANGLE_3D_H_INCLUDED__
|
||||||
|
#define __IRR_TRIANGLE_3D_H_INCLUDED__
|
||||||
|
|
||||||
#include "vector3d.h"
|
#include "vector3d.h"
|
||||||
#include "line3d.h"
|
#include "line3d.h"
|
||||||
@ -273,4 +274,5 @@ namespace core
|
|||||||
} // end namespace core
|
} // end namespace core
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_POINT_2D_H_INCLUDED__
|
||||||
|
#define __IRR_POINT_2D_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrMath.h"
|
#include "irrMath.h"
|
||||||
#include "dimension2d.h"
|
#include "dimension2d.h"
|
||||||
@ -75,47 +76,47 @@ public:
|
|||||||
return *(&X+index);
|
return *(&X+index);
|
||||||
}
|
}
|
||||||
|
|
||||||
//! sort in order X, Y.
|
//! sort in order X, Y. Equality with rounding tolerance.
|
||||||
bool operator<=(const vector2d<T>&other) const
|
bool operator<=(const vector2d<T>&other) const
|
||||||
{
|
{
|
||||||
return !(*this > other);
|
return (X<other.X || core::equals(X, other.X)) ||
|
||||||
|
(core::equals(X, other.X) && (Y<other.Y || core::equals(Y, other.Y)));
|
||||||
}
|
}
|
||||||
|
|
||||||
//! sort in order X, Y.
|
//! sort in order X, Y. Equality with rounding tolerance.
|
||||||
bool operator>=(const vector2d<T>&other) const
|
bool operator>=(const vector2d<T>&other) const
|
||||||
{
|
{
|
||||||
return !(*this < other);
|
return (X>other.X || core::equals(X, other.X)) ||
|
||||||
|
(core::equals(X, other.X) && (Y>other.Y || core::equals(Y, other.Y)));
|
||||||
}
|
}
|
||||||
|
|
||||||
//! sort in order X, Y.
|
//! sort in order X, Y. Difference must be above rounding tolerance.
|
||||||
bool operator<(const vector2d<T>&other) const
|
bool operator<(const vector2d<T>&other) const
|
||||||
{
|
{
|
||||||
return X < other.X || (X == other.X && Y < other.Y);
|
return (X<other.X && !core::equals(X, other.X)) ||
|
||||||
|
(core::equals(X, other.X) && Y<other.Y && !core::equals(Y, other.Y));
|
||||||
}
|
}
|
||||||
|
|
||||||
//! sort in order X, Y.
|
//! sort in order X, Y. Difference must be above rounding tolerance.
|
||||||
bool operator>(const vector2d<T>&other) const
|
bool operator>(const vector2d<T>&other) const
|
||||||
{
|
{
|
||||||
return X > other.X || (X == other.X && Y > other.Y);
|
return (X>other.X && !core::equals(X, other.X)) ||
|
||||||
|
(core::equals(X, other.X) && Y>other.Y && !core::equals(Y, other.Y));
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator==(const vector2d<T>& other) const {
|
bool operator==(const vector2d<T>& other) const { return equals(other); }
|
||||||
return X == other.X && Y == other.Y;
|
bool operator!=(const vector2d<T>& other) const { return !equals(other); }
|
||||||
}
|
|
||||||
|
|
||||||
bool operator!=(const vector2d<T>& other) const {
|
|
||||||
return !(*this == other);
|
|
||||||
}
|
|
||||||
|
|
||||||
// functions
|
// functions
|
||||||
|
|
||||||
//! Checks if this vector equals the other one.
|
//! Checks if this vector equals the other one.
|
||||||
/** Takes floating point rounding errors into account.
|
/** Takes floating point rounding errors into account.
|
||||||
\param other Vector to compare with.
|
\param other Vector to compare with.
|
||||||
|
\param tolerance Epsilon value for both - comparing X and Y.
|
||||||
\return True if the two vector are (almost) equal, else false. */
|
\return True if the two vector are (almost) equal, else false. */
|
||||||
bool equals(const vector2d<T>& other) const
|
bool equals(const vector2d<T>& other, const T tolerance = (T)ROUNDING_ERROR_f32 ) const
|
||||||
{
|
{
|
||||||
return core::equals(X, other.X) && core::equals(Y, other.Y);
|
return core::equals(X, other.X, tolerance) && core::equals(Y, other.Y, tolerance);
|
||||||
}
|
}
|
||||||
|
|
||||||
vector2d<T>& set(T nx, T ny) {X=nx; Y=ny; return *this; }
|
vector2d<T>& set(T nx, T ny) {X=nx; Y=ny; return *this; }
|
||||||
@ -142,7 +143,7 @@ public:
|
|||||||
bool nearlyParallel( const vector2d<T> & other, const T factor = relativeErrorFactor<T>()) const
|
bool nearlyParallel( const vector2d<T> & other, const T factor = relativeErrorFactor<T>()) const
|
||||||
{
|
{
|
||||||
// https://eagergames.wordpress.com/2017/04/01/fast-parallel-lines-and-vectors-test/
|
// https://eagergames.wordpress.com/2017/04/01/fast-parallel-lines-and-vectors-test/
|
||||||
// if a || b then a.x/a.y = b.x/b.y (similar triangles)
|
// if a || b then a.x/a.y = b.x/b.y (similiar triangles)
|
||||||
// if a || b then either both x are 0 or both y are 0.
|
// if a || b then either both x are 0 or both y are 0.
|
||||||
|
|
||||||
return equalsRelative( X*other.Y, other.X* Y, factor)
|
return equalsRelative( X*other.Y, other.X* Y, factor)
|
||||||
@ -431,4 +432,5 @@ struct hash<irr::core::vector2d<T> >
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
@ -2,7 +2,8 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
#pragma once
|
#ifndef __IRR_POINT_3D_H_INCLUDED__
|
||||||
|
#define __IRR_POINT_3D_H_INCLUDED__
|
||||||
|
|
||||||
#include "irrMath.h"
|
#include "irrMath.h"
|
||||||
|
|
||||||
@ -68,51 +69,57 @@ namespace core
|
|||||||
return *(&X+index);
|
return *(&X+index);
|
||||||
}
|
}
|
||||||
|
|
||||||
//! sort in order X, Y, Z.
|
//! sort in order X, Y, Z. Equality with rounding tolerance.
|
||||||
bool operator<=(const vector3d<T>&other) const
|
bool operator<=(const vector3d<T>&other) const
|
||||||
{
|
{
|
||||||
return !(*this > other);
|
return (X<other.X || core::equals(X, other.X)) ||
|
||||||
|
(core::equals(X, other.X) && (Y<other.Y || core::equals(Y, other.Y))) ||
|
||||||
|
(core::equals(X, other.X) && core::equals(Y, other.Y) && (Z<other.Z || core::equals(Z, other.Z)));
|
||||||
}
|
}
|
||||||
|
|
||||||
//! sort in order X, Y, Z.
|
//! sort in order X, Y, Z. Equality with rounding tolerance.
|
||||||
bool operator>=(const vector3d<T>&other) const
|
bool operator>=(const vector3d<T>&other) const
|
||||||
{
|
{
|
||||||
return !(*this < other);
|
return (X>other.X || core::equals(X, other.X)) ||
|
||||||
|
(core::equals(X, other.X) && (Y>other.Y || core::equals(Y, other.Y))) ||
|
||||||
|
(core::equals(X, other.X) && core::equals(Y, other.Y) && (Z>other.Z || core::equals(Z, other.Z)));
|
||||||
}
|
}
|
||||||
|
|
||||||
//! sort in order X, Y, Z.
|
//! sort in order X, Y, Z. Difference must be above rounding tolerance.
|
||||||
bool operator<(const vector3d<T>&other) const
|
bool operator<(const vector3d<T>&other) const
|
||||||
{
|
{
|
||||||
return X < other.X || (X == other.X && Y < other.Y) ||
|
return (X<other.X && !core::equals(X, other.X)) ||
|
||||||
(X == other.X && Y == other.Y && Z < other.Z);
|
(core::equals(X, other.X) && Y<other.Y && !core::equals(Y, other.Y)) ||
|
||||||
|
(core::equals(X, other.X) && core::equals(Y, other.Y) && Z<other.Z && !core::equals(Z, other.Z));
|
||||||
}
|
}
|
||||||
|
|
||||||
//! sort in order X, Y, Z.
|
//! sort in order X, Y, Z. Difference must be above rounding tolerance.
|
||||||
bool operator>(const vector3d<T>&other) const
|
bool operator>(const vector3d<T>&other) const
|
||||||
{
|
{
|
||||||
return X > other.X || (X == other.X && Y > other.Y) ||
|
return (X>other.X && !core::equals(X, other.X)) ||
|
||||||
(X == other.X && Y == other.Y && Z > other.Z);
|
(core::equals(X, other.X) && Y>other.Y && !core::equals(Y, other.Y)) ||
|
||||||
|
(core::equals(X, other.X) && core::equals(Y, other.Y) && Z>other.Z && !core::equals(Z, other.Z));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//! use weak float compare
|
||||||
bool operator==(const vector3d<T>& other) const
|
bool operator==(const vector3d<T>& other) const
|
||||||
{
|
{
|
||||||
return X == other.X && Y == other.Y && Z == other.Z;
|
return this->equals(other);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool operator!=(const vector3d<T>& other) const
|
bool operator!=(const vector3d<T>& other) const
|
||||||
{
|
{
|
||||||
return !(*this == other);
|
return !this->equals(other);
|
||||||
}
|
}
|
||||||
|
|
||||||
// functions
|
// functions
|
||||||
|
|
||||||
//! Checks if this vector equals the other one.
|
//! returns if this vector equals the other one, taking floating point rounding errors into account
|
||||||
/** Takes floating point rounding errors into account.
|
bool equals(const vector3d<T>& other, const T tolerance = (T)ROUNDING_ERROR_f32 ) const
|
||||||
\param other Vector to compare with.
|
|
||||||
\return True if the two vector are (almost) equal, else false. */
|
|
||||||
bool equals(const vector3d<T>& other) const
|
|
||||||
{
|
{
|
||||||
return core::equals(X, other.X) && core::equals(Y, other.Y) && core::equals(Z, other.Z);
|
return core::equals(X, other.X, tolerance) &&
|
||||||
|
core::equals(Y, other.Y, tolerance) &&
|
||||||
|
core::equals(Z, other.Z, tolerance);
|
||||||
}
|
}
|
||||||
|
|
||||||
vector3d<T>& set(const T nx, const T ny, const T nz) {X=nx; Y=ny; Z=nz; return *this;}
|
vector3d<T>& set(const T nx, const T ny, const T nz) {X=nx; Y=ny; Z=nz; return *this;}
|
||||||
@ -148,7 +155,7 @@ namespace core
|
|||||||
|
|
||||||
//! Calculates the cross product with another vector.
|
//! Calculates the cross product with another vector.
|
||||||
/** \param p Vector to multiply with.
|
/** \param p Vector to multiply with.
|
||||||
\return Cross product of this vector with p. */
|
\return Crossproduct of this vector with p. */
|
||||||
vector3d<T> crossProduct(const vector3d<T>& p) const
|
vector3d<T> crossProduct(const vector3d<T>& p) const
|
||||||
{
|
{
|
||||||
return vector3d<T>(Y * p.Z - Z * p.Y, Z * p.X - X * p.Z, X * p.Y - Y * p.X);
|
return vector3d<T>(Y * p.Z - Z * p.Y, Z * p.X - X * p.Z, X * p.Y - Y * p.X);
|
||||||
@ -200,10 +207,7 @@ namespace core
|
|||||||
}
|
}
|
||||||
|
|
||||||
//! Rotates the vector by a specified number of degrees around the Y axis and the specified center.
|
//! Rotates the vector by a specified number of degrees around the Y axis and the specified center.
|
||||||
/** CAREFUL: For historical reasons rotateXZBy uses a right-handed rotation
|
/** \param degrees Number of degrees to rotate around the Y axis.
|
||||||
(maybe to make it more similar to the 2D vector rotations which are counterclockwise).
|
|
||||||
To have this work the same way as rest of Irrlicht (nodes, matrices, other rotateBy functions) pass -1*degrees in here.
|
|
||||||
\param degrees Number of degrees to rotate around the Y axis.
|
|
||||||
\param center The center of the rotation. */
|
\param center The center of the rotation. */
|
||||||
void rotateXZBy(f64 degrees, const vector3d<T>& center=vector3d<T>())
|
void rotateXZBy(f64 degrees, const vector3d<T>& center=vector3d<T>())
|
||||||
{
|
{
|
||||||
@ -481,4 +485,5 @@ struct hash<irr::core::vector3d<T> >
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
235
irr-readme.txt
Normal file
235
irr-readme.txt
Normal file
@ -0,0 +1,235 @@
|
|||||||
|
==========================================================================
|
||||||
|
The Irrlicht Engine SDK version 1.9
|
||||||
|
==========================================================================
|
||||||
|
|
||||||
|
Welcome to the Irrlicht Engine SDK.
|
||||||
|
|
||||||
|
Content of this file:
|
||||||
|
|
||||||
|
1. Directory Structure Overview
|
||||||
|
2. How To Start
|
||||||
|
3. Requirements
|
||||||
|
4. Release Notes
|
||||||
|
5. License
|
||||||
|
6. Contact
|
||||||
|
|
||||||
|
|
||||||
|
==========================================================================
|
||||||
|
1. Directory Structure Overview
|
||||||
|
==========================================================================
|
||||||
|
|
||||||
|
You will find some directories after uncompressing the archive of the
|
||||||
|
SDK. These are:
|
||||||
|
|
||||||
|
\bin The compiled library Irrlicht.DLL and some compiled demo
|
||||||
|
and example applications, just start them to see the
|
||||||
|
Irrlicht Engine in action. Windows only.
|
||||||
|
\doc Documentation of the Irrlicht Engine.
|
||||||
|
\examples Examples and tutorials showing how to use the engine with
|
||||||
|
C++.
|
||||||
|
\include Header files to include when programming with the engine.
|
||||||
|
\lib Libs to link with your programs when using the engine.
|
||||||
|
\media Graphics and sound resources for the demo applications and
|
||||||
|
examples.
|
||||||
|
\source The source code of the Irrlicht Engine. This code is
|
||||||
|
not needed to develop applications with the engine,
|
||||||
|
but it is included to enable recompilation and
|
||||||
|
debugging, if necessary.
|
||||||
|
\tools Useful tools (with sourcecode) for the engine.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
==========================================================================
|
||||||
|
2. How to start
|
||||||
|
==========================================================================
|
||||||
|
|
||||||
|
To see the engine in action in Windows, just go to the \bin\Win32-VisualStudio
|
||||||
|
directory, and start some applications. There should also be an
|
||||||
|
application named Demo.exe which should show the most
|
||||||
|
interesting features of Irrlicht.
|
||||||
|
|
||||||
|
To start developing own applications and games with the engine take
|
||||||
|
a look at the 01.HelloWorld example in the \examples directory.
|
||||||
|
There is also a .html file with a tutorial which should be
|
||||||
|
easily comprehensible.
|
||||||
|
|
||||||
|
The Irrlicht Engine is a static lib under linux. A precompiled version can be
|
||||||
|
generated from the sources using the Makefile in source/Irrlicht. Run 'make' in
|
||||||
|
that subfolder. After this you should be able to 'make' all
|
||||||
|
example applications in /examples by calling the buildAllExamples script. You
|
||||||
|
can run the examples then from the bin folder.
|
||||||
|
|
||||||
|
It is also possible to use Irrlicht as shared object
|
||||||
|
(libIrrlicht.so.versionNumber). Use the proper makefile target for this by
|
||||||
|
running 'make sharedlib' in the source folder. See the Makefile for details.
|
||||||
|
|
||||||
|
For OSX you can find an XCode project file in source/Irrlicht/MacOSX. This will
|
||||||
|
build the libIrrlicht.a library necessary to create the apps.
|
||||||
|
|
||||||
|
==========================================================================
|
||||||
|
3. Requirements
|
||||||
|
==========================================================================
|
||||||
|
|
||||||
|
You can use one of the following compilers/IDEs to develop applications
|
||||||
|
with Irrlicht or recompile the engine. However, other compilers/IDEs may
|
||||||
|
work as well, we simply didn't test them.
|
||||||
|
|
||||||
|
* gcc 4.x
|
||||||
|
* Visual Studio 2010(10.0)-2013(12.0)
|
||||||
|
* Code::Blocks (& gcc or visual studio toolkit)
|
||||||
|
|
||||||
|
If you ever want to (re)compile the engine yourself (which means you don't
|
||||||
|
want to use the precompiled version) you need the following:
|
||||||
|
|
||||||
|
* Windows:
|
||||||
|
* Needed: PlatformSDK (which usually comes with all IDEs, download
|
||||||
|
it separately for MSVC Express 2005)
|
||||||
|
* Optional: DirectX SDK, for D3D9 support
|
||||||
|
* Optional: DirectX SDK prior to May 2006, for D3D8 support
|
||||||
|
|
||||||
|
* Linux:
|
||||||
|
* Needed: XServer with include files
|
||||||
|
* Optional: OpenGL headers and libraries (libGL.so) for OpenGL support
|
||||||
|
GLX +
|
||||||
|
XF86VidMode [package x11proto-xf86vidmode-dev] or XRandr
|
||||||
|
(X11 support libraries, the latter two for fullscreen mode)
|
||||||
|
|
||||||
|
* OSX:
|
||||||
|
* Needed: XCode and Cocoa framework
|
||||||
|
* Needed: OpenGL headers and libraries
|
||||||
|
|
||||||
|
==========================================================================
|
||||||
|
4. Release Notes
|
||||||
|
==========================================================================
|
||||||
|
|
||||||
|
Informations about changes in this new version of the engine can be
|
||||||
|
found in changes.txt.
|
||||||
|
|
||||||
|
Please note that the textures, 3D models and levels are copyright
|
||||||
|
by their authors and not covered by the Irrlicht engine license.
|
||||||
|
|
||||||
|
==========================================================================
|
||||||
|
5. License
|
||||||
|
==========================================================================
|
||||||
|
|
||||||
|
The license of the Irrlicht Engine is based on the zlib/libpng license.
|
||||||
|
Even though this license does not require you to mention that you are
|
||||||
|
using the Irrlicht Engine in your product, an acknowledgement
|
||||||
|
would be highly appreciated.
|
||||||
|
|
||||||
|
Please note that the Irrlicht Engine is based in part on the work of
|
||||||
|
the Independent JPEG Group, the zlib, and libpng. This means that if you use
|
||||||
|
the Irrlicht Engine in your product, you must acknowledge somewhere
|
||||||
|
in your documentation that you've used the IJG code and libpng. It would
|
||||||
|
also be nice to mention that you use the Irrlicht Engine and the zlib.
|
||||||
|
See the README files in the jpeglib and the zlib for
|
||||||
|
further informations.
|
||||||
|
|
||||||
|
|
||||||
|
The Irrlicht Engine License
|
||||||
|
===========================
|
||||||
|
|
||||||
|
Copyright (C) 2002-2012 Nikolaus Gebhardt
|
||||||
|
|
||||||
|
This software is provided 'as-is', without any express or implied
|
||||||
|
warranty. In no event will the authors be held liable for any damages
|
||||||
|
arising from the use of this software.
|
||||||
|
|
||||||
|
Permission is granted to anyone to use this software for any purpose,
|
||||||
|
including commercial applications, and to alter it and redistribute it
|
||||||
|
freely, subject to the following restrictions:
|
||||||
|
|
||||||
|
1. The origin of this software must not be misrepresented; you must not
|
||||||
|
claim that you wrote the original software. If you use this software
|
||||||
|
in a product, an acknowledgement in the product documentation would be
|
||||||
|
appreciated but is not required.
|
||||||
|
2. Altered source versions must be clearly marked as such, and must not be
|
||||||
|
misrepresented as being the original software.
|
||||||
|
3. This notice may not be removed or altered from any source distribution.
|
||||||
|
|
||||||
|
|
||||||
|
==========================================================================
|
||||||
|
6. Contact
|
||||||
|
==========================================================================
|
||||||
|
|
||||||
|
If you have problems, questions or suggestions, please visit the
|
||||||
|
official homepage of the Irrlicht Engine:
|
||||||
|
|
||||||
|
http://irrlicht.sourceforge.net
|
||||||
|
|
||||||
|
You will find forums, bugtrackers, patches, tutorials, and other stuff
|
||||||
|
which will help you out.
|
||||||
|
|
||||||
|
If want to contact the team of the engine, please send an email to
|
||||||
|
Nikolaus Gebhardt:
|
||||||
|
|
||||||
|
irrlicht@users.sourceforge.net
|
||||||
|
|
||||||
|
Please also not that parts of the engine have been written or contributed
|
||||||
|
by other people. Especially: (There are probably more people, sorry if I forgot one.
|
||||||
|
See http://irrlicht.sourceforge.net/author.html for more informations)
|
||||||
|
|
||||||
|
Christian Stehno (hybrid) Contribution Coordinator/Developer
|
||||||
|
Michael Zeilfelder (cutealien) Developer
|
||||||
|
Patryk Nadrowski (Nadro) Developer
|
||||||
|
Yoran Bosman (Yoran) Webserver administrator
|
||||||
|
Gareth Davidson (bitplane) Developer/ Forum admin
|
||||||
|
Thomas Alten (burningwater) Wrote the burningsvideo software rasterizer
|
||||||
|
Luke P. Hoschke (luke) Wrote the b3d loader, the new animation system, VBOs and other things
|
||||||
|
Colin MacDonald (rogerborg) All hands person
|
||||||
|
Ahmed Hilali (blindside) The shader and advanced effects man
|
||||||
|
Dean Wadsworth (varmint) OSX port maintainer and game developer
|
||||||
|
Alvaro F. Celis (afecelis) Lots of work in the community, for example video tutorials about Irrlicht, forum admin
|
||||||
|
John Goewert (Saigumi) Wrote some tutorials for the Irrlicht Engine and doing admin stuff
|
||||||
|
Jam Takes care of moderating the forums and keeps them clean from those evil spammers.
|
||||||
|
|
||||||
|
Many others (this list hasn't been updated in a while, but they are often mentioned in changes.txt)
|
||||||
|
Etienne Petitjean wrote the MacPort of the engine
|
||||||
|
Mark Jeacocke Wrote lots of helpful comments and ideas in the forums and per email.
|
||||||
|
Julio Gorg<72> Created the 'Unofficial DirectX 9.0 Driver for the Irrlicht Engine'
|
||||||
|
Andy Spurgeon Wrote the Dev-Cpp tutorial.
|
||||||
|
Andr<64> Simon Wrote the Codewarrior tutorial.
|
||||||
|
KnightToFlight Created the unoffical terrain renderer addon for the Irrlicht Engine.
|
||||||
|
Jon Pry Wrote the code to load compressed TGA files.
|
||||||
|
Matthew Couch Wrote the tokamak integration tutorial.
|
||||||
|
Max Winkel Wrote the splitscreen tutorial.
|
||||||
|
Gorgon Zola Wrote the ODE integration tutorial.
|
||||||
|
Dean P. Macri Sent in code for curved surfaces and PCX Loading.
|
||||||
|
Sirshane Made several bug fixes, sent in code for making the mouse cursor invisible in Linux.
|
||||||
|
Matthias Gall Sent in code for a spline scene node animator and reported lots of bugs.
|
||||||
|
Mario Gruber Suggested triangle fan drawing and sent in code for this.
|
||||||
|
Ariaci Spotted out a bug in the ATI driver.
|
||||||
|
Dr Andros C Bragianos Improved texture mapping in cube scene node.
|
||||||
|
Philipp Dortmann Sent in code for stencil buffer support for OpenGL.
|
||||||
|
Jerome Nichols Created the Irrlicht/Ruby interface located at irr.rubyforge.org
|
||||||
|
Vash TheStampede Sent code for missing Draw2DLine() implementations
|
||||||
|
MattyBoy XBOX support suggestions
|
||||||
|
Oliver Klems createImageFromData() method suggestion/implementation
|
||||||
|
Jox really, really a lot of bug fixes, and the LMTS file loader
|
||||||
|
Zola Quaternion method additions
|
||||||
|
Tomasz Nowakowski various bug fixes
|
||||||
|
Nicholas Bray stencil shadow bug fixes with OpenGL
|
||||||
|
REAPER mouswheel events for scrollbar
|
||||||
|
Calimero various bug fixes like vector2d operators
|
||||||
|
Haddock bugfix in the linked list
|
||||||
|
G.o.D XML parser fix
|
||||||
|
Erik Zilli Translated some of the tutorials from my stuttering english into real english. :)
|
||||||
|
Martin Piskernig Linux bugfixing and testing
|
||||||
|
Soconne Wrote the original terrain renderer were Irrlichts terrain renderer of Irrlicht is based on it.
|
||||||
|
Spintz GeoMipMap scene node, terrain renderer of Irrlicht is based on it.
|
||||||
|
Murphy McCauley OCT file loader, MIM tools
|
||||||
|
Saurav Mohapatra IrrCSM, and lots of addons, suggestions and bug reports
|
||||||
|
Zhuck Dimitry My3D Tools
|
||||||
|
Terry Welsh Allowed me to use the textures of his 'Parallax Mapping with Offset Limiting' paper for the parallax demo of Irrlicht
|
||||||
|
rt Wrote the original .png loader for Irrlicht
|
||||||
|
Salvatore Russo Wrote the original .dmf loader for Irrlicht
|
||||||
|
Vox Various bug reports and fixes
|
||||||
|
atomice Contributed code for a ms3d loader enhancement
|
||||||
|
William Finlayson OpenGL RTT, GLSL support and the reflection 2 layer material for OpenGL.
|
||||||
|
Delight Various code contributions for Irrlicht.NET (particle system, basic shader support and more)
|
||||||
|
Michael Zoech Improved GLSL support
|
||||||
|
Jean-loup Gailly, Mark Adler Created the zlib and libpng
|
||||||
|
Guy Eric Schalnat, Andreas Dilger, Glenn Randers-Pehrson and others Created libpng
|
||||||
|
The Independent JPEG Group Created JPEG lib
|
||||||
|
Dr Brian Gladman AES Created aesGladman
|
||||||
|
|
2
lib/Linux/readme.txt
Normal file
2
lib/Linux/readme.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
You might have to recompile the engine to get library files in here.
|
||||||
|
Check the readme.txt in the corresponding bin folders for more information.
|
2
lib/OSX/readme.txt
Normal file
2
lib/OSX/readme.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
You might have to recompile the engine to get library files in here.
|
||||||
|
Check the readme.txt in the corresponding bin folders for more information.
|
2
lib/Win32-gcc/readme.txt
Normal file
2
lib/Win32-gcc/readme.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
You might have to recompile the engine to get library files in here.
|
||||||
|
Check the readme.txt in the corresponding bin folders for more information.
|
2
lib/Win32-visualstudio/readme.txt
Normal file
2
lib/Win32-visualstudio/readme.txt
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
You might have to recompile the engine to get library files in here.
|
||||||
|
Check the readme.txt in the corresponding bin folders for more information.
|
6
ogles-readme.txt
Normal file
6
ogles-readme.txt
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
This branch is used for development of the OpenGL-ES drivers for Irrlicht.
|
||||||
|
There will be drivers for ogl-es 1.x and 2.x at some time, but we'll start
|
||||||
|
with 1.x first. Both drivers will be separate drivers, loosely based on the
|
||||||
|
OpenGL driver.
|
||||||
|
The branch is based on SVN/trunk and will be updated only very slowly. It's
|
||||||
|
not intended for regular use besides when working with ogl-es development.
|
34
repro.sh
Executable file
34
repro.sh
Executable file
@ -0,0 +1,34 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
aflout=out/default
|
||||||
|
myout=out_rep
|
||||||
|
exe=./bin/Linux/LoadMesh
|
||||||
|
rm -rf "$myout" && mkdir -p "$myout"
|
||||||
|
find $aflout/crashes -name 'id:*' -print | \
|
||||||
|
while read file; do
|
||||||
|
echo "➤ Testing $file..."
|
||||||
|
short=${file##*/}
|
||||||
|
short=${short%%,*}
|
||||||
|
fout=$myout/$short.txt
|
||||||
|
$exe "$file" >"$fout" 2>&1
|
||||||
|
r=$?
|
||||||
|
if grep -Fq '==ERROR: AddressSanitizer: SEGV on unknown address' "$fout"; then
|
||||||
|
gdb -q --batch -iex 'set confirm off' -ex r -ex bt --args \
|
||||||
|
${exe}_noasan "$file" >"$fout" 2>&1
|
||||||
|
if grep -Eq '^(Thread|Program).*received signal' "$fout"; then
|
||||||
|
cp "$file" "$myout/$short.bin"
|
||||||
|
echo "✔ Reproduced (gdb)"
|
||||||
|
else
|
||||||
|
echo "✗ Not reproduced (gdb)"
|
||||||
|
rm -f "$fout"
|
||||||
|
fi
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
grep -Fq '==ABORTING' "$fout" && r=1
|
||||||
|
if [ $r -eq 0 ]; then
|
||||||
|
echo "✗ Not reproduced (asan)"
|
||||||
|
rm -f "$fout"
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
cp "$file" "$myout/$short.bin"
|
||||||
|
echo "✔ Reproduced (asan)"
|
||||||
|
done
|
17
run.sh
Executable file
17
run.sh
Executable file
@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
export AFL_SKIP_CPUFREQ=1
|
||||||
|
export AFL_TMPDIR=/dev/shm
|
||||||
|
exe=./bin/Linux/LoadMesh
|
||||||
|
opts=(
|
||||||
|
-t 100
|
||||||
|
-i sample_u/
|
||||||
|
-o out/
|
||||||
|
)
|
||||||
|
if ! [ -d sample_u ]; then
|
||||||
|
mkdir sample_u
|
||||||
|
afl-cmin.bash -T 4 -i sample/ -o sample_u/ -- $exe @@
|
||||||
|
echo; echo
|
||||||
|
fi
|
||||||
|
exec afl-fuzz \
|
||||||
|
"${opts[@]}" "$@" \
|
||||||
|
-- $exe @@
|
@ -355,7 +355,7 @@ f:write[[
|
|||||||
#include <KHR/khrplatform.h>
|
#include <KHR/khrplatform.h>
|
||||||
|
|
||||||
#ifndef APIENTRY
|
#ifndef APIENTRY
|
||||||
#define APIENTRY KHRONOS_APIENTRY
|
#define APIENTRY
|
||||||
#endif
|
#endif
|
||||||
#ifndef APIENTRYP
|
#ifndef APIENTRYP
|
||||||
#define APIENTRYP APIENTRY *
|
#define APIENTRYP APIENTRY *
|
||||||
@ -387,9 +387,9 @@ public:
|
|||||||
// Call this once after creating the context.
|
// Call this once after creating the context.
|
||||||
void LoadAllProcedures(irr::video::IContextManager *cmgr);
|
void LoadAllProcedures(irr::video::IContextManager *cmgr);
|
||||||
// Check if an extension is supported.
|
// Check if an extension is supported.
|
||||||
inline bool IsExtensionPresent(const std::string &ext) const
|
inline bool IsExtensionPresent(const std::string &ext)
|
||||||
{
|
{
|
||||||
return extensions.count(ext) > 0;
|
return extensions.find(ext) != extensions.end();
|
||||||
}
|
}
|
||||||
|
|
||||||
]];
|
]];
|
||||||
@ -403,16 +403,13 @@ f:write[[
|
|||||||
static constexpr const GLenum NONE = 0;
|
static constexpr const GLenum NONE = 0;
|
||||||
]];
|
]];
|
||||||
f:write( "};\n" );
|
f:write( "};\n" );
|
||||||
f:write( "\n// Global GL procedures object.\n" );
|
f:write( "\n//Global GL procedures object.\n" );
|
||||||
f:write( "IRRLICHT_API extern OpenGLProcedures GL;\n" );
|
f:write( "IRRLICHT_API extern OpenGLProcedures GL;\n" );
|
||||||
f:close();
|
f:close();
|
||||||
|
|
||||||
-- Write loader implementation
|
-- Write loader implementation
|
||||||
f = io.open( sourceTreePath .. "/source/Irrlicht/mt_opengl_loader.cpp", "wb" );
|
f = io.open( sourceTreePath .. "/source/Irrlicht/mt_opengl_loader.cpp", "wb" );
|
||||||
f:write[[
|
f:write[[
|
||||||
// This code was generated by scripts/BindingGenerator.lua
|
|
||||||
// Do not modify it, modify and run the generator instead.
|
|
||||||
|
|
||||||
#include "mt_opengl.h"
|
#include "mt_opengl.h"
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
@ -426,24 +423,9 @@ void OpenGLProcedures::LoadAllProcedures(irr::video::IContextManager *cmgr)
|
|||||||
f:write( loader:Concat() );
|
f:write( loader:Concat() );
|
||||||
f:write[[
|
f:write[[
|
||||||
|
|
||||||
// OpenGL 3 way to enumerate extensions
|
|
||||||
GLint ext_count = 0;
|
|
||||||
GetIntegerv(NUM_EXTENSIONS, &ext_count);
|
|
||||||
extensions.reserve(ext_count);
|
|
||||||
for (GLint k = 0; k < ext_count; k++) {
|
|
||||||
auto tmp = GetStringi(EXTENSIONS, k);
|
|
||||||
if (tmp)
|
|
||||||
extensions.emplace((char*)tmp);
|
|
||||||
}
|
|
||||||
if (!extensions.empty())
|
|
||||||
return;
|
|
||||||
|
|
||||||
// OpenGL 2 / ES 2 way to enumerate extensions
|
|
||||||
auto ext_str = GetString(EXTENSIONS);
|
|
||||||
if (!ext_str)
|
|
||||||
return;
|
|
||||||
// get the extension string, chop it up
|
// get the extension string, chop it up
|
||||||
std::stringstream ext_ss((char*)ext_str);
|
std::string ext_string = std::string((char*)GetString(EXTENSIONS));
|
||||||
|
std::stringstream ext_ss(ext_string);
|
||||||
std::string tmp;
|
std::string tmp;
|
||||||
while (std::getline(ext_ss, tmp, ' '))
|
while (std::getline(ext_ss, tmp, ' '))
|
||||||
extensions.emplace(tmp);
|
extensions.emplace(tmp);
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#!/bin/bash -e
|
#!/bin/bash -e
|
||||||
topdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
||||||
|
|
||||||
[[ -z "$CC" || -z "$CXX" ]] && exit 255
|
[[ -z "$CC" || -z "$CXX" ]] && exit 255
|
||||||
|
|
||||||
variant=win32
|
variant=win32
|
||||||
[[ "$(basename "$CXX")" == "x86_64-"* ]] && variant=win64
|
[[ "$(basename "$CXX")" == "x86_64-"* ]] && variant=win64
|
||||||
with_sdl=0
|
with_sdl=0
|
||||||
@ -9,29 +9,26 @@ with_sdl=0
|
|||||||
#with_gl3=0
|
#with_gl3=0
|
||||||
#[[ "$extras" == *"-gl3"* ]] && with_gl3=1
|
#[[ "$extras" == *"-gl3"* ]] && with_gl3=1
|
||||||
|
|
||||||
libjpeg_version=3.0.1
|
libjpeg_version=2.1.5.1
|
||||||
libpng_version=1.6.40
|
libpng_version=1.6.39
|
||||||
sdl2_version=2.28.5
|
sdl2_version=2.28.1
|
||||||
zlib_version=1.3
|
zlib_version=1.2.13
|
||||||
|
|
||||||
download () {
|
|
||||||
local url=$1
|
|
||||||
local filename=${url##*/}
|
|
||||||
local foldername=${filename%%[.-]*}
|
|
||||||
|
|
||||||
[ -d "./$foldername" ] && return 0
|
|
||||||
[ -e "$filename" ] || wget "$url" -O "$filename"
|
|
||||||
sha256sum -w -c <(grep -F "$filename" "$topdir/sha256sums.txt")
|
|
||||||
unzip -o "$filename" -d "$foldername"
|
|
||||||
}
|
|
||||||
|
|
||||||
mkdir -p libs
|
mkdir -p libs
|
||||||
pushd libs
|
pushd libs
|
||||||
libs=$PWD
|
libs=$PWD
|
||||||
download "http://minetest.kitsunemimi.pw/libjpeg-$libjpeg_version-$variant.zip"
|
[ -e libjpeg.zip ] || \
|
||||||
download "http://minetest.kitsunemimi.pw/libpng-$libpng_version-$variant.zip"
|
wget "http://minetest.kitsunemimi.pw/libjpeg-$libjpeg_version-$variant.zip" -O libjpeg.zip
|
||||||
[ $with_sdl -eq 1 ] && download "http://minetest.kitsunemimi.pw/sdl2-$sdl2_version-$variant.zip"
|
[ -e libpng.zip ] || \
|
||||||
download "http://minetest.kitsunemimi.pw/zlib-$zlib_version-$variant.zip"
|
wget "http://minetest.kitsunemimi.pw/libpng-$libpng_version-$variant.zip" -O libpng.zip
|
||||||
|
[[ $with_sdl -eq 0 || -e sdl2.zip ]] || \
|
||||||
|
wget "http://minetest.kitsunemimi.pw/sdl2-$sdl2_version-$variant.zip" -O sdl2.zip
|
||||||
|
[ -e zlib.zip ] || \
|
||||||
|
wget "http://minetest.kitsunemimi.pw/zlib-$zlib_version-$variant.zip" -O zlib.zip
|
||||||
|
[ -d libjpeg ] || unzip -o libjpeg.zip -d libjpeg
|
||||||
|
[ -d libpng ] || unzip -o libpng.zip -d libpng
|
||||||
|
[[ $with_sdl -eq 0 || -d sdl2 ]] || unzip -o sdl2.zip -d sdl2
|
||||||
|
[ -d zlib ] || unzip -o zlib.zip -d zlib
|
||||||
popd
|
popd
|
||||||
|
|
||||||
tmp=(
|
tmp=(
|
||||||
@ -43,14 +40,10 @@ tmp=(
|
|||||||
-DZLIB_LIBRARY=$libs/zlib/lib/libz.dll.a \
|
-DZLIB_LIBRARY=$libs/zlib/lib/libz.dll.a \
|
||||||
-DZLIB_INCLUDE_DIR=$libs/zlib/include
|
-DZLIB_INCLUDE_DIR=$libs/zlib/include
|
||||||
)
|
)
|
||||||
if [ $with_sdl -eq 1 ]; then
|
[ $with_sdl -eq 1 ] && tmp+=(
|
||||||
tmp+=(
|
-DUSE_SDL2=ON
|
||||||
-DUSE_SDL2=ON
|
-DCMAKE_PREFIX_PATH=$libs/sdl2/lib/cmake
|
||||||
-DCMAKE_PREFIX_PATH=$libs/sdl2/lib/cmake
|
)
|
||||||
)
|
|
||||||
else
|
|
||||||
tmp+=(-DUSE_SDL2=OFF)
|
|
||||||
fi
|
|
||||||
#[ $with_gl3 -eq 1 ] && tmp+=(-DENABLE_OPENGL=OFF -DENABLE_OPENGL3=ON)
|
#[ $with_gl3 -eq 1 ] && tmp+=(-DENABLE_OPENGL=OFF -DENABLE_OPENGL3=ON)
|
||||||
|
|
||||||
cmake . "${tmp[@]}"
|
cmake . "${tmp[@]}"
|
||||||
|
@ -1,12 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
set -e
|
|
||||||
topdir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
||||||
[ -z "$1" ] && exit 255
|
|
||||||
|
|
||||||
ver=13.2.0
|
|
||||||
os=ubuntu22.04
|
|
||||||
name="mingw-w64-${1}_${ver}_${os}.tar.xz"
|
|
||||||
wget "http://minetest.kitsunemimi.pw/$name" -O "$name"
|
|
||||||
sha256sum -w -c <(grep -F "$name" "$topdir/sha256sums.txt")
|
|
||||||
sudo tar -xaf "$name" -C /usr
|
|
||||||
rm -f "$name"
|
|
@ -1,10 +0,0 @@
|
|||||||
a7dc54d5fb9f841eae26ee17f6146c0b7a0e5d99a914866a394b723dffc83316 libjpeg-3.0.1-win32.zip
|
|
||||||
cd1f667ed2d24d96e1d61fcf91ba6d7b11270a4903e36f08e640971884caaccd libjpeg-3.0.1-win64.zip
|
|
||||||
72a624fbaef15909f80976c9c569717e9438bd34c3209071378f05487e859f8a libpng-1.6.40-win32.zip
|
|
||||||
8e2552f6965c385f7e2467018d583fd206744db18e36656ddf1c07c8663ea23f libpng-1.6.40-win64.zip
|
|
||||||
9f0cfab8ca089d48be7a59f85d5fd5648f18f54c91d7ac6c31b281ba5e90852a mingw-w64-i686_13.2.0_ubuntu22.04.tar.xz
|
|
||||||
93bc9f04d43a023358d1ae2b76dec42d3d79baecd452402ee9fb3ee21945fdfe mingw-w64-x86_64_13.2.0_ubuntu22.04.tar.xz
|
|
||||||
2abdc82b4cac710bab0b3e9f9a9c38cc242abcca443c1e1f7af51d29a5eb5457 sdl2-2.28.5-win32.zip
|
|
||||||
949a3de77d1c97240ee4b35e15495962b5effb816f7f03efe5c6edd8975a8b19 sdl2-2.28.5-win64.zip
|
|
||||||
3c5abd40e9492c834651d995db6bbf0f57a7579d091d2d03110293b95e9b039a zlib-1.3-win32.zip
|
|
||||||
f63d9a38c2ee56fa1e95a486224c274412cb5b3275734c1da53b0a68a7e8c654 zlib-1.3-win64.zip
|
|
@ -3,6 +3,7 @@
|
|||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef _IRR_COMPILE_ANDROID_ASSET_READER_
|
||||||
|
|
||||||
#include "CAndroidAssetReader.h"
|
#include "CAndroidAssetReader.h"
|
||||||
|
|
||||||
@ -105,3 +106,4 @@ void CAndroidAssetFileArchive::addDirectoryToFileList(const io::path &dirname_)
|
|||||||
} // end namespace io
|
} // end namespace io
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif // _IRR_COMPILE_ANDROID_ASSET_READER_
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#ifdef _IRR_COMPILE_ANDROID_ASSET_READER_
|
||||||
|
|
||||||
|
|
||||||
#include "IReadFile.h"
|
#include "IReadFile.h"
|
||||||
#include "IFileArchive.h"
|
#include "IFileArchive.h"
|
||||||
#include "CFileList.h"
|
#include "CFileList.h"
|
||||||
@ -58,3 +61,4 @@ namespace io
|
|||||||
} // end namespace io
|
} // end namespace io
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif // _IRR_COMPILE_ANDROID_ASSET_READER_
|
||||||
|
@ -2,6 +2,9 @@
|
|||||||
// This file is part of the "Irrlicht Engine".
|
// This file is part of the "Irrlicht Engine".
|
||||||
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
// For conditions of distribution and use, see copyright notice in irrlicht.h
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef _IRR_COMPILE_ANDROID_ASSET_READER_
|
||||||
|
|
||||||
#include "CAndroidAssetReader.h"
|
#include "CAndroidAssetReader.h"
|
||||||
|
|
||||||
#include "CReadFile.h"
|
#include "CReadFile.h"
|
||||||
@ -66,3 +69,4 @@ const io::path& CAndroidAssetReader::getFileName() const
|
|||||||
} // end namespace io
|
} // end namespace io
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif // _IRR_COMPILE_ANDROID_ASSET_READER_
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#ifdef _IRR_COMPILE_ANDROID_ASSET_READER_
|
||||||
|
|
||||||
|
|
||||||
#include "IReadFile.h"
|
#include "IReadFile.h"
|
||||||
|
|
||||||
struct AAssetManager;
|
struct AAssetManager;
|
||||||
@ -63,3 +66,4 @@ namespace io
|
|||||||
} // end namespace io
|
} // end namespace io
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif // _IRR_COMPILE_ANDROID_ASSET_READER_
|
||||||
|
@ -5,6 +5,8 @@
|
|||||||
|
|
||||||
#include "CIrrDeviceAndroid.h"
|
#include "CIrrDeviceAndroid.h"
|
||||||
|
|
||||||
|
#ifdef _IRR_COMPILE_WITH_ANDROID_DEVICE_
|
||||||
|
|
||||||
#include "os.h"
|
#include "os.h"
|
||||||
#include "CFileSystem.h"
|
#include "CFileSystem.h"
|
||||||
#include "CAndroidAssetReader.h"
|
#include "CAndroidAssetReader.h"
|
||||||
@ -106,7 +108,7 @@ bool CIrrDeviceAndroid::run()
|
|||||||
s32 Events = 0;
|
s32 Events = 0;
|
||||||
android_poll_source* Source = 0;
|
android_poll_source* Source = 0;
|
||||||
|
|
||||||
while ((id = ALooper_pollAll(0, 0, &Events, (void**)&Source)) >= 0)
|
while ((id = ALooper_pollAll(((Focused && !Paused) || !Initialized) ? 0 : -1, 0, &Events, (void**)&Source)) >= 0)
|
||||||
{
|
{
|
||||||
if(Source)
|
if(Source)
|
||||||
Source->process(Android, Source);
|
Source->process(Android, Source);
|
||||||
@ -193,11 +195,6 @@ bool CIrrDeviceAndroid::isWindowMinimized() const
|
|||||||
return !Focused;
|
return !Focused;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CIrrDeviceAndroid::isWindowVisible() const
|
|
||||||
{
|
|
||||||
return !Paused;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CIrrDeviceAndroid::closeDevice()
|
void CIrrDeviceAndroid::closeDevice()
|
||||||
{
|
{
|
||||||
ANativeActivity_finish(Android->activity);
|
ANativeActivity_finish(Android->activity);
|
||||||
@ -861,3 +858,5 @@ bool CIrrDeviceAndroid::isGyroscopeAvailable()
|
|||||||
}
|
}
|
||||||
|
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef _IRR_COMPILE_WITH_ANDROID_DEVICE_
|
||||||
|
|
||||||
#include "CIrrDeviceStub.h"
|
#include "CIrrDeviceStub.h"
|
||||||
#include "IrrlichtDevice.h"
|
#include "IrrlichtDevice.h"
|
||||||
@ -36,8 +37,6 @@ namespace irr
|
|||||||
|
|
||||||
virtual bool isWindowMinimized() const;
|
virtual bool isWindowMinimized() const;
|
||||||
|
|
||||||
virtual bool isWindowVisible() const;
|
|
||||||
|
|
||||||
virtual void closeDevice();
|
virtual void closeDevice();
|
||||||
|
|
||||||
virtual void setResizable(bool resize = false);
|
virtual void setResizable(bool resize = false);
|
||||||
@ -99,3 +98,4 @@ namespace irr
|
|||||||
|
|
||||||
} // end namespace irr
|
} // end namespace irr
|
||||||
|
|
||||||
|
#endif // _IRR_COMPILE_WITH_ANDROID_DEVICE_
|
||||||
|
@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
#include "CKeyEventWrapper.h"
|
#include "CKeyEventWrapper.h"
|
||||||
|
|
||||||
|
#ifdef _IRR_COMPILE_WITH_ANDROID_DEVICE_
|
||||||
|
|
||||||
#include "os.h"
|
#include "os.h"
|
||||||
|
|
||||||
namespace irr
|
namespace irr
|
||||||
@ -56,3 +58,6 @@ int CKeyEventWrapper::getUnicodeChar(int metaState)
|
|||||||
|
|
||||||
} // namespace jni
|
} // namespace jni
|
||||||
} // namespace irr
|
} // namespace irr
|
||||||
|
|
||||||
|
|
||||||
|
#endif // _IRR_COMPILE_WITH_ANDROID_DEVICE_
|
||||||
|
@ -3,6 +3,8 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#ifdef _IRR_COMPILE_WITH_ANDROID_DEVICE_
|
||||||
|
|
||||||
#include <jni.h>
|
#include <jni.h>
|
||||||
|
|
||||||
struct android_app;
|
struct android_app;
|
||||||
@ -33,3 +35,5 @@ private:
|
|||||||
|
|
||||||
} // namespace jni
|
} // namespace jni
|
||||||
} // namespace irr
|
} // namespace irr
|
||||||
|
|
||||||
|
#endif // _IRR_COMPILE_WITH_ANDROID_DEVICE_
|
||||||
|
File diff suppressed because it is too large
Load Diff
@ -7,7 +7,9 @@
|
|||||||
#include "ISceneManager.h"
|
#include "ISceneManager.h"
|
||||||
#include "S3DVertex.h"
|
#include "S3DVertex.h"
|
||||||
#include "os.h"
|
#include "os.h"
|
||||||
|
#ifdef _IRR_COMPILE_WITH_SKINNED_MESH_SUPPORT_
|
||||||
#include "CSkinnedMesh.h"
|
#include "CSkinnedMesh.h"
|
||||||
|
#endif
|
||||||
#include "IDummyTransformationSceneNode.h"
|
#include "IDummyTransformationSceneNode.h"
|
||||||
#include "IBoneSceneNode.h"
|
#include "IBoneSceneNode.h"
|
||||||
#include "IMaterialRenderer.h"
|
#include "IMaterialRenderer.h"
|
||||||
@ -51,8 +53,6 @@ CAnimatedMeshSceneNode::~CAnimatedMeshSceneNode()
|
|||||||
{
|
{
|
||||||
if (LoopCallBack)
|
if (LoopCallBack)
|
||||||
LoopCallBack->drop();
|
LoopCallBack->drop();
|
||||||
if (Mesh)
|
|
||||||
Mesh->drop();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -187,6 +187,10 @@ IMesh * CAnimatedMeshSceneNode::getMeshForCurrentFrame()
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
#ifndef _IRR_COMPILE_WITH_SKINNED_MESH_SUPPORT_
|
||||||
|
return 0;
|
||||||
|
#else
|
||||||
|
|
||||||
// As multiple scene nodes may be sharing the same skinned mesh, we have to
|
// As multiple scene nodes may be sharing the same skinned mesh, we have to
|
||||||
// re-animate it every frame to ensure that this node gets the mesh that it needs.
|
// re-animate it every frame to ensure that this node gets the mesh that it needs.
|
||||||
|
|
||||||
@ -219,6 +223,7 @@ IMesh * CAnimatedMeshSceneNode::getMeshForCurrentFrame()
|
|||||||
}
|
}
|
||||||
|
|
||||||
return skinnedMesh;
|
return skinnedMesh;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -461,6 +466,11 @@ u32 CAnimatedMeshSceneNode::getMaterialCount() const
|
|||||||
//! the corresponding joint, if the mesh in this scene node is a skinned mesh.
|
//! the corresponding joint, if the mesh in this scene node is a skinned mesh.
|
||||||
IBoneSceneNode* CAnimatedMeshSceneNode::getJointNode(const c8* jointName)
|
IBoneSceneNode* CAnimatedMeshSceneNode::getJointNode(const c8* jointName)
|
||||||
{
|
{
|
||||||
|
#ifndef _IRR_COMPILE_WITH_SKINNED_MESH_SUPPORT_
|
||||||
|
os::Printer::log("Compiled without _IRR_COMPILE_WITH_SKINNED_MESH_SUPPORT_", ELL_WARNING);
|
||||||
|
return 0;
|
||||||
|
#else
|
||||||
|
|
||||||
if (!Mesh || Mesh->getMeshType() != EAMT_SKINNED)
|
if (!Mesh || Mesh->getMeshType() != EAMT_SKINNED)
|
||||||
{
|
{
|
||||||
os::Printer::log("No mesh, or mesh not of skinned mesh type", ELL_WARNING);
|
os::Printer::log("No mesh, or mesh not of skinned mesh type", ELL_WARNING);
|
||||||
@ -486,6 +496,7 @@ IBoneSceneNode* CAnimatedMeshSceneNode::getJointNode(const c8* jointName)
|
|||||||
}
|
}
|
||||||
|
|
||||||
return JointChildSceneNodes[number];
|
return JointChildSceneNodes[number];
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -494,6 +505,11 @@ IBoneSceneNode* CAnimatedMeshSceneNode::getJointNode(const c8* jointName)
|
|||||||
//! the corresponding joint, if the mesh in this scene node is a skinned mesh.
|
//! the corresponding joint, if the mesh in this scene node is a skinned mesh.
|
||||||
IBoneSceneNode* CAnimatedMeshSceneNode::getJointNode(u32 jointID)
|
IBoneSceneNode* CAnimatedMeshSceneNode::getJointNode(u32 jointID)
|
||||||
{
|
{
|
||||||
|
#ifndef _IRR_COMPILE_WITH_SKINNED_MESH_SUPPORT_
|
||||||
|
os::Printer::log("Compiled without _IRR_COMPILE_WITH_SKINNED_MESH_SUPPORT_", ELL_WARNING);
|
||||||
|
return 0;
|
||||||
|
#else
|
||||||
|
|
||||||
if (!Mesh || Mesh->getMeshType() != EAMT_SKINNED)
|
if (!Mesh || Mesh->getMeshType() != EAMT_SKINNED)
|
||||||
{
|
{
|
||||||
os::Printer::log("No mesh, or mesh not of skinned mesh type", ELL_WARNING);
|
os::Printer::log("No mesh, or mesh not of skinned mesh type", ELL_WARNING);
|
||||||
@ -509,17 +525,23 @@ IBoneSceneNode* CAnimatedMeshSceneNode::getJointNode(u32 jointID)
|
|||||||
}
|
}
|
||||||
|
|
||||||
return JointChildSceneNodes[jointID];
|
return JointChildSceneNodes[jointID];
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
//! Gets joint count.
|
//! Gets joint count.
|
||||||
u32 CAnimatedMeshSceneNode::getJointCount() const
|
u32 CAnimatedMeshSceneNode::getJointCount() const
|
||||||
{
|
{
|
||||||
|
#ifndef _IRR_COMPILE_WITH_SKINNED_MESH_SUPPORT_
|
||||||
|
return 0;
|
||||||
|
#else
|
||||||
|
|
||||||
if (!Mesh || Mesh->getMeshType() != EAMT_SKINNED)
|
if (!Mesh || Mesh->getMeshType() != EAMT_SKINNED)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
ISkinnedMesh *skinnedMesh=(ISkinnedMesh*)Mesh;
|
ISkinnedMesh *skinnedMesh=(ISkinnedMesh*)Mesh;
|
||||||
|
|
||||||
return skinnedMesh->getJointCount();
|
return skinnedMesh->getJointCount();
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -680,6 +702,9 @@ void CAnimatedMeshSceneNode::setRenderFromIdentity(bool enable)
|
|||||||
//! updates the joint positions of this mesh
|
//! updates the joint positions of this mesh
|
||||||
void CAnimatedMeshSceneNode::animateJoints(bool CalculateAbsolutePositions)
|
void CAnimatedMeshSceneNode::animateJoints(bool CalculateAbsolutePositions)
|
||||||
{
|
{
|
||||||
|
#ifndef _IRR_COMPILE_WITH_SKINNED_MESH_SUPPORT_
|
||||||
|
return;
|
||||||
|
#else
|
||||||
if (Mesh && Mesh->getMeshType() == EAMT_SKINNED )
|
if (Mesh && Mesh->getMeshType() == EAMT_SKINNED )
|
||||||
{
|
{
|
||||||
checkJoints();
|
checkJoints();
|
||||||
@ -751,12 +776,17 @@ void CAnimatedMeshSceneNode::animateJoints(bool CalculateAbsolutePositions)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
*/
|
*/
|
||||||
void CAnimatedMeshSceneNode::checkJoints()
|
void CAnimatedMeshSceneNode::checkJoints()
|
||||||
{
|
{
|
||||||
|
#ifndef _IRR_COMPILE_WITH_SKINNED_MESH_SUPPORT_
|
||||||
|
return;
|
||||||
|
#else
|
||||||
|
|
||||||
if (!Mesh || Mesh->getMeshType() != EAMT_SKINNED)
|
if (!Mesh || Mesh->getMeshType() != EAMT_SKINNED)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
@ -773,6 +803,7 @@ void CAnimatedMeshSceneNode::checkJoints()
|
|||||||
JointsUsed=true;
|
JointsUsed=true;
|
||||||
JointMode=EJUOR_READ;
|
JointMode=EJUOR_READ;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
@ -274,14 +274,7 @@ bool CB3DMeshFileLoader::readChunkMESH(CSkinnedMesh::SJoint *inJoint)
|
|||||||
{
|
{
|
||||||
scene::SSkinMeshBuffer *meshBuffer = AnimatedMesh->addMeshBuffer();
|
scene::SSkinMeshBuffer *meshBuffer = AnimatedMesh->addMeshBuffer();
|
||||||
|
|
||||||
if (brushID == -1)
|
if (brushID!=-1)
|
||||||
{ /* ok */ }
|
|
||||||
else if (brushID < 0 || (u32)brushID >= Materials.size())
|
|
||||||
{
|
|
||||||
os::Printer::log("Illegal brush ID found", B3DFile->getFileName(), ELL_ERROR);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
meshBuffer->Material=Materials[brushID].Material;
|
meshBuffer->Material=Materials[brushID].Material;
|
||||||
}
|
}
|
||||||
@ -361,8 +354,7 @@ bool CB3DMeshFileLoader::readChunkVRTS(CSkinnedMesh::SJoint *inJoint)
|
|||||||
tex_coord_set_size = os::Byteswap::byteswap(tex_coord_set_size);
|
tex_coord_set_size = os::Byteswap::byteswap(tex_coord_set_size);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (tex_coord_sets < 0 || tex_coord_set_size < 0 ||
|
if (tex_coord_sets >= max_tex_coords || tex_coord_set_size >= 4) // Something is wrong
|
||||||
tex_coord_sets >= max_tex_coords || tex_coord_set_size >= 4) // Something is wrong
|
|
||||||
{
|
{
|
||||||
os::Printer::log("tex_coord_sets or tex_coord_set_size too big", B3DFile->getFileName(), ELL_ERROR);
|
os::Printer::log("tex_coord_sets or tex_coord_set_size too big", B3DFile->getFileName(), ELL_ERROR);
|
||||||
return false;
|
return false;
|
||||||
@ -466,18 +458,13 @@ bool CB3DMeshFileLoader::readChunkTRIS(scene::SSkinMeshBuffer *meshBuffer, u32 m
|
|||||||
|
|
||||||
SB3dMaterial *B3dMaterial;
|
SB3dMaterial *B3dMaterial;
|
||||||
|
|
||||||
if (triangle_brush_id == -1)
|
if (triangle_brush_id != -1)
|
||||||
B3dMaterial = 0;
|
|
||||||
else if (triangle_brush_id < 0 || (u32)triangle_brush_id >= Materials.size())
|
|
||||||
{
|
|
||||||
os::Printer::log("Illegal material index found", B3DFile->getFileName(), ELL_ERROR);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
B3dMaterial = &Materials[triangle_brush_id];
|
B3dMaterial = &Materials[triangle_brush_id];
|
||||||
meshBuffer->Material = B3dMaterial->Material;
|
meshBuffer->Material = B3dMaterial->Material;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
B3dMaterial = 0;
|
||||||
|
|
||||||
const s32 memoryNeeded = B3dStack.getLast().length / sizeof(s32);
|
const s32 memoryNeeded = B3dStack.getLast().length / sizeof(s32);
|
||||||
meshBuffer->Indices.reallocate(memoryNeeded + meshBuffer->Indices.size() + 1);
|
meshBuffer->Indices.reallocate(memoryNeeded + meshBuffer->Indices.size() + 1);
|
||||||
@ -596,12 +583,6 @@ bool CB3DMeshFileLoader::readChunkBONE(CSkinnedMesh::SJoint *inJoint)
|
|||||||
#endif
|
#endif
|
||||||
globalVertexID += VerticesStart;
|
globalVertexID += VerticesStart;
|
||||||
|
|
||||||
if (globalVertexID >= AnimatedVertices_VertexID.size())
|
|
||||||
{
|
|
||||||
os::Printer::log("Illegal vertex index found", B3DFile->getFileName(), ELL_ERROR);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (AnimatedVertices_VertexID[globalVertexID]==-1)
|
if (AnimatedVertices_VertexID[globalVertexID]==-1)
|
||||||
{
|
{
|
||||||
os::Printer::log("B3dMeshLoader: Weight has bad vertex id (no link to meshbuffer index found)");
|
os::Printer::log("B3dMeshLoader: Weight has bad vertex id (no link to meshbuffer index found)");
|
||||||
@ -1034,11 +1015,10 @@ bool CB3DMeshFileLoader::readChunkBRUS()
|
|||||||
void CB3DMeshFileLoader::readString(core::stringc& newstring)
|
void CB3DMeshFileLoader::readString(core::stringc& newstring)
|
||||||
{
|
{
|
||||||
newstring="";
|
newstring="";
|
||||||
while (true)
|
while (B3DFile->getPos() <= B3DFile->getSize())
|
||||||
{
|
{
|
||||||
c8 character;
|
c8 character;
|
||||||
if (B3DFile->read(&character, sizeof(character)) == 0)
|
B3DFile->read(&character, sizeof(character));
|
||||||
return; // eof
|
|
||||||
if (character==0)
|
if (character==0)
|
||||||
return;
|
return;
|
||||||
newstring.append(character);
|
newstring.append(character);
|
||||||
|
@ -757,6 +757,9 @@ void CColorConverter::convert_viaFormat(const void* sP, ECOLOR_FORMAT sF, s32 sN
|
|||||||
case ECF_R8G8B8:
|
case ECF_R8G8B8:
|
||||||
convert_A1R5G5B5toR8G8B8(sP, sN, dP);
|
convert_A1R5G5B5toR8G8B8(sP, sN, dP);
|
||||||
break;
|
break;
|
||||||
|
IRR_CASE_IIMAGE_COMPRESSED_FORMAT
|
||||||
|
os::Printer::log("CColorConverter::convert_viaFormat method doesn't support compressed images.", ELL_WARNING);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -777,6 +780,9 @@ void CColorConverter::convert_viaFormat(const void* sP, ECOLOR_FORMAT sF, s32 sN
|
|||||||
case ECF_R8G8B8:
|
case ECF_R8G8B8:
|
||||||
convert_R5G6B5toR8G8B8(sP, sN, dP);
|
convert_R5G6B5toR8G8B8(sP, sN, dP);
|
||||||
break;
|
break;
|
||||||
|
IRR_CASE_IIMAGE_COMPRESSED_FORMAT
|
||||||
|
os::Printer::log("CColorConverter::convert_viaFormat method doesn't support compressed images.", ELL_WARNING);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -797,6 +803,9 @@ void CColorConverter::convert_viaFormat(const void* sP, ECOLOR_FORMAT sF, s32 sN
|
|||||||
case ECF_R8G8B8:
|
case ECF_R8G8B8:
|
||||||
convert_A8R8G8B8toR8G8B8(sP, sN, dP);
|
convert_A8R8G8B8toR8G8B8(sP, sN, dP);
|
||||||
break;
|
break;
|
||||||
|
IRR_CASE_IIMAGE_COMPRESSED_FORMAT
|
||||||
|
os::Printer::log("CColorConverter::convert_viaFormat method doesn't support compressed images.", ELL_WARNING);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
@ -817,11 +826,17 @@ void CColorConverter::convert_viaFormat(const void* sP, ECOLOR_FORMAT sF, s32 sN
|
|||||||
case ECF_R8G8B8:
|
case ECF_R8G8B8:
|
||||||
convert_R8G8B8toR8G8B8(sP, sN, dP);
|
convert_R8G8B8toR8G8B8(sP, sN, dP);
|
||||||
break;
|
break;
|
||||||
|
IRR_CASE_IIMAGE_COMPRESSED_FORMAT
|
||||||
|
os::Printer::log("CColorConverter::convert_viaFormat method doesn't support compressed images.", ELL_WARNING);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
IRR_CASE_IIMAGE_COMPRESSED_FORMAT
|
||||||
|
os::Printer::log("CColorConverter::convert_viaFormat method doesn't support compressed images.", ELL_WARNING);
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
|
@ -4,8 +4,6 @@
|
|||||||
|
|
||||||
#include "CEGLManager.h"
|
#include "CEGLManager.h"
|
||||||
|
|
||||||
#ifdef _IRR_COMPILE_WITH_EGL_MANAGER_
|
|
||||||
|
|
||||||
#include "irrString.h"
|
#include "irrString.h"
|
||||||
#include "irrArray.h"
|
#include "irrArray.h"
|
||||||
#include "os.h"
|
#include "os.h"
|
||||||
@ -44,7 +42,7 @@ bool CEGLManager::initialize(const SIrrlichtCreationParameters& params, const SE
|
|||||||
return true;
|
return true;
|
||||||
|
|
||||||
// Window is depend on platform.
|
// Window is depend on platform.
|
||||||
#if defined(_IRR_COMPILE_WITH_WINDOWS_DEVICE_)
|
#if defined(_IRR_WINDOWS_API_)
|
||||||
EglWindow = (NativeWindowType)Data.OpenGLWin32.HWnd;
|
EglWindow = (NativeWindowType)Data.OpenGLWin32.HWnd;
|
||||||
Data.OpenGLWin32.HDc = GetDC((HWND)EglWindow);
|
Data.OpenGLWin32.HDc = GetDC((HWND)EglWindow);
|
||||||
EglDisplay = eglGetDisplay((NativeDisplayType)Data.OpenGLWin32.HDc);
|
EglDisplay = eglGetDisplay((NativeDisplayType)Data.OpenGLWin32.HDc);
|
||||||
@ -99,7 +97,7 @@ void CEGLManager::terminate()
|
|||||||
EglDisplay = EGL_NO_DISPLAY;
|
EglDisplay = EGL_NO_DISPLAY;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(_IRR_COMPILE_WITH_WINDOWS_DEVICE_)
|
#if defined(_IRR_WINDOWS_API_)
|
||||||
if (Data.OpenGLWin32.HDc)
|
if (Data.OpenGLWin32.HDc)
|
||||||
{
|
{
|
||||||
ReleaseDC((HWND)EglWindow, (HDC)Data.OpenGLWin32.HDc);
|
ReleaseDC((HWND)EglWindow, (HDC)Data.OpenGLWin32.HDc);
|
||||||
@ -664,4 +662,3 @@ bool CEGLManager::testEGLError()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
|
||||||
|
@ -4,8 +4,6 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#ifdef _IRR_COMPILE_WITH_EGL_MANAGER_
|
|
||||||
|
|
||||||
#include <EGL/egl.h>
|
#include <EGL/egl.h>
|
||||||
|
|
||||||
#include "SIrrCreationParameters.h"
|
#include "SIrrCreationParameters.h"
|
||||||
@ -111,4 +109,3 @@ namespace video
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
@ -22,9 +22,9 @@ namespace gui
|
|||||||
CGUIComboBox::CGUIComboBox(IGUIEnvironment* environment, IGUIElement* parent,
|
CGUIComboBox::CGUIComboBox(IGUIEnvironment* environment, IGUIElement* parent,
|
||||||
s32 id, core::rect<s32> rectangle)
|
s32 id, core::rect<s32> rectangle)
|
||||||
: IGUIComboBox(environment, parent, id, rectangle),
|
: IGUIComboBox(environment, parent, id, rectangle),
|
||||||
ListButton(nullptr), SelectedText(nullptr), ListBox(nullptr), LastFocus(nullptr),
|
ListButton(0), SelectedText(0), ListBox(0), LastFocus(0),
|
||||||
Selected(-1), HAlign(EGUIA_UPPERLEFT), VAlign(EGUIA_CENTER), MaxSelectionRows(5), HasFocus(false),
|
Selected(-1), HAlign(EGUIA_UPPERLEFT), VAlign(EGUIA_CENTER), MaxSelectionRows(5), HasFocus(false),
|
||||||
ActiveFont(nullptr)
|
ActiveFont(0)
|
||||||
{
|
{
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
setDebugName("CGUIComboBox");
|
setDebugName("CGUIComboBox");
|
||||||
@ -185,15 +185,6 @@ void CGUIComboBox::setSelected(s32 idx)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
//! Sets the selected item and emits a change event.
|
|
||||||
/** Set this to -1 if no item should be selected */
|
|
||||||
void CGUIComboBox::setAndSendSelected(s32 idx)
|
|
||||||
{
|
|
||||||
setSelected(idx);
|
|
||||||
sendSelectionChangedEvent();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
//! called if an event happened.
|
//! called if an event happened.
|
||||||
bool CGUIComboBox::OnEvent(const SEvent& event)
|
bool CGUIComboBox::OnEvent(const SEvent& event)
|
||||||
{
|
{
|
||||||
@ -217,7 +208,7 @@ bool CGUIComboBox::OnEvent(const SEvent& event)
|
|||||||
openCloseMenu();
|
openCloseMenu();
|
||||||
}
|
}
|
||||||
|
|
||||||
ListButton->setPressed(ListBox == nullptr);
|
ListButton->setPressed(ListBox == 0);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -370,7 +361,7 @@ void CGUIComboBox::sendSelectionChangedEvent()
|
|||||||
|
|
||||||
event.EventType = EET_GUI_EVENT;
|
event.EventType = EET_GUI_EVENT;
|
||||||
event.GUIEvent.Caller = this;
|
event.GUIEvent.Caller = this;
|
||||||
event.GUIEvent.Element = nullptr;
|
event.GUIEvent.Element = 0;
|
||||||
event.GUIEvent.EventType = EGET_COMBO_BOX_CHANGED;
|
event.GUIEvent.EventType = EGET_COMBO_BOX_CHANGED;
|
||||||
Parent->OnEvent(event);
|
Parent->OnEvent(event);
|
||||||
}
|
}
|
||||||
@ -456,23 +447,12 @@ void CGUIComboBox::openCloseMenu()
|
|||||||
// close list box
|
// close list box
|
||||||
Environment->setFocus(this);
|
Environment->setFocus(this);
|
||||||
ListBox->remove();
|
ListBox->remove();
|
||||||
ListBox = nullptr;
|
ListBox = 0;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (Parent) {
|
if (Parent)
|
||||||
SEvent event;
|
|
||||||
event.EventType = EET_GUI_EVENT;
|
|
||||||
event.GUIEvent.Caller = this;
|
|
||||||
event.GUIEvent.Element = nullptr;
|
|
||||||
event.GUIEvent.EventType = EGET_LISTBOX_OPENED;
|
|
||||||
|
|
||||||
// Allow to prevent the listbox from opening.
|
|
||||||
if (Parent->OnEvent(event))
|
|
||||||
return;
|
|
||||||
|
|
||||||
Parent->bringToFront(this);
|
Parent->bringToFront(this);
|
||||||
}
|
|
||||||
|
|
||||||
IGUISkin* skin = Environment->getSkin();
|
IGUISkin* skin = Environment->getSkin();
|
||||||
u32 h = Items.size();
|
u32 h = Items.size();
|
||||||
|
@ -55,10 +55,6 @@ namespace gui
|
|||||||
//! sets the selected item. Set this to -1 if no item should be selected
|
//! sets the selected item. Set this to -1 if no item should be selected
|
||||||
void setSelected(s32 idx) override;
|
void setSelected(s32 idx) override;
|
||||||
|
|
||||||
//! Sets the selected item and emits a change event.
|
|
||||||
/** Set this to -1 if no item should be selected */
|
|
||||||
void setAndSendSelected(s32 idx) override;
|
|
||||||
|
|
||||||
//! sets the text alignment of the text part
|
//! sets the text alignment of the text part
|
||||||
void setTextAlignment(EGUI_ALIGNMENT horizontal, EGUI_ALIGNMENT vertical) override;
|
void setTextAlignment(EGUI_ALIGNMENT horizontal, EGUI_ALIGNMENT vertical) override;
|
||||||
|
|
||||||
|
@ -299,7 +299,7 @@ bool CGUIEditBox::processKey(const SEvent& event)
|
|||||||
const s32 realmend = MarkBegin < MarkEnd ? MarkEnd : MarkBegin;
|
const s32 realmend = MarkBegin < MarkEnd ? MarkEnd : MarkBegin;
|
||||||
|
|
||||||
core::stringc s;
|
core::stringc s;
|
||||||
wStringToUTF8(s, Text.subString(realmbgn, realmend - realmbgn));
|
wStringToMultibyte(s, Text.subString(realmbgn, realmend - realmbgn));
|
||||||
Operator->copyToClipboard(s.c_str());
|
Operator->copyToClipboard(s.c_str());
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
@ -312,7 +312,7 @@ bool CGUIEditBox::processKey(const SEvent& event)
|
|||||||
|
|
||||||
// copy
|
// copy
|
||||||
core::stringc sc;
|
core::stringc sc;
|
||||||
wStringToUTF8(sc, Text.subString(realmbgn, realmend - realmbgn));
|
wStringToMultibyte(sc, Text.subString(realmbgn, realmend - realmbgn));
|
||||||
Operator->copyToClipboard(sc.c_str());
|
Operator->copyToClipboard(sc.c_str());
|
||||||
|
|
||||||
if (isEnabled())
|
if (isEnabled())
|
||||||
@ -345,7 +345,7 @@ bool CGUIEditBox::processKey(const SEvent& event)
|
|||||||
if (p)
|
if (p)
|
||||||
{
|
{
|
||||||
irr::core::stringw widep;
|
irr::core::stringw widep;
|
||||||
core::utf8ToWString(widep, p);
|
core::multibyteToWString(widep, p);
|
||||||
|
|
||||||
if (MarkBegin == MarkEnd)
|
if (MarkBegin == MarkEnd)
|
||||||
{
|
{
|
||||||
@ -1157,7 +1157,7 @@ bool CGUIEditBox::processMouse(const SEvent& event)
|
|||||||
const c8 *inserted_text_utf8 = Operator->getTextFromPrimarySelection();
|
const c8 *inserted_text_utf8 = Operator->getTextFromPrimarySelection();
|
||||||
if (!inserted_text_utf8)
|
if (!inserted_text_utf8)
|
||||||
return inserted_text;
|
return inserted_text;
|
||||||
core::utf8ToWString(inserted_text, inserted_text_utf8);
|
core::multibyteToWString(inserted_text, inserted_text_utf8);
|
||||||
return inserted_text;
|
return inserted_text;
|
||||||
}());
|
}());
|
||||||
|
|
||||||
@ -1659,7 +1659,7 @@ void CGUIEditBox::setTextMarkers(s32 begin, s32 end)
|
|||||||
const s32 realmend = MarkBegin < MarkEnd ? MarkEnd : MarkBegin;
|
const s32 realmend = MarkBegin < MarkEnd ? MarkEnd : MarkBegin;
|
||||||
|
|
||||||
core::stringc s;
|
core::stringc s;
|
||||||
wStringToUTF8(s, Text.subString(realmbgn, realmend - realmbgn));
|
wStringToMultibyte(s, Text.subString(realmbgn, realmend - realmbgn));
|
||||||
Operator->copyToPrimarySelection(s.c_str());
|
Operator->copyToPrimarySelection(s.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -149,7 +149,7 @@ void CGUIEnvironment::loadBuiltInFont()
|
|||||||
CGUIFont* font = new CGUIFont(this, DefaultFontName );
|
CGUIFont* font = new CGUIFont(this, DefaultFontName );
|
||||||
if (!font->load(file))
|
if (!font->load(file))
|
||||||
{
|
{
|
||||||
os::Printer::log("Error: Could not load built-in Font.", ELL_ERROR);
|
os::Printer::log("Error: Could not load built-in Font. Did you compile without the BMP loader?", ELL_ERROR);
|
||||||
font->drop();
|
font->drop();
|
||||||
file->drop();
|
file->drop();
|
||||||
return;
|
return;
|
||||||
|
@ -623,7 +623,7 @@ void CGUIListBox::recalculateScrollPos()
|
|||||||
if (!AutoScroll)
|
if (!AutoScroll)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
const s32 selPos = (getSelected() == -1 ? TotalItemHeight : getSelected() * ItemHeight) - ScrollBar->getPos();
|
const s32 selPos = (Selected == -1 ? TotalItemHeight : Selected * ItemHeight) - ScrollBar->getPos();
|
||||||
|
|
||||||
if (selPos < 0)
|
if (selPos < 0)
|
||||||
{
|
{
|
||||||
|
@ -75,6 +75,10 @@ void CImage::setPixel(u32 x, u32 y, const SColor &color, bool blend)
|
|||||||
*dest = blend ? PixelBlend32 ( *dest, color.color ) : color.color;
|
*dest = blend ? PixelBlend32 ( *dest, color.color ) : color.color;
|
||||||
} break;
|
} break;
|
||||||
|
|
||||||
|
IRR_CASE_IIMAGE_COMPRESSED_FORMAT
|
||||||
|
os::Printer::log("IImage::setPixel method doesn't work with compressed images.", ELL_WARNING);
|
||||||
|
return;
|
||||||
|
|
||||||
case ECF_UNKNOWN:
|
case ECF_UNKNOWN:
|
||||||
os::Printer::log("IImage::setPixel unknown format.", ELL_WARNING);
|
os::Printer::log("IImage::setPixel unknown format.", ELL_WARNING);
|
||||||
return;
|
return;
|
||||||
@ -105,6 +109,10 @@ SColor CImage::getPixel(u32 x, u32 y) const
|
|||||||
return SColor(255,p[0],p[1],p[2]);
|
return SColor(255,p[0],p[1],p[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
IRR_CASE_IIMAGE_COMPRESSED_FORMAT
|
||||||
|
os::Printer::log("IImage::getPixel method doesn't work with compressed images.", ELL_WARNING);
|
||||||
|
break;
|
||||||
|
|
||||||
case ECF_UNKNOWN:
|
case ECF_UNKNOWN:
|
||||||
os::Printer::log("IImage::getPixel unknown format.", ELL_WARNING);
|
os::Printer::log("IImage::getPixel unknown format.", ELL_WARNING);
|
||||||
break;
|
break;
|
||||||
|
@ -45,32 +45,20 @@ bool CImageLoaderBMP::isALoadableFileFormat(io::IReadFile* file) const
|
|||||||
return headerID == 0x4d42;
|
return headerID == 0x4d42;
|
||||||
}
|
}
|
||||||
|
|
||||||
// UB-safe overflow check
|
|
||||||
static inline bool overflowCheck(const void *base, size_t offset, const void *end)
|
|
||||||
{
|
|
||||||
auto baseI = reinterpret_cast<uintptr_t>(base),
|
|
||||||
endI = reinterpret_cast<uintptr_t>(end);
|
|
||||||
return baseI > endI || offset >= (endI - baseI);
|
|
||||||
}
|
|
||||||
// check whether &p[0] to &p[_off - 1] can be accessed
|
|
||||||
#define CHECKP(_off) if ((_off) < 0 || overflowCheck(p, _off, pEnd)) goto exit
|
|
||||||
// same for d
|
|
||||||
#define CHECKD(_off) if ((_off) < 0 || overflowCheck(d, _off, destEnd)) goto exit
|
|
||||||
|
|
||||||
void CImageLoaderBMP::decompress8BitRLE(u8*& bmpData, s32 size, s32 width, s32 height, s32 pitch) const
|
void CImageLoaderBMP::decompress8BitRLE(u8*& bmpData, s32 size, s32 width, s32 height, s32 pitch) const
|
||||||
{
|
{
|
||||||
u8* p = bmpData;
|
u8* p = bmpData;
|
||||||
const u8* pEnd = bmpData + size;
|
|
||||||
u8* newBmp = new u8[(width+pitch)*height];
|
u8* newBmp = new u8[(width+pitch)*height];
|
||||||
u8* d = newBmp;
|
u8* d = newBmp;
|
||||||
const u8* destEnd = newBmp + (width+pitch)*height;
|
u8* destEnd = newBmp + (width+pitch)*height;
|
||||||
s32 line = 0;
|
s32 line = 0;
|
||||||
|
|
||||||
while (p < pEnd && d < destEnd)
|
while (bmpData - p < size && d < destEnd)
|
||||||
{
|
{
|
||||||
if (*p == 0)
|
if (*p == 0)
|
||||||
{
|
{
|
||||||
++p; CHECKP(1);
|
++p;
|
||||||
|
|
||||||
switch(*p)
|
switch(*p)
|
||||||
{
|
{
|
||||||
@ -80,28 +68,29 @@ void CImageLoaderBMP::decompress8BitRLE(u8*& bmpData, s32 size, s32 width, s32 h
|
|||||||
d = newBmp + (line*(width+pitch));
|
d = newBmp + (line*(width+pitch));
|
||||||
break;
|
break;
|
||||||
case 1: // end of bmp
|
case 1: // end of bmp
|
||||||
goto exit;
|
delete [] bmpData;
|
||||||
|
bmpData = newBmp;
|
||||||
|
return;
|
||||||
case 2:
|
case 2:
|
||||||
++p; CHECKP(2);
|
++p; d +=(u8)*p; // delta
|
||||||
d += (u8)*p; ++p; // delta
|
++p; d += ((u8)*p)*(width+pitch);
|
||||||
d += ((u8)*p)*(width+pitch); ++p;
|
++p;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
// absolute mode
|
// absolute mode
|
||||||
s32 count = (u8)*p; ++p;
|
s32 count = (u8)*p; ++p;
|
||||||
s32 readAdditional = ((2-(count%2))%2);
|
s32 readAdditional = ((2-(count%2))%2);
|
||||||
|
s32 i;
|
||||||
|
|
||||||
CHECKP(count); CHECKD(count);
|
for (i=0; i<count; ++i)
|
||||||
for (s32 i=0; i<count; ++i)
|
|
||||||
{
|
{
|
||||||
*d = *p;
|
*d = *p;
|
||||||
++p;
|
++p;
|
||||||
++d;
|
++d;
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECKP(readAdditional);
|
for (i=0; i<readAdditional; ++i)
|
||||||
for (s32 i=0; i<readAdditional; ++i)
|
|
||||||
++p;
|
++p;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -109,9 +98,7 @@ void CImageLoaderBMP::decompress8BitRLE(u8*& bmpData, s32 size, s32 width, s32 h
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
s32 count = (u8)*p; ++p;
|
s32 count = (u8)*p; ++p;
|
||||||
CHECKP(1);
|
|
||||||
u8 color = *p; ++p;
|
u8 color = *p; ++p;
|
||||||
CHECKD(count);
|
|
||||||
for (s32 i=0; i<count; ++i)
|
for (s32 i=0; i<count; ++i)
|
||||||
{
|
{
|
||||||
*d = color;
|
*d = color;
|
||||||
@ -120,37 +107,26 @@ void CImageLoaderBMP::decompress8BitRLE(u8*& bmpData, s32 size, s32 width, s32 h
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
exit:
|
|
||||||
delete [] bmpData;
|
delete [] bmpData;
|
||||||
bmpData = newBmp;
|
bmpData = newBmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
// how many bytes will be touched given the current state of decompress4BitRLE
|
|
||||||
static inline u32 shiftedCount(s32 count, s32 shift)
|
|
||||||
{
|
|
||||||
_IRR_DEBUG_BREAK_IF(count < 0)
|
|
||||||
u32 ret = count / 2;
|
|
||||||
if (shift == 0 || count % 2 == 1)
|
|
||||||
++ret;
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
void CImageLoaderBMP::decompress4BitRLE(u8*& bmpData, s32 size, s32 width, s32 height, s32 pitch) const
|
void CImageLoaderBMP::decompress4BitRLE(u8*& bmpData, s32 size, s32 width, s32 height, s32 pitch) const
|
||||||
{
|
{
|
||||||
const s32 lineWidth = (width+1)/2+pitch;
|
s32 lineWidth = (width+1)/2+pitch;
|
||||||
u8* p = bmpData;
|
u8* p = bmpData;
|
||||||
const u8* pEnd = bmpData + size;
|
|
||||||
u8* newBmp = new u8[lineWidth*height];
|
u8* newBmp = new u8[lineWidth*height];
|
||||||
u8* d = newBmp;
|
u8* d = newBmp;
|
||||||
const u8* destEnd = newBmp + lineWidth*height;
|
u8* destEnd = newBmp + lineWidth*height;
|
||||||
s32 line = 0;
|
s32 line = 0;
|
||||||
s32 shift = 4;
|
s32 shift = 4;
|
||||||
|
|
||||||
while (p < pEnd && d < destEnd)
|
while (bmpData - p < size && d < destEnd)
|
||||||
{
|
{
|
||||||
if (*p == 0)
|
if (*p == 0)
|
||||||
{
|
{
|
||||||
++p; CHECKP(1);
|
++p;
|
||||||
|
|
||||||
switch(*p)
|
switch(*p)
|
||||||
{
|
{
|
||||||
@ -161,10 +137,12 @@ void CImageLoaderBMP::decompress4BitRLE(u8*& bmpData, s32 size, s32 width, s32 h
|
|||||||
shift = 4;
|
shift = 4;
|
||||||
break;
|
break;
|
||||||
case 1: // end of bmp
|
case 1: // end of bmp
|
||||||
goto exit;
|
delete [] bmpData;
|
||||||
|
bmpData = newBmp;
|
||||||
|
return;
|
||||||
case 2:
|
case 2:
|
||||||
{
|
{
|
||||||
++p; CHECKP(2);
|
++p;
|
||||||
s32 x = (u8)*p; ++p;
|
s32 x = (u8)*p; ++p;
|
||||||
s32 y = (u8)*p; ++p;
|
s32 y = (u8)*p; ++p;
|
||||||
d += x/2 + y*lineWidth;
|
d += x/2 + y*lineWidth;
|
||||||
@ -177,16 +155,15 @@ void CImageLoaderBMP::decompress4BitRLE(u8*& bmpData, s32 size, s32 width, s32 h
|
|||||||
s32 count = (u8)*p; ++p;
|
s32 count = (u8)*p; ++p;
|
||||||
s32 readAdditional = ((2-((count)%2))%2);
|
s32 readAdditional = ((2-((count)%2))%2);
|
||||||
s32 readShift = 4;
|
s32 readShift = 4;
|
||||||
|
s32 i;
|
||||||
|
|
||||||
CHECKP(shiftedCount(count, readShift));
|
for (i=0; i<count; ++i)
|
||||||
CHECKD(shiftedCount(count, shift));
|
|
||||||
for (s32 i=0; i<count; ++i)
|
|
||||||
{
|
{
|
||||||
s32 color = (((u8)*p) >> readShift) & 0x0f;
|
s32 color = (((u8)*p) >> readShift) & 0x0f;
|
||||||
readShift -= 4;
|
readShift -= 4;
|
||||||
if (readShift < 0)
|
if (readShift < 0)
|
||||||
{
|
{
|
||||||
++*p; // <- bug?
|
++*p;
|
||||||
readShift = 4;
|
readShift = 4;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -202,8 +179,7 @@ void CImageLoaderBMP::decompress4BitRLE(u8*& bmpData, s32 size, s32 width, s32 h
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
CHECKP(readAdditional);
|
for (i=0; i<readAdditional; ++i)
|
||||||
for (s32 i=0; i<readAdditional; ++i)
|
|
||||||
++p;
|
++p;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -211,12 +187,10 @@ void CImageLoaderBMP::decompress4BitRLE(u8*& bmpData, s32 size, s32 width, s32 h
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
s32 count = (u8)*p; ++p;
|
s32 count = (u8)*p; ++p;
|
||||||
CHECKP(1);
|
|
||||||
s32 color1 = (u8)*p; color1 = color1 & 0x0f;
|
s32 color1 = (u8)*p; color1 = color1 & 0x0f;
|
||||||
s32 color2 = (u8)*p; color2 = (color2 >> 4) & 0x0f;
|
s32 color2 = (u8)*p; color2 = (color2 >> 4) & 0x0f;
|
||||||
++p;
|
++p;
|
||||||
|
|
||||||
CHECKD(shiftedCount(count, shift));
|
|
||||||
for (s32 i=0; i<count; ++i)
|
for (s32 i=0; i<count; ++i)
|
||||||
{
|
{
|
||||||
u8 mask = 0x0f << shift;
|
u8 mask = 0x0f << shift;
|
||||||
@ -233,14 +207,11 @@ void CImageLoaderBMP::decompress4BitRLE(u8*& bmpData, s32 size, s32 width, s32 h
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
exit:
|
|
||||||
delete [] bmpData;
|
delete [] bmpData;
|
||||||
bmpData = newBmp;
|
bmpData = newBmp;
|
||||||
}
|
}
|
||||||
|
|
||||||
#undef CHECKOFF
|
|
||||||
#undef CHECKP
|
|
||||||
#undef CHECKD
|
|
||||||
|
|
||||||
//! creates a surface from the file
|
//! creates a surface from the file
|
||||||
IImage* CImageLoaderBMP::loadImage(io::IReadFile* file) const
|
IImage* CImageLoaderBMP::loadImage(io::IReadFile* file) const
|
||||||
@ -291,16 +262,12 @@ IImage* CImageLoaderBMP::loadImage(io::IReadFile* file) const
|
|||||||
// read palette
|
// read palette
|
||||||
|
|
||||||
long pos = file->getPos();
|
long pos = file->getPos();
|
||||||
constexpr s32 paletteAllocSize = 256;
|
|
||||||
s32 paletteSize = (header.BitmapDataOffset - pos) / 4;
|
s32 paletteSize = (header.BitmapDataOffset - pos) / 4;
|
||||||
paletteSize = core::clamp(paletteSize, 0, paletteAllocSize);
|
|
||||||
|
|
||||||
s32* paletteData = 0;
|
s32* paletteData = 0;
|
||||||
if (paletteSize)
|
if (paletteSize)
|
||||||
{
|
{
|
||||||
// always allocate an 8-bit palette to ensure enough space
|
paletteData = new s32[paletteSize];
|
||||||
paletteData = new s32[paletteAllocSize];
|
|
||||||
memset(paletteData, 0, paletteAllocSize * sizeof(s32));
|
|
||||||
file->read(paletteData, paletteSize * sizeof(s32));
|
file->read(paletteData, paletteSize * sizeof(s32));
|
||||||
#ifdef __BIG_ENDIAN__
|
#ifdef __BIG_ENDIAN__
|
||||||
for (s32 i=0; i<paletteSize; ++i)
|
for (s32 i=0; i<paletteSize; ++i)
|
||||||
@ -319,17 +286,14 @@ IImage* CImageLoaderBMP::loadImage(io::IReadFile* file) const
|
|||||||
|
|
||||||
file->seek(header.BitmapDataOffset);
|
file->seek(header.BitmapDataOffset);
|
||||||
|
|
||||||
s32 widthInBytes;
|
f32 t = (header.Width) * (header.BPP / 8.0f);
|
||||||
{
|
s32 widthInBytes = (s32)t;
|
||||||
f32 t = (header.Width) * (header.BPP / 8.0f);
|
t -= widthInBytes;
|
||||||
widthInBytes = (s32)t;
|
if (t!=0.0f)
|
||||||
t -= widthInBytes;
|
++widthInBytes;
|
||||||
if (t!=0.0f)
|
|
||||||
++widthInBytes;
|
|
||||||
}
|
|
||||||
|
|
||||||
const s32 lineSize = widthInBytes + ((4-(widthInBytes%4)))%4;
|
s32 lineData = widthInBytes + ((4-(widthInBytes%4)))%4;
|
||||||
pitch = lineSize - widthInBytes;
|
pitch = lineData - widthInBytes;
|
||||||
|
|
||||||
u8* bmpData = new u8[header.BitmapDataSize];
|
u8* bmpData = new u8[header.BitmapDataSize];
|
||||||
file->read(bmpData, header.BitmapDataSize);
|
file->read(bmpData, header.BitmapDataSize);
|
||||||
@ -339,24 +303,15 @@ IImage* CImageLoaderBMP::loadImage(io::IReadFile* file) const
|
|||||||
{
|
{
|
||||||
case 1: // 8 bit rle
|
case 1: // 8 bit rle
|
||||||
decompress8BitRLE(bmpData, header.BitmapDataSize, header.Width, header.Height, pitch);
|
decompress8BitRLE(bmpData, header.BitmapDataSize, header.Width, header.Height, pitch);
|
||||||
header.BitmapDataSize = (header.Width + pitch) * header.Height;
|
|
||||||
break;
|
break;
|
||||||
case 2: // 4 bit rle
|
case 2: // 4 bit rle
|
||||||
decompress4BitRLE(bmpData, header.BitmapDataSize, header.Width, header.Height, pitch);
|
decompress4BitRLE(bmpData, header.BitmapDataSize, header.Width, header.Height, pitch);
|
||||||
header.BitmapDataSize = ((header.Width+1)/2 + pitch) * header.Height;
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (header.BitmapDataSize < lineSize * header.Height)
|
|
||||||
{
|
|
||||||
os::Printer::log("Bitmap data is cut off.", ELL_ERROR);
|
|
||||||
|
|
||||||
delete [] paletteData;
|
|
||||||
delete [] bmpData;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
// create surface
|
// create surface
|
||||||
|
|
||||||
|
// no default constructor from packed area! ARM problem!
|
||||||
core::dimension2d<u32> dim;
|
core::dimension2d<u32> dim;
|
||||||
dim.Width = header.Width;
|
dim.Width = header.Width;
|
||||||
dim.Height = header.Height;
|
dim.Height = header.Height;
|
||||||
|
@ -31,10 +31,10 @@ u8 *CImageLoaderTGA::loadCompressedImage(io::IReadFile *file, const STGAHeader&
|
|||||||
// This was written and sent in by Jon Pry, thank you very much!
|
// This was written and sent in by Jon Pry, thank you very much!
|
||||||
// I only changed the formatting a little bit.
|
// I only changed the formatting a little bit.
|
||||||
|
|
||||||
const u32 bytesPerPixel = header.PixelDepth/8;
|
s32 bytesPerPixel = header.PixelDepth/8;
|
||||||
const u32 imageSize = header.ImageHeight * header.ImageWidth * bytesPerPixel;
|
s32 imageSize = header.ImageHeight * header.ImageWidth * bytesPerPixel;
|
||||||
u8* data = new u8[imageSize];
|
u8* data = new u8[imageSize];
|
||||||
u32 currentByte = 0;
|
s32 currentByte = 0;
|
||||||
|
|
||||||
while(currentByte < imageSize)
|
while(currentByte < imageSize)
|
||||||
{
|
{
|
||||||
@ -45,17 +45,8 @@ u8 *CImageLoaderTGA::loadCompressedImage(io::IReadFile *file, const STGAHeader&
|
|||||||
{
|
{
|
||||||
chunkheader++; // Add 1 To The Value To Get Total Number Of Raw Pixels
|
chunkheader++; // Add 1 To The Value To Get Total Number Of Raw Pixels
|
||||||
|
|
||||||
const u32 bytesToRead = bytesPerPixel * chunkheader;
|
file->read(&data[currentByte], bytesPerPixel * chunkheader);
|
||||||
if ( currentByte+bytesToRead <= imageSize )
|
currentByte += bytesPerPixel * chunkheader;
|
||||||
{
|
|
||||||
file->read(&data[currentByte], bytesToRead);
|
|
||||||
currentByte += bytesToRead;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
os::Printer::log("Compressed TGA file RAW chunk tries writing beyond buffer", file->getFileName(), ELL_WARNING);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -64,27 +55,15 @@ u8 *CImageLoaderTGA::loadCompressedImage(io::IReadFile *file, const STGAHeader&
|
|||||||
// If It's An RLE Header
|
// If It's An RLE Header
|
||||||
chunkheader -= 127; // Subtract 127 To Get Rid Of The ID Bit
|
chunkheader -= 127; // Subtract 127 To Get Rid Of The ID Bit
|
||||||
|
|
||||||
u32 dataOffset = currentByte;
|
s32 dataOffset = currentByte;
|
||||||
if ( dataOffset+bytesPerPixel < imageSize )
|
file->read(&data[dataOffset], bytesPerPixel);
|
||||||
{
|
|
||||||
file->read(&data[dataOffset], bytesPerPixel);
|
|
||||||
currentByte += bytesPerPixel;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
os::Printer::log("Compressed TGA file RLE headertries writing beyond buffer", file->getFileName(), ELL_WARNING);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
for(u32 counter = 1; counter < chunkheader; counter++)
|
currentByte += bytesPerPixel;
|
||||||
|
|
||||||
|
for(s32 counter = 1; counter < chunkheader; counter++)
|
||||||
{
|
{
|
||||||
if ( currentByte + bytesPerPixel <= imageSize )
|
for(s32 elementCounter=0; elementCounter < bytesPerPixel; elementCounter++)
|
||||||
{
|
data[currentByte + elementCounter] = data[dataOffset + elementCounter];
|
||||||
for(u32 elementCounter=0; elementCounter < bytesPerPixel; elementCounter++)
|
|
||||||
{
|
|
||||||
data[currentByte + elementCounter] = data[dataOffset + elementCounter];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
currentByte += bytesPerPixel;
|
currentByte += bytesPerPixel;
|
||||||
}
|
}
|
||||||
@ -137,17 +116,8 @@ IImage* CImageLoaderTGA::loadImage(io::IReadFile* file) const
|
|||||||
|
|
||||||
if (header.ColorMapType)
|
if (header.ColorMapType)
|
||||||
{
|
{
|
||||||
// Create 32 bit palette
|
// create 32 bit palette
|
||||||
const irr::u16 paletteSize = core::max_((u16)256, header.ColorMapLength); // ColorMapLength can lie, but so far we only use palette for 8-bit, so ensure it has 256 entries
|
palette = new u32[ header.ColorMapLength];
|
||||||
palette = new u32[paletteSize];
|
|
||||||
|
|
||||||
if( paletteSize > header.ColorMapLength )
|
|
||||||
{
|
|
||||||
// To catch images using palette colors with invalid indices
|
|
||||||
const irr::u32 errorCol = irr::video::SColor(255,255, 0, 205).color; // bright magenta
|
|
||||||
for ( irr::u16 i = header.ColorMapLength; i< paletteSize; ++i )
|
|
||||||
palette[i] = errorCol;
|
|
||||||
}
|
|
||||||
|
|
||||||
// read color map
|
// read color map
|
||||||
u8 * colorMap = new u8[header.ColorMapEntrySize/8 * header.ColorMapLength];
|
u8 * colorMap = new u8[header.ColorMapEntrySize/8 * header.ColorMapLength];
|
||||||
@ -178,7 +148,7 @@ IImage* CImageLoaderTGA::loadImage(io::IReadFile* file) const
|
|||||||
header.ImageType == 3 // Uncompressed, black and white images
|
header.ImageType == 3 // Uncompressed, black and white images
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
const s32 imageSize = header.ImageHeight * header.ImageWidth * (header.PixelDepth/8);
|
const s32 imageSize = header.ImageHeight * header.ImageWidth * header.PixelDepth/8;
|
||||||
data = new u8[imageSize];
|
data = new u8[imageSize];
|
||||||
file->read(data, imageSize);
|
file->read(data, imageSize);
|
||||||
}
|
}
|
||||||
@ -213,28 +183,14 @@ IImage* CImageLoaderTGA::loadImage(io::IReadFile* file) const
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
switch ( header.ColorMapEntrySize )
|
image = new CImage(ECF_A1R5G5B5,
|
||||||
{
|
core::dimension2d<u32>(header.ImageWidth, header.ImageHeight));
|
||||||
case 16:
|
if (image)
|
||||||
image = new CImage(ECF_A1R5G5B5, core::dimension2d<u32>(header.ImageWidth, header.ImageHeight));
|
CColorConverter::convert8BitTo16Bit((u8*)data,
|
||||||
if ( image )
|
(s16*)image->getData(),
|
||||||
CColorConverter::convert8BitTo16Bit((u8*)data,
|
header.ImageWidth,header.ImageHeight,
|
||||||
(s16*)image->getData(),
|
(s32*) palette, 0,
|
||||||
header.ImageWidth,header.ImageHeight,
|
(header.ImageDescriptor&0x20)==0);
|
||||||
(s32*) palette, 0,
|
|
||||||
(header.ImageDescriptor&0x20)==0);
|
|
||||||
break;
|
|
||||||
// Note: 24 bit with palette would need a 24 bit palette, too lazy doing that now (textures will prefer 32-bit later anyway)
|
|
||||||
default:
|
|
||||||
image = new CImage(ECF_A8R8G8B8, core::dimension2d<u32>(header.ImageWidth, header.ImageHeight));
|
|
||||||
if ( image )
|
|
||||||
CColorConverter::convert8BitTo32Bit((u8*)data,
|
|
||||||
(u8*)image->getData(),
|
|
||||||
header.ImageWidth,header.ImageHeight,
|
|
||||||
(u8*) palette, 0,
|
|
||||||
(header.ImageDescriptor&0x20)==0);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -147,11 +147,6 @@ CIrrDeviceLinux::CIrrDeviceLinux(const SIrrlichtCreationParameters& param)
|
|||||||
// create keymap
|
// create keymap
|
||||||
createKeyMap();
|
createKeyMap();
|
||||||
|
|
||||||
// initialize X11 thread safety
|
|
||||||
// libX11 1.8+ has this on by default
|
|
||||||
// without it, multi-threaded GL drivers may crash
|
|
||||||
XInitThreads();
|
|
||||||
|
|
||||||
// create window
|
// create window
|
||||||
if (CreationParams.DriverType != video::EDT_NULL)
|
if (CreationParams.DriverType != video::EDT_NULL)
|
||||||
{
|
{
|
||||||
@ -987,7 +982,7 @@ bool CIrrDeviceLinux::run()
|
|||||||
os::Printer::log("XLookupNone", ELL_INFORMATION);
|
os::Printer::log("XLookupNone", ELL_INFORMATION);
|
||||||
else if ( status == XLookupKeySym )
|
else if ( status == XLookupKeySym )
|
||||||
// Getting this also when user did not set setlocale(LC_ALL, ""); and using an unknown locale
|
// Getting this also when user did not set setlocale(LC_ALL, ""); and using an unknown locale
|
||||||
// XSupportsLocale doesn't seem to catch that unfortunately - any other ideas to catch it are welcome.
|
// XSupportsLocale doesn't seeem to catch that unfortunately - any other ideas to catch it are welcome.
|
||||||
os::Printer::log("XLookupKeySym", ELL_INFORMATION);
|
os::Printer::log("XLookupKeySym", ELL_INFORMATION);
|
||||||
else if ( status == XBufferOverflow )
|
else if ( status == XBufferOverflow )
|
||||||
os::Printer::log("XBufferOverflow", ELL_INFORMATION);
|
os::Printer::log("XBufferOverflow", ELL_INFORMATION);
|
||||||
@ -2063,7 +2058,7 @@ Cursor CIrrDeviceLinux::TextureToMonochromeCursor(irr::video::ITexture * tex, co
|
|||||||
ZPixmap, // XYBitmap (depth=1), ZPixmap(depth=x)
|
ZPixmap, // XYBitmap (depth=1), ZPixmap(depth=x)
|
||||||
0, 0, sourceRect.getWidth(), sourceRect.getHeight(),
|
0, 0, sourceRect.getWidth(), sourceRect.getHeight(),
|
||||||
32, // bitmap_pad,
|
32, // bitmap_pad,
|
||||||
0// bytes_per_line (0 means continuous in memory)
|
0// bytes_per_line (0 means continuos in memory)
|
||||||
);
|
);
|
||||||
sourceImage->data = new char[sourceImage->height * sourceImage->bytes_per_line];
|
sourceImage->data = new char[sourceImage->height * sourceImage->bytes_per_line];
|
||||||
XImage * maskImage = XCreateImage(XDisplay, VisualInfo->visual,
|
XImage * maskImage = XCreateImage(XDisplay, VisualInfo->visual,
|
||||||
@ -2256,7 +2251,7 @@ CIrrDeviceLinux::CCursorControl::CCursorControl(CIrrDeviceLinux* dev, bool null)
|
|||||||
CIrrDeviceLinux::CCursorControl::~CCursorControl()
|
CIrrDeviceLinux::CCursorControl::~CCursorControl()
|
||||||
{
|
{
|
||||||
// Do not clearCursors here as the display is already closed
|
// Do not clearCursors here as the display is already closed
|
||||||
// TODO (cutealien): dropping cursorcontrol earlier might work, not sure about reason why that's done in stub currently.
|
// TODO (cutealien): droping cursorcontrol earlier might work, not sure about reason why that's done in stub currently.
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef _IRR_COMPILE_WITH_X11_
|
#ifdef _IRR_COMPILE_WITH_X11_
|
||||||
|
@ -22,7 +22,7 @@ namespace irr
|
|||||||
class CIrrDeviceMacOSX;
|
class CIrrDeviceMacOSX;
|
||||||
}
|
}
|
||||||
|
|
||||||
@interface CIrrDelegateOSX : NSObject <NSApplicationDelegate, NSWindowDelegate>
|
@interface CIrrDelegateOSX : NSObject
|
||||||
|
|
||||||
- (id)initWithDevice:(irr::CIrrDeviceMacOSX*)device;
|
- (id)initWithDevice:(irr::CIrrDeviceMacOSX*)device;
|
||||||
- (void)terminate:(id)sender;
|
- (void)terminate:(id)sender;
|
||||||
|
@ -564,7 +564,7 @@ CIrrDeviceMacOSX::CIrrDeviceMacOSX(const SIrrlichtCreationParameters& param)
|
|||||||
{
|
{
|
||||||
[[NSAutoreleasePool alloc] init];
|
[[NSAutoreleasePool alloc] init];
|
||||||
[[NSApplication sharedApplication] activateIgnoringOtherApps:YES];
|
[[NSApplication sharedApplication] activateIgnoringOtherApps:YES];
|
||||||
[[NSApplication sharedApplication] setDelegate:[[[CIrrDelegateOSX alloc] initWithDevice:this] autorelease]];
|
[NSApp setDelegate:(id<NSApplicationDelegate>)[[[CIrrDelegateOSX alloc] initWithDevice:this] autorelease]];
|
||||||
|
|
||||||
// Create menu
|
// Create menu
|
||||||
|
|
||||||
@ -685,7 +685,7 @@ bool CIrrDeviceMacOSX::createWindow()
|
|||||||
{
|
{
|
||||||
if (Window)
|
if (Window)
|
||||||
{
|
{
|
||||||
[Window setDelegate:(CIrrDelegateOSX *)[NSApp delegate]];
|
[Window setDelegate:(id<NSWindowDelegate>)[NSApp delegate]];
|
||||||
[Window setAcceptsMouseMovedEvents:TRUE];
|
[Window setAcceptsMouseMovedEvents:TRUE];
|
||||||
[Window setIsVisible:TRUE];
|
[Window setIsVisible:TRUE];
|
||||||
[Window makeKeyAndOrderFront:nil];
|
[Window makeKeyAndOrderFront:nil];
|
||||||
|
@ -229,7 +229,7 @@ CIrrDeviceSDL::CIrrDeviceSDL(const SIrrlichtCreationParameters& param)
|
|||||||
Window((SDL_Window*)param.WindowId), SDL_Flags(0),
|
Window((SDL_Window*)param.WindowId), SDL_Flags(0),
|
||||||
MouseX(0), MouseY(0), MouseXRel(0), MouseYRel(0), MouseButtonStates(0),
|
MouseX(0), MouseY(0), MouseXRel(0), MouseYRel(0), MouseButtonStates(0),
|
||||||
Width(param.WindowSize.Width), Height(param.WindowSize.Height),
|
Width(param.WindowSize.Width), Height(param.WindowSize.Height),
|
||||||
Resizable(param.WindowResizable == 1 ? true : false), CurrentTouchCount(0)
|
Resizable(param.WindowResizable == 1 ? true : false)
|
||||||
{
|
{
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
setDebugName("CIrrDeviceSDL");
|
setDebugName("CIrrDeviceSDL");
|
||||||
@ -254,21 +254,14 @@ CIrrDeviceSDL::CIrrDeviceSDL(const SIrrlichtCreationParameters& param)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Minetest has its own code to synthesize mouse events from touch events,
|
|
||||||
// so we prevent SDL from doing it.
|
|
||||||
SDL_SetHint(SDL_HINT_TOUCH_MOUSE_EVENTS, "0");
|
|
||||||
SDL_SetHint(SDL_HINT_MOUSE_TOUCH_EVENTS, "0");
|
|
||||||
|
|
||||||
// create keymap
|
// create keymap
|
||||||
createKeyMap();
|
createKeyMap();
|
||||||
|
|
||||||
// create window
|
// create window
|
||||||
if (CreationParams.DriverType != video::EDT_NULL)
|
if (CreationParams.DriverType != video::EDT_NULL)
|
||||||
{
|
{
|
||||||
if (!createWindow()) {
|
// create the window, only if we do not use the null device
|
||||||
Close = true;
|
createWindow();
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -562,11 +555,7 @@ bool CIrrDeviceSDL::run()
|
|||||||
|
|
||||||
irrevent.EventType = irr::EET_MOUSE_INPUT_EVENT;
|
irrevent.EventType = irr::EET_MOUSE_INPUT_EVENT;
|
||||||
irrevent.MouseInput.Event = irr::EMIE_MOUSE_WHEEL;
|
irrevent.MouseInput.Event = irr::EMIE_MOUSE_WHEEL;
|
||||||
#if SDL_VERSION_ATLEAST(2, 0, 18)
|
|
||||||
irrevent.MouseInput.Wheel = SDL_event.wheel.preciseY;
|
irrevent.MouseInput.Wheel = SDL_event.wheel.preciseY;
|
||||||
#else
|
|
||||||
irrevent.MouseInput.Wheel = SDL_event.wheel.y;
|
|
||||||
#endif
|
|
||||||
irrevent.MouseInput.Shift = (keymod & KMOD_SHIFT) != 0;
|
irrevent.MouseInput.Shift = (keymod & KMOD_SHIFT) != 0;
|
||||||
irrevent.MouseInput.Control = (keymod & KMOD_CTRL) != 0;
|
irrevent.MouseInput.Control = (keymod & KMOD_CTRL) != 0;
|
||||||
irrevent.MouseInput.X = MouseX;
|
irrevent.MouseInput.X = MouseX;
|
||||||
@ -684,7 +673,7 @@ bool CIrrDeviceSDL::run()
|
|||||||
{
|
{
|
||||||
irrevent.EventType = irr::EET_STRING_INPUT_EVENT;
|
irrevent.EventType = irr::EET_STRING_INPUT_EVENT;
|
||||||
irrevent.StringInput.Str = new core::stringw();
|
irrevent.StringInput.Str = new core::stringw();
|
||||||
irr::core::utf8ToWString(*irrevent.StringInput.Str, SDL_event.text.text);
|
irr::core::multibyteToWString(*irrevent.StringInput.Str, SDL_event.text.text);
|
||||||
postEventFromUser(irrevent);
|
postEventFromUser(irrevent);
|
||||||
delete irrevent.StringInput.Str;
|
delete irrevent.StringInput.Str;
|
||||||
irrevent.StringInput.Str = NULL;
|
irrevent.StringInput.Str = NULL;
|
||||||
@ -752,45 +741,6 @@ bool CIrrDeviceSDL::run()
|
|||||||
postEventFromUser(irrevent);
|
postEventFromUser(irrevent);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case SDL_FINGERDOWN:
|
|
||||||
irrevent.EventType = EET_TOUCH_INPUT_EVENT;
|
|
||||||
irrevent.TouchInput.Event = ETIE_PRESSED_DOWN;
|
|
||||||
irrevent.TouchInput.ID = SDL_event.tfinger.fingerId;
|
|
||||||
irrevent.TouchInput.X = SDL_event.tfinger.x * Width;
|
|
||||||
irrevent.TouchInput.Y = SDL_event.tfinger.y * Height;
|
|
||||||
CurrentTouchCount++;
|
|
||||||
irrevent.TouchInput.touchedCount = CurrentTouchCount;
|
|
||||||
|
|
||||||
postEventFromUser(irrevent);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case SDL_FINGERMOTION:
|
|
||||||
irrevent.EventType = EET_TOUCH_INPUT_EVENT;
|
|
||||||
irrevent.TouchInput.Event = ETIE_MOVED;
|
|
||||||
irrevent.TouchInput.ID = SDL_event.tfinger.fingerId;
|
|
||||||
irrevent.TouchInput.X = SDL_event.tfinger.x * Width;
|
|
||||||
irrevent.TouchInput.Y = SDL_event.tfinger.y * Height;
|
|
||||||
irrevent.TouchInput.touchedCount = CurrentTouchCount;
|
|
||||||
|
|
||||||
postEventFromUser(irrevent);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case SDL_FINGERUP:
|
|
||||||
irrevent.EventType = EET_TOUCH_INPUT_EVENT;
|
|
||||||
irrevent.TouchInput.Event = ETIE_LEFT_UP;
|
|
||||||
irrevent.TouchInput.ID = SDL_event.tfinger.fingerId;
|
|
||||||
irrevent.TouchInput.X = SDL_event.tfinger.x * Width;
|
|
||||||
irrevent.TouchInput.Y = SDL_event.tfinger.y * Height;
|
|
||||||
// To match Android behavior, still count the pointer that was
|
|
||||||
// just released.
|
|
||||||
irrevent.TouchInput.touchedCount = CurrentTouchCount;
|
|
||||||
if (CurrentTouchCount > 0) {
|
|
||||||
CurrentTouchCount--;
|
|
||||||
}
|
|
||||||
|
|
||||||
postEventFromUser(irrevent);
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
} // end switch
|
} // end switch
|
||||||
@ -978,7 +928,7 @@ void CIrrDeviceSDL::sleep(u32 timeMs, bool pauseTimer)
|
|||||||
void CIrrDeviceSDL::setWindowCaption(const wchar_t* text)
|
void CIrrDeviceSDL::setWindowCaption(const wchar_t* text)
|
||||||
{
|
{
|
||||||
core::stringc textc;
|
core::stringc textc;
|
||||||
core::wStringToUTF8(textc, text);
|
core::wStringToMultibyte(textc, text);
|
||||||
SDL_SetWindowTitle(Window, textc.c_str());
|
SDL_SetWindowTitle(Window, textc.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user