mirror of
https://github.com/simtactics/niotso.git
synced 2025-03-22 10:52:20 +00:00
New Scene class definition. Also fixed a compile error for some users involving the definition of IID_IXAudio2
This commit is contained in:
parent
8bb608d5ce
commit
2e7f3b24ca
9 changed files with 85 additions and 10 deletions
|
@ -24,7 +24,7 @@ if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_GNUCXX)
|
||||||
set(ASMFLAGS "-O3 -F win32")
|
set(ASMFLAGS "-O3 -F win32")
|
||||||
|
|
||||||
set(CFLAGS_LANG_C "-ansi")
|
set(CFLAGS_LANG_C "-ansi")
|
||||||
set(CFLAGS_LANG_CPP "-fno-exceptions -fno-rtti")
|
set(CFLAGS_LANG_CPP "-fno-exceptions -fno-rtti -fno-threadsafe-statics")
|
||||||
|
|
||||||
|
|
||||||
####
|
####
|
||||||
|
@ -40,10 +40,10 @@ if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_GNUCXX)
|
||||||
|
|
||||||
# Size
|
# Size
|
||||||
set(CFLAGS_SIZE "${CFLAGS} -Os -g0 -fomit-frame-pointer -ffast-math -fmerge-all-constants -funsafe-loop-optimizations -fmerge-all-constants -fsched-pressure")
|
set(CFLAGS_SIZE "${CFLAGS} -Os -g0 -fomit-frame-pointer -ffast-math -fmerge-all-constants -funsafe-loop-optimizations -fmerge-all-constants -fsched-pressure")
|
||||||
set(LDFLAGS_SIZE "${LDFLAGS} -s")
|
set(LDFLAGS_SIZE "${LDFLAGS} -s -fwhole-program")
|
||||||
|
|
||||||
# Speed
|
# Speed
|
||||||
set(CFLAGS_SPEED "${CFLAGS} -O3 -g0 -fomit-frame-pointer -ffast-math -fmerge-all-constants -funsafe-loop-optimizations -fmerge-all-constants -fsched-pressure -fmodulo-sched -fmodulo-sched-allow-regmoves -fgcse-sm -fgcse-las -fsched-spec-load -fsched-spec-load-dangerous -fsched-stalled-insns=0 -fsched-stalled-insns-dep -fsched2-use-superblocks -fipa-pta -fipa-matrix-reorg -ftree-loop-linear -floop-interchange -floop-strip-mine -floop-block -fgraphite-identity -floop-parallelize-all -ftree-loop-distribution -ftree-loop-im -ftree-loop-ivcanon -fivopts -fvect-cost-model -fvariable-expansion-in-unroller -fbranch-target-load-optimize -maccumulate-outgoing-args -fwhole-program -flto")
|
set(CFLAGS_SPEED "${CFLAGS} -O3 -g0 -fomit-frame-pointer -ffast-math -fmerge-all-constants -funsafe-loop-optimizations -fmerge-all-constants -fsched-pressure -fmodulo-sched -fmodulo-sched-allow-regmoves -fgcse-sm -fgcse-las -fsched-spec-load -fsched-spec-load-dangerous -fsched-stalled-insns=0 -fsched-stalled-insns-dep -fsched2-use-superblocks -fipa-pta -fipa-matrix-reorg -ftree-loop-linear -floop-interchange -floop-strip-mine -floop-block -fgraphite-identity -floop-parallelize-all -ftree-loop-distribution -ftree-loop-im -ftree-loop-ivcanon -fivopts -fvect-cost-model -fvariable-expansion-in-unroller -fbranch-target-load-optimize -maccumulate-outgoing-args -flto")
|
||||||
set(LDFLAGS_SPEED "${LDFLAGS} -s -fwhole-program -flto")
|
set(LDFLAGS_SPEED "${LDFLAGS} -s -fwhole-program -flto")
|
||||||
else()
|
else()
|
||||||
# Debug
|
# Debug
|
||||||
|
|
5
Client/Audio/windows/xaudio2.cpp
Normal file
5
Client/Audio/windows/xaudio2.cpp
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
#include <initguid.h>
|
||||||
|
|
||||||
|
DEFINE_GUID(CLSID_XAudio2, 0xe21a7345, 0xeb21, 0x468e, 0xbe, 0x50, 0x80, 0x4d, 0xb9, 0x7c, 0xf7, 0x08);
|
||||||
|
DEFINE_GUID(CLSID_XAudio2_Debug, 0xf7a76c21, 0x53d4, 0x46bb, 0xac, 0x53, 0x8b, 0x45, 0x9c, 0xae, 0x46, 0xbd);
|
||||||
|
DEFINE_GUID(IID_IXAudio2, 0x8bcf1f58, 0x9fe7, 0x4583, 0x8a, 0xc6, 0xe2, 0xad, 0xc4, 0x65, 0xc8, 0xbb);
|
|
@ -9,7 +9,7 @@
|
||||||
#undef NULL
|
#undef NULL
|
||||||
#define NULL 0
|
#define NULL 0
|
||||||
|
|
||||||
#include <initguid.h>
|
#include <guiddef.h>
|
||||||
#include <mmreg.h>
|
#include <mmreg.h>
|
||||||
|
|
||||||
DEFINE_GUID(CLSID_XAudio2, 0xe21a7345, 0xeb21, 0x468e, 0xbe, 0x50, 0x80, 0x4d, 0xb9, 0x7c, 0xf7, 0x08);
|
DEFINE_GUID(CLSID_XAudio2, 0xe21a7345, 0xeb21, 0x468e, 0xbe, 0x50, 0x80, 0x4d, 0xb9, 0x7c, 0xf7, 0x08);
|
||||||
|
|
|
@ -6,6 +6,7 @@ if(WIN32)
|
||||||
Client.cpp
|
Client.cpp
|
||||||
MessageHandler.cpp
|
MessageHandler.cpp
|
||||||
Audio/Startup.cpp
|
Audio/Startup.cpp
|
||||||
|
Audio/windows/XAudio2.cpp
|
||||||
Graphics/Startup.cpp
|
Graphics/Startup.cpp
|
||||||
Graphics/Viewport.cpp
|
Graphics/Viewport.cpp
|
||||||
resources/Resource.rc
|
resources/Resource.rc
|
||||||
|
|
|
@ -26,6 +26,8 @@ namespace Window {
|
||||||
int CreateWindowInvisible(HINSTANCE hInst, unsigned Width, unsigned Height, bool Fullscreen);
|
int CreateWindowInvisible(HINSTANCE hInst, unsigned Width, unsigned Height, bool Fullscreen);
|
||||||
void Shutdown();
|
void Shutdown();
|
||||||
|
|
||||||
|
Scene * CurrentScene;
|
||||||
|
|
||||||
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE, LPSTR, int)
|
int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE, LPSTR, int)
|
||||||
{
|
{
|
||||||
int result;
|
int result;
|
||||||
|
@ -75,6 +77,9 @@ int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE, LPSTR, int)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CurrentScene = new LoginScreen();
|
||||||
|
CurrentScene->Render();
|
||||||
|
|
||||||
MSG msg;
|
MSG msg;
|
||||||
while(GetMessage(&msg, NULL, 0, 0))
|
while(GetMessage(&msg, NULL, 0, 0))
|
||||||
{
|
{
|
||||||
|
|
|
@ -27,8 +27,10 @@
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
#include "System/System.hpp"
|
#include "System/System.hpp"
|
||||||
#include "Resources/Resource.h"
|
#include "Resources/Resource.h"
|
||||||
#include "Graphics/Graphics.hpp"
|
|
||||||
#include "Audio/Audio.hpp"
|
#include "Audio/Audio.hpp"
|
||||||
|
#include "Graphics/Graphics.hpp"
|
||||||
|
#include "Scene/Scene.hpp"
|
||||||
|
|
||||||
//IsometricEngine.cpp
|
//IsometricEngine.cpp
|
||||||
namespace Window {
|
namespace Window {
|
||||||
|
|
58
Client/Scene/Scene.hpp
Normal file
58
Client/Scene/Scene.hpp
Normal file
|
@ -0,0 +1,58 @@
|
||||||
|
/*
|
||||||
|
Niotso - Copyright (C) 2012 Fatbag <X-Fi6@phppoll.org>
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
class Scene {
|
||||||
|
const float TickPeriod;
|
||||||
|
float TimeDelta;
|
||||||
|
virtual int Run(float TimeDelta) = 0;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
Scene(float c) : TickPeriod(c), TimeDelta(0) {}
|
||||||
|
|
||||||
|
public:
|
||||||
|
int RunFor(float TimeDelta) {
|
||||||
|
if(TickPeriod == 0){
|
||||||
|
return Run(TimeDelta);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Redraw = false;
|
||||||
|
this->TimeDelta += TimeDelta;
|
||||||
|
while(this->TimeDelta >= 0){
|
||||||
|
int result = Run(TickPeriod);
|
||||||
|
if(result == System::SHUTDOWN)
|
||||||
|
return System::SHUTDOWN;
|
||||||
|
if(result > 0) Redraw = true;
|
||||||
|
this->TimeDelta -= TickPeriod;
|
||||||
|
}
|
||||||
|
return (Redraw) ? 1 : -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void Render() = 0;
|
||||||
|
};
|
||||||
|
|
||||||
|
class LoginScreen : public Scene {
|
||||||
|
public: LoginScreen() : Scene(1.0f/15) {}
|
||||||
|
|
||||||
|
private:
|
||||||
|
int Run(float){
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
public:
|
||||||
|
void Render(){
|
||||||
|
}
|
||||||
|
};
|
|
@ -26,6 +26,10 @@ namespace System {
|
||||||
//Event objects
|
//Event objects
|
||||||
extern HANDLE Shutdown;
|
extern HANDLE Shutdown;
|
||||||
extern HANDLE Initialized[2], Terminated[2];
|
extern HANDLE Initialized[2], Terminated[2];
|
||||||
|
|
||||||
|
enum {
|
||||||
|
SHUTDOWN
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
enum {
|
enum {
|
||||||
|
|
|
@ -445,7 +445,6 @@ void KillGLWindow()
|
||||||
hInstance = NULL;
|
hInstance = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef bool (APIENTRY *PFNWGLSWAPINTERVALFARPROC)(int);
|
|
||||||
BOOL CreateGLWindow(const char * title, int width, int height, int bits, bool fullscreenflag)
|
BOOL CreateGLWindow(const char * title, int width, int height, int bits, bool fullscreenflag)
|
||||||
{
|
{
|
||||||
fullscreen = fullscreenflag;
|
fullscreen = fullscreenflag;
|
||||||
|
@ -531,7 +530,7 @@ BOOL CreateGLWindow(const char * title, int width, int height, int bits, bool fu
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned PixelFormat = ChoosePixelFormat(hDC, &pfd);
|
int PixelFormat = ChoosePixelFormat(hDC, &pfd);
|
||||||
if(!PixelFormat){
|
if(!PixelFormat){
|
||||||
KillGLWindow();
|
KillGLWindow();
|
||||||
MessageBox(NULL, "Can't find a suitable PixelFormat.", NULL, MB_OK | MB_ICONERROR);
|
MessageBox(NULL, "Can't find a suitable PixelFormat.", NULL, MB_OK | MB_ICONERROR);
|
||||||
|
@ -568,9 +567,10 @@ BOOL CreateGLWindow(const char * title, int width, int height, int bits, bool fu
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
PFNWGLSWAPINTERVALFARPROC wglSwapIntervalEXT = 0;
|
BOOL (WINAPI *wglSwapIntervalEXT)(int) = (BOOL (WINAPI *)(int)) wglGetProcAddress("wglSwapIntervalEXT");
|
||||||
wglSwapIntervalEXT = (PFNWGLSWAPINTERVALFARPROC)wglGetProcAddress("wglSwapIntervalEXT");
|
|
||||||
if(wglSwapIntervalEXT) wglSwapIntervalEXT(1);
|
if(wglSwapIntervalEXT) wglSwapIntervalEXT(1);
|
||||||
|
int (WINAPI *wglGetSwapIntervalEXT)(void) = (int (WINAPI *)(void)) wglGetProcAddress("wglGetSwapIntervalEXT");
|
||||||
|
if(wglGetSwapIntervalEXT) wglGetSwapIntervalEXT(); //Seems necessary on some cards
|
||||||
|
|
||||||
QueryPerformanceFrequency(&ClockFreq);
|
QueryPerformanceFrequency(&ClockFreq);
|
||||||
QueryPerformanceCounter(&PreviousTime);
|
QueryPerformanceCounter(&PreviousTime);
|
||||||
|
@ -587,7 +587,7 @@ LRESULT CALLBACK WndProc(HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
|
||||||
}else if(wParam == VK_F11 && !keys[VK_F11]){
|
}else if(wParam == VK_F11 && !keys[VK_F11]){
|
||||||
KillGLWindow();
|
KillGLWindow();
|
||||||
fullscreen = !fullscreen;
|
fullscreen = !fullscreen;
|
||||||
if(!CreateGLWindow("libvitaboy - Renderer",640,480,16,fullscreen)){
|
if(!CreateGLWindow("libvitaboy - Renderer",640,480,24,fullscreen)){
|
||||||
PostQuitMessage(0);
|
PostQuitMessage(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue