mirror of
https://github.com/haya3218/SDfmL.git
synced 2024-08-14 23:57:09 +00:00
Fix music, fix cameras, fix shit
This commit is contained in:
parent
b412a3b6cf
commit
98dee3e698
6 changed files with 177 additions and 63 deletions
|
@ -9,6 +9,7 @@ set(SDL2_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/src/SDL2/")
|
||||||
set(OUT_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/src/SoLoud/")
|
set(OUT_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/src/SoLoud/")
|
||||||
set(OUT2_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/src/SoLoud/MIDI/")
|
set(OUT2_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/src/SoLoud/MIDI/")
|
||||||
set(OUT3_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/src/toml/")
|
set(OUT3_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/src/toml/")
|
||||||
|
set(OUT4_INCLUDE_DIRS "${CMAKE_CURRENT_LIST_DIR}/src/sdfml/")
|
||||||
|
|
||||||
# Support both 32 and 64 bit builds
|
# Support both 32 and 64 bit builds
|
||||||
# Someone make a pull request to support MingW
|
# Someone make a pull request to support MingW
|
||||||
|
@ -29,6 +30,7 @@ include_directories(${SDL2_INCLUDE_DIRS})
|
||||||
include_directories(${OUT_INCLUDE_DIRS})
|
include_directories(${OUT_INCLUDE_DIRS})
|
||||||
include_directories(${OUT2_INCLUDE_DIRS})
|
include_directories(${OUT2_INCLUDE_DIRS})
|
||||||
include_directories(${OUT3_INCLUDE_DIRS})
|
include_directories(${OUT3_INCLUDE_DIRS})
|
||||||
|
include_directories(${OUT4_INCLUDE_DIRS})
|
||||||
include_directories(${CMAKE_CURRENT_LIST_DIR}/src)
|
include_directories(${CMAKE_CURRENT_LIST_DIR}/src)
|
||||||
|
|
||||||
# add EVERY FUCKING source file to SOURCES
|
# add EVERY FUCKING source file to SOURCES
|
||||||
|
@ -44,6 +46,8 @@ FILE(GLOB SOURCES "${CMAKE_CURRENT_LIST_DIR}/src/*.cpp"
|
||||||
"${CMAKE_CURRENT_LIST_DIR}/src/SoLoud/MIDI/soloud_midi.h"
|
"${CMAKE_CURRENT_LIST_DIR}/src/SoLoud/MIDI/soloud_midi.h"
|
||||||
"${CMAKE_CURRENT_LIST_DIR}/src/SoLoud/MIDI/*.cpp"
|
"${CMAKE_CURRENT_LIST_DIR}/src/SoLoud/MIDI/*.cpp"
|
||||||
"${CMAKE_CURRENT_LIST_DIR}/src/toml/*.hpp"
|
"${CMAKE_CURRENT_LIST_DIR}/src/toml/*.hpp"
|
||||||
|
"${CMAKE_CURRENT_LIST_DIR}/src/sdfml/*.cpp"
|
||||||
|
"${CMAKE_CURRENT_LIST_DIR}/src/sdfml/*.hpp"
|
||||||
)
|
)
|
||||||
|
|
||||||
# set c++ std to 17
|
# set c++ std to 17
|
||||||
|
|
|
@ -4,6 +4,7 @@ A wrapper build around SDL2, some of its libraries, and SoLoud to make a lot of
|
||||||
more easier to use.
|
more easier to use.
|
||||||
|
|
||||||
Stuff like:
|
Stuff like:
|
||||||
|
|
||||||
- Rendering functions
|
- Rendering functions
|
||||||
- Object system
|
- Object system
|
||||||
- Sound
|
- Sound
|
||||||
|
@ -11,12 +12,13 @@ Stuff like:
|
||||||
- and most possibly, more.... idk.
|
- and most possibly, more.... idk.
|
||||||
- Less dll binary clutter!
|
- Less dll binary clutter!
|
||||||
|
|
||||||
# How the shit to use it den
|
## How the shit to use it den
|
||||||
|
|
||||||
Currently, it only supports MSVC, but you could probably tweak CMakeLists.txt to be able to use
|
Currently, it only supports MSVC, but you could probably tweak CMakeLists.txt to be able to use
|
||||||
MingW, or GCC.
|
MingW, or GCC.
|
||||||
|
|
||||||
## Requirements
|
### Requirements
|
||||||
|
|
||||||
- CMake, to build the damn thing
|
- CMake, to build the damn thing
|
||||||
- SDL2 and SDL_ttf 2.0, duh
|
- SDL2 and SDL_ttf 2.0, duh
|
||||||
- SoLoud (static library)
|
- SoLoud (static library)
|
||||||
|
@ -35,4 +37,4 @@ You know how to place them. It's fucking common sense.
|
||||||
- After successfully making the build files, run `cmake --build --config Release` to build it without the use of VStudio.
|
- After successfully making the build files, run `cmake --build --config Release` to build it without the use of VStudio.
|
||||||
- If everything worked well, congratulations! You have just compiled a shitty program.
|
- If everything worked well, congratulations! You have just compiled a shitty program.
|
||||||
|
|
||||||
`src/Main.cpp` should contain example code with some explanations.
|
`src/Main.cpp` should contain example code with some explanations.
|
||||||
|
|
14
src/Main.cpp
14
src/Main.cpp
|
@ -24,19 +24,17 @@
|
||||||
|
|
||||||
class ExampleState : public sdfml::sdState {
|
class ExampleState : public sdfml::sdState {
|
||||||
public:
|
public:
|
||||||
sdfml::musplayer pl;
|
|
||||||
sdfml::sdAnimatedSprite example;
|
sdfml::sdAnimatedSprite example;
|
||||||
sdfml::sdCam camera;
|
sdfml::sdSprite bg1;
|
||||||
|
SDL_Rect camera = {0, 0, 640, 480};
|
||||||
// vector<sdfml::sdSprite> bgs;
|
// vector<sdfml::sdSprite> bgs;
|
||||||
virtual void create() {
|
virtual void create() {
|
||||||
camera.pos = {0, 0};
|
|
||||||
camera.size = {sdfml::mContext.size.x, sdfml::mContext.size.y};
|
|
||||||
example.create(50, 50, "data/images/smile.png");
|
example.create(50, 50, "data/images/smile.png");
|
||||||
example.AddAnimation("idle", {{0, 0, 50, 50}, {50, 0, 50, 50}});
|
example.AddAnimation("idle", {{0, 0, 50, 50}, {50, 0, 50, 50}});
|
||||||
example.PlayAnimation("idle");
|
example.PlayAnimation("idle");
|
||||||
example.framerate = 1;
|
example.framerate = 1;
|
||||||
//example.attachCamera(camera);
|
sdfml::sound.music.playMod("data/music/DOPE.it");
|
||||||
pl.playSFX("data/sounds/puch.wav");
|
example.updateCamera(&camera);
|
||||||
add(&example);
|
add(&example);
|
||||||
}
|
}
|
||||||
virtual void update(float elapsed) {
|
virtual void update(float elapsed) {
|
||||||
|
@ -49,8 +47,7 @@ class ExampleState : public sdfml::sdState {
|
||||||
if (sdfml::key_pressed(SDL_SCANCODE_DOWN))
|
if (sdfml::key_pressed(SDL_SCANCODE_DOWN))
|
||||||
example.y += 1;
|
example.y += 1;
|
||||||
|
|
||||||
//sdfml::focusCamera(&camera, example);
|
sdfml::focusCamera(&camera, example);
|
||||||
//example.updateCamera(camera);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -66,6 +63,7 @@ int main(int argc, char* argv[])
|
||||||
// Verbose redirects io output to console, if available
|
// Verbose redirects io output to console, if available
|
||||||
if (pa[{"-v", "--verbose"}]) {
|
if (pa[{"-v", "--verbose"}]) {
|
||||||
RedirectIOToConsole();
|
RedirectIOToConsole();
|
||||||
|
sdfml::llog("Verbose mode", " enabled.", NORMAL, __FILENAME__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
sdfml::switchState(&m);
|
sdfml::switchState(&m);
|
||||||
|
|
|
@ -34,6 +34,8 @@
|
||||||
|
|
||||||
#include "guicon.h"
|
#include "guicon.h"
|
||||||
|
|
||||||
|
#include "sdfml/music.hpp"
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
#define __FILENAME__ (strrchr(__FILE__, '\\') ? strrchr(__FILE__, '\\') + 1 : __FILE__)
|
#define __FILENAME__ (strrchr(__FILE__, '\\') ? strrchr(__FILE__, '\\') + 1 : __FILE__)
|
||||||
#else
|
#else
|
||||||
|
@ -135,8 +137,6 @@ namespace sdfml {
|
||||||
};
|
};
|
||||||
|
|
||||||
static context mContext;
|
static context mContext;
|
||||||
|
|
||||||
static SoLoud::Soloud audio;
|
|
||||||
static SoLoud::SoundFont sf;
|
static SoLoud::SoundFont sf;
|
||||||
|
|
||||||
class sdSprite {
|
class sdSprite {
|
||||||
|
@ -163,8 +163,8 @@ namespace sdfml {
|
||||||
_w = width*scale.x;
|
_w = width*scale.x;
|
||||||
_h = height*scale.y;
|
_h = height*scale.y;
|
||||||
|
|
||||||
_sc.x = _x-_cam.pos.x;
|
_sc.x = _x-_camera->x;
|
||||||
_sc.y = _y-_cam.pos.y;
|
_sc.y = _y-_camera->y;
|
||||||
_sc.w = _w;
|
_sc.w = _w;
|
||||||
_sc.h = _h;
|
_sc.h = _h;
|
||||||
|
|
||||||
|
@ -193,37 +193,39 @@ namespace sdfml {
|
||||||
virtual void src_rect(SDL_Rect rect) {
|
virtual void src_rect(SDL_Rect rect) {
|
||||||
_src_rect = rect;
|
_src_rect = rect;
|
||||||
}
|
}
|
||||||
virtual void updateCamera(sdCam camera) {
|
virtual void updateCamera(SDL_Rect* camera) {
|
||||||
_cam = camera;
|
_camera = camera;
|
||||||
}
|
}
|
||||||
private:
|
private:
|
||||||
int _x, _y, _w, _h;
|
int _x, _y, _w, _h;
|
||||||
|
|
||||||
SDL_Rect _sc;
|
SDL_Rect _sc;
|
||||||
SDL_Rect _src_rect = {0, 0, 0, 0};
|
SDL_Rect _src_rect = {0, 0, 0, 0};
|
||||||
|
SDL_Rect dummy = {0, 0, 0, 0};
|
||||||
sdCam _cam;
|
sdCam _cam;
|
||||||
|
SDL_Rect* _camera = &dummy;
|
||||||
SDL_Texture* _tex;
|
SDL_Texture* _tex;
|
||||||
};
|
};
|
||||||
|
|
||||||
inline void focusCamera(sdCam* camera, sdSprite sprite) {
|
inline void focusCamera(SDL_Rect* camera, sdSprite sprite) {
|
||||||
camera->pos.x = ( sprite.x + (sprite.width / 2) ) - mContext.size.x / 2;
|
camera->x = ( sprite.x + (sprite.width / 2) ) - mContext.size.x / 2;
|
||||||
camera->pos.y = ( sprite.y + (sprite.height / 2) ) - mContext.size.y / 2;
|
camera->y = ( sprite.y + (sprite.height / 2) ) - mContext.size.y / 2;
|
||||||
|
|
||||||
if( camera->pos.x < 0 )
|
if( camera->x < 0 )
|
||||||
{
|
{
|
||||||
camera->pos.x = 0;
|
camera->x = 0;
|
||||||
}
|
}
|
||||||
if( camera->pos.y < 0 )
|
if( camera->y < 0 )
|
||||||
{
|
{
|
||||||
camera->pos.y = 0;
|
camera->y = 0;
|
||||||
}
|
}
|
||||||
if( camera->pos.x > camera->size.x )
|
if( camera->x > camera->w )
|
||||||
{
|
{
|
||||||
camera->pos.x = camera->size.x;
|
camera->x = camera->w;
|
||||||
}
|
}
|
||||||
if( camera->pos.y > camera->size.y )
|
if( camera->y > camera->h )
|
||||||
{
|
{
|
||||||
camera->pos.y = camera->size.y;
|
camera->y = camera->h;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -359,8 +361,7 @@ namespace sdfml {
|
||||||
});
|
});
|
||||||
soundfont = tomlParse<string>("conf.toml", "config", "soundfont");
|
soundfont = tomlParse<string>("conf.toml", "config", "soundfont");
|
||||||
|
|
||||||
if (audio.init() > 0)
|
sound.init();
|
||||||
return llog("SoLoud", " has failed to initialize.", ERROR_, __FILENAME__, __LINE__);
|
|
||||||
llog("SoLoud", " is now initialized.", NORMAL, __FILENAME__, __LINE__);
|
llog("SoLoud", " is now initialized.", NORMAL, __FILENAME__, __LINE__);
|
||||||
if (SDL_Init(SDL_INIT_EVERYTHING) < 0)
|
if (SDL_Init(SDL_INIT_EVERYTHING) < 0)
|
||||||
return llog("SDL", " has failed to initialize.", ERROR_, __FILENAME__, __LINE__);
|
return llog("SDL", " has failed to initialize.", ERROR_, __FILENAME__, __LINE__);
|
||||||
|
@ -390,6 +391,24 @@ namespace sdfml {
|
||||||
return llog("", "Fully finalized initialization. Command over.", NORMAL, __FILENAME__, __LINE__);
|
return llog("", "Fully finalized initialization. Command over.", NORMAL, __FILENAME__, __LINE__);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
using Func = std::function<T()>;
|
||||||
|
|
||||||
|
static vector<float> _sec;
|
||||||
|
static vector<Func<int>> _call;
|
||||||
|
static vector<bool> _repeats;
|
||||||
|
static vector<int> _ticks;
|
||||||
|
|
||||||
|
class sdTimer {
|
||||||
|
public:
|
||||||
|
void start(float seconds, Func<int> callback, bool repeat = false) {
|
||||||
|
_sec.push_back(seconds);
|
||||||
|
_call.push_back(callback);
|
||||||
|
_repeats.push_back(repeat);
|
||||||
|
_ticks.push_back(0);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
static const Uint8* kb;
|
static const Uint8* kb;
|
||||||
static const Uint8* kb_last;
|
static const Uint8* kb_last;
|
||||||
|
|
||||||
|
@ -411,6 +430,10 @@ namespace sdfml {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
inline int Sec2Tick(float time) {
|
||||||
|
return FRAMERATE*time;
|
||||||
|
}
|
||||||
|
|
||||||
inline int update() {
|
inline int update() {
|
||||||
int lastUpdate = SDL_GetTicks();
|
int lastUpdate = SDL_GetTicks();
|
||||||
bool run = true;
|
bool run = true;
|
||||||
|
@ -432,6 +455,32 @@ namespace sdfml {
|
||||||
if (curState != nullptr)
|
if (curState != nullptr)
|
||||||
curState->update(dT);
|
curState->update(dT);
|
||||||
|
|
||||||
|
// I know this is a shitty way to do this
|
||||||
|
// but bear with me
|
||||||
|
// it was hard to work with lambdas properly man
|
||||||
|
// let me have this just one please :)
|
||||||
|
if (_sec.size() > 0) {
|
||||||
|
for (int i = 0; i < _sec.size(); i++) {
|
||||||
|
if (_ticks[i] != -1)
|
||||||
|
_ticks[i]++;
|
||||||
|
|
||||||
|
if (_sec[i] != -1) {
|
||||||
|
if (!(_ticks[i] < Sec2Tick(_sec[i]))) {
|
||||||
|
if (_call[i] != NULL)
|
||||||
|
_call[i]();
|
||||||
|
if (!_repeats[i] && _repeats[i] != NULL)
|
||||||
|
{
|
||||||
|
_ticks[i] = -1;
|
||||||
|
_sec[i] = -1;
|
||||||
|
_call[i] = NULL;
|
||||||
|
_repeats[i] = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// cout << i << endl;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
lastUpdate = current;
|
lastUpdate = current;
|
||||||
|
|
||||||
if (curState != nullptr)
|
if (curState != nullptr)
|
||||||
|
@ -458,8 +507,8 @@ namespace sdfml {
|
||||||
}
|
}
|
||||||
SDL_DestroyRenderer(mContext.renderer);
|
SDL_DestroyRenderer(mContext.renderer);
|
||||||
SDL_DestroyWindow(mContext.window);
|
SDL_DestroyWindow(mContext.window);
|
||||||
audio.stopAll();
|
sound.deinit();
|
||||||
audio.deinit();
|
ReleaseConsole();
|
||||||
TTF_Quit();
|
TTF_Quit();
|
||||||
SDL_Quit();
|
SDL_Quit();
|
||||||
|
|
||||||
|
@ -467,39 +516,24 @@ namespace sdfml {
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void switchState(sdState* state) {
|
inline void switchState(sdState* state) {
|
||||||
|
if (curState != nullptr) {
|
||||||
|
_ticks = {};
|
||||||
|
_call = {};
|
||||||
|
_repeats = {};
|
||||||
|
_sec = {};
|
||||||
|
if (curState->get_spr().size() > 0) {
|
||||||
|
for (auto texture : curState->get_spr()) {
|
||||||
|
texture->destroy();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (curState->get_mspr().size() > 0) {
|
||||||
|
for (auto texture : curState->get_mspr()) {
|
||||||
|
texture.destroy();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
curState = state;
|
curState = state;
|
||||||
curState->create();
|
curState->create();
|
||||||
}
|
}
|
||||||
|
|
||||||
static pair<string, int> curMusic = pair<string, int>("", 0);
|
|
||||||
|
|
||||||
class musplayer {
|
|
||||||
public:
|
|
||||||
SoLoud::WavStream wav;
|
|
||||||
SoLoud::WavStream sfxWav;
|
|
||||||
SoLoud::Openmpt mod;
|
|
||||||
|
|
||||||
void playSFX(string path) {
|
|
||||||
//audio.stopAudioSource(sfxWav);
|
|
||||||
sfxWav.load(path.c_str());
|
|
||||||
audio.play(sfxWav);
|
|
||||||
}
|
|
||||||
|
|
||||||
void playMus(string path, bool loop = true) {
|
|
||||||
audio.stopAudioSource(wav);
|
|
||||||
wav.load(path.c_str());
|
|
||||||
wav.setLooping(loop);
|
|
||||||
curMusic.second = audio.playBackground(wav);
|
|
||||||
curMusic.first = path;
|
|
||||||
}
|
|
||||||
|
|
||||||
void playMod(string path, bool loop = true) {
|
|
||||||
//audio.stopAudioSource(mod);
|
|
||||||
mod.load(path.c_str());
|
|
||||||
mod.setLooping(loop);
|
|
||||||
curMusic.second = audio.playBackground(mod);
|
|
||||||
curMusic.first = path;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
6
src/sdfml/music.cpp
Normal file
6
src/sdfml/music.cpp
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
#include "music.hpp"
|
||||||
|
|
||||||
|
std::array<SoLoud::WavStream, MAX_SFX> sdfml::sfxBanks;
|
||||||
|
std::pair<SoLoud::WavStream, SoLoud::Openmpt> sdfml::musicBank;
|
||||||
|
SoLoud::Soloud sdfml::audio;
|
||||||
|
sdfml::AudioHandler sdfml::sound;
|
70
src/sdfml/music.hpp
Normal file
70
src/sdfml/music.hpp
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
#ifndef _MUSIC_H
|
||||||
|
#define _MUSIC_H
|
||||||
|
#include "../SoLoud/soloud.h"
|
||||||
|
#include "../SoLoud/soloud_wavstream.h"
|
||||||
|
#include "../SoLoud/soloud_speech.h"
|
||||||
|
#include "../SoLoud/soloud_modplug.h"
|
||||||
|
#include "../SoLoud/soloud_openmpt.h"
|
||||||
|
#include <array>
|
||||||
|
#include <string>
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
|
#define MAX_SFX 10
|
||||||
|
|
||||||
|
namespace sdfml {
|
||||||
|
|
||||||
|
extern std::array<SoLoud::WavStream, MAX_SFX> sfxBanks;
|
||||||
|
extern std::pair<SoLoud::WavStream, SoLoud::Openmpt> musicBank;
|
||||||
|
|
||||||
|
extern SoLoud::Soloud audio;
|
||||||
|
|
||||||
|
class MusicHandler {
|
||||||
|
public:
|
||||||
|
void playMusic(std::string path) {
|
||||||
|
musicBank.first.stop();
|
||||||
|
audio.stopAudioSource(musicBank.first);
|
||||||
|
musicBank.first.load(path.c_str());
|
||||||
|
audio.play(musicBank.first);
|
||||||
|
}
|
||||||
|
|
||||||
|
void playMod(std::string path) {
|
||||||
|
musicBank.second.stop();
|
||||||
|
audio.stopAudioSource(musicBank.second);
|
||||||
|
musicBank.second.load(path.c_str());
|
||||||
|
audio.playBackground(musicBank.second);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class AudioHandler {
|
||||||
|
public:
|
||||||
|
MusicHandler music;
|
||||||
|
|
||||||
|
void init() {
|
||||||
|
audio.init();
|
||||||
|
}
|
||||||
|
|
||||||
|
void deinit() {
|
||||||
|
audio.stopAll();
|
||||||
|
audio.deinit();
|
||||||
|
}
|
||||||
|
|
||||||
|
void play(std::string path) {
|
||||||
|
for (int i = 0; i < MAX_SFX; i++) {
|
||||||
|
if (sfxBanks[i].getLength() > 0) {
|
||||||
|
sfxBanks[i].load(path.c_str());
|
||||||
|
audio.play(sfxBanks[i]);
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
sfxBanks[i].stop();
|
||||||
|
audio.stopAudioSource(sfxBanks[i]);
|
||||||
|
sfxBanks[i].load(path.c_str());
|
||||||
|
audio.play(sfxBanks[i]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
extern AudioHandler sound;
|
||||||
|
}
|
||||||
|
#endif
|
Loading…
Reference in a new issue