# Changes 0.2.4-2
- Document the rest of th elibs - remove sound.hpp header
This commit is contained in:
parent
7d3f619169
commit
e6495d70b1
@ -27,9 +27,14 @@ SOFTWARE.
|
||||
#include <pd/external/json.hpp>
|
||||
|
||||
namespace PD {
|
||||
/**
|
||||
* Download manager class
|
||||
*/
|
||||
class DownloadManager : public SmartCtor<DownloadManager> {
|
||||
public:
|
||||
/** Alias to contain Error Cdoe and for some Errors a Status Code */
|
||||
using Error = u64;
|
||||
/** Error Codes of DL Manager */
|
||||
enum Error_ {
|
||||
Error_None, ///< Function Executed Successfully
|
||||
Error_Memory, ///< Memory Allocation Error
|
||||
@ -42,12 +47,22 @@ class DownloadManager : public SmartCtor<DownloadManager> {
|
||||
Error_Invalid, ///< Invalid Json struct
|
||||
Error_NoWifi, ///< Console not connected to wifi
|
||||
};
|
||||
DownloadManager() {}
|
||||
~DownloadManager() {}
|
||||
DownloadManager() = default;
|
||||
~DownloadManager() = default;
|
||||
|
||||
/**
|
||||
* Extract the DL Manager Error code of a Error
|
||||
* @param err Error
|
||||
* @return Downloadmanager Error code
|
||||
*/
|
||||
static Error_ GetErrorCode(Error err) {
|
||||
return (Error_)u32(err & 0xffffffff);
|
||||
}
|
||||
/**
|
||||
* Extract the DL Manager Status code of a Error
|
||||
* @param err Error
|
||||
* @return Status code
|
||||
*/
|
||||
static int GetStatusCode(Error err) {
|
||||
Error_ c = GetErrorCode(err);
|
||||
if (c != Error_StatusCode && c != Error_CtrStatus && c != Error_Curl) {
|
||||
@ -56,17 +71,45 @@ class DownloadManager : public SmartCtor<DownloadManager> {
|
||||
return u32(err >> 32);
|
||||
}
|
||||
|
||||
/**
|
||||
* Download from URL inro a String Buffer
|
||||
* @param url URL to download from
|
||||
* @param res result buffer
|
||||
* @return Error Code
|
||||
*/
|
||||
Error Get(const std::string& url, std::string& res);
|
||||
/**
|
||||
* Download from URL into a File
|
||||
* @param url URL to download from
|
||||
* @param res_path Path to write file to
|
||||
* @return Error Code
|
||||
*/
|
||||
Error GetFile(const std::string& url, const std::string& res_path);
|
||||
/**
|
||||
* Download a File from a Git Release
|
||||
* @param url URL of the repo
|
||||
* @param asset Asset to download
|
||||
* @param path Path to write file into
|
||||
* @param pre download from Prerelease
|
||||
* @return Error Code
|
||||
*/
|
||||
Error GetGitRelease(const std::string& url, const std::string& asset,
|
||||
const std::string& path, bool pre);
|
||||
/**
|
||||
* Get a json API request as nlohmann json object
|
||||
* @param url URL to request
|
||||
* @param res result json object
|
||||
* @return Error Code
|
||||
*/
|
||||
Error GetAsJson(const std::string& url, nlohmann::json& res);
|
||||
|
||||
/** Get Current Progress in Bytes */
|
||||
u64 ProgressCurrent() const { return current; }
|
||||
/** Get Total number in bytes */
|
||||
u64 ProgressTotal() const { return total; }
|
||||
|
||||
private:
|
||||
u64 current;
|
||||
u64 total;
|
||||
u64 current; ///< Current Progress
|
||||
u64 total; ///< Total Bytes tp Download
|
||||
};
|
||||
} // namespace PD
|
@ -23,50 +23,71 @@ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
||||
*/
|
||||
|
||||
#include <pd/drivers/hid.hpp>
|
||||
#include <pd/core/tween.hpp>
|
||||
#include <pd/drivers/hid.hpp>
|
||||
#include <pd/overlays/overlay.hpp>
|
||||
|
||||
namespace PD {
|
||||
/**
|
||||
* Development Function to dump Keyboard Layout into a Json File
|
||||
* @param path Path to write into
|
||||
*/
|
||||
void DumpLayout(const std::string& path);
|
||||
/// Keyboard class
|
||||
/// @brief needs to be pushed with text and State reference as Overlay
|
||||
/// to communicate with it
|
||||
/// @note Hardcoded Rendering to get maximum Rendering Performance
|
||||
/**
|
||||
* Keyboard class
|
||||
*
|
||||
* - needs to be pushed with text and State reference as Overlay
|
||||
* to communicate with it
|
||||
* @note Hardcoded Rendering to get maximum Rendering Performance
|
||||
*/
|
||||
class Keyboard : public Overlay {
|
||||
public:
|
||||
/** Key Operations */
|
||||
enum KeyOperation {
|
||||
AppendSelf = 0,
|
||||
Shift = 1,
|
||||
Backspace = 2,
|
||||
Enter = 3,
|
||||
OpCancel = 4,
|
||||
OpConfirm = 5,
|
||||
Tab = 6,
|
||||
Caps = 7,
|
||||
Space = 8,
|
||||
Op1 = 9,
|
||||
Op2 = 10,
|
||||
AppendSelf = 0, ///< Append Keyname to res string
|
||||
Shift = 1, ///< Shift
|
||||
Backspace = 2, ///< Backspace
|
||||
Enter = 3, ///< Enter
|
||||
OpCancel = 4, ///< Cancel
|
||||
OpConfirm = 5, ///< Confirm
|
||||
Tab = 6, ///< Tab
|
||||
Caps = 7, ///< Caps
|
||||
Space = 8, ///< Space
|
||||
Op1 = 9, ///< Unnset Op 1
|
||||
Op2 = 10, ///< Unset Op 2
|
||||
};
|
||||
/** Keyboard Type */
|
||||
enum Type {
|
||||
Default,
|
||||
Numpad,
|
||||
Password,
|
||||
Default, ///< Default Keyboard
|
||||
Numpad, ///< Numpad
|
||||
Password, ///< Password Input
|
||||
};
|
||||
/** State */
|
||||
enum State {
|
||||
None,
|
||||
Cancel,
|
||||
Confirm,
|
||||
None, ///< Doing nothing
|
||||
Cancel, ///< Cancelled
|
||||
Confirm, ///< Confirmed
|
||||
};
|
||||
/** Alias for Keyboard Flags */
|
||||
using Flags = u32;
|
||||
/** Flags */
|
||||
enum Flags_ {
|
||||
Flags_None = 0,
|
||||
Flags_BlendTop = 1 << 0,
|
||||
Flags_BlendBottom = 1 << 1,
|
||||
Flags_LockControls = 1 << 2,
|
||||
Flags_Transparency = 1 << 3,
|
||||
Flags_None = 0, ///< Nothing
|
||||
Flags_BlendTop = 1 << 0, ///< Blend Top Screen
|
||||
Flags_BlendBottom = 1 << 1, ///< Blend Bottom
|
||||
Flags_LockControls = 1 << 2, ///< Lock Contols (Input Driver)
|
||||
Flags_Transparency = 1 << 3, ///< Transparant Keyboard Colors
|
||||
// Default Flags
|
||||
Flags_Default = Flags_BlendBottom | Flags_BlendTop | Flags_LockControls,
|
||||
};
|
||||
/**
|
||||
* Keyboard Constructor
|
||||
* @param text Result Text
|
||||
* @param state Result State
|
||||
* @param hint Hint to display if result is empty
|
||||
* @param type Keyboard type
|
||||
* @param flags Keyboard flags to use
|
||||
*/
|
||||
Keyboard(std::string& text, State& state, const std::string& hint = "",
|
||||
Type type = Default, Flags flags = Flags_Default) {
|
||||
too++;
|
||||
@ -84,46 +105,74 @@ class Keyboard : public Overlay {
|
||||
flymgr.From(vec2(0, 240)).To(vec2(0, 115)).In(0.3f).As(flymgr.EaseInQuad);
|
||||
chflymgr.From(vec2(-320, 0)).To(vec2(-320, 0)).In(0.1f).As(chflymgr.Linear);
|
||||
}
|
||||
/** Deconstructor */
|
||||
~Keyboard() { too--; }
|
||||
|
||||
/**
|
||||
* Rendering and Input Handler
|
||||
* @param delta Deltatime for Animations
|
||||
* @param ren Renderer Reference
|
||||
* @param inp Input Driver reference
|
||||
*/
|
||||
void Update(float delta, LI::Renderer::Ref ren, Hid::Ref inp) override;
|
||||
|
||||
/** Remove Keyboard */
|
||||
void Rem() {
|
||||
rem = true;
|
||||
flymgr.From(vec2(0, 115)).To(vec2(0, 240)).In(0.2f).As(flymgr.EaseOutQuad);
|
||||
}
|
||||
|
||||
private:
|
||||
/** Prerender Keys */
|
||||
void LoadTheKeys(LI::Renderer::Ref ren);
|
||||
/** Controller Movement */
|
||||
void Movement(Hid::Ref inp);
|
||||
/** Trigger Move from to Animation */
|
||||
void MoveSelector();
|
||||
/** Execute a Key operation */
|
||||
void DoOperation(KeyOperation op, const std::string& kname);
|
||||
/** Recolor all Keys with the same operation */
|
||||
void RecolorBy(KeyOperation op, u32 color, int cm);
|
||||
/** Bind an operation */
|
||||
void InputOpBind(Hid::Key k, KeyOperation op, Hid::Ref inp, int cm);
|
||||
// Result Text reference
|
||||
std::string* text;
|
||||
// Copy of the Text
|
||||
std::string copy;
|
||||
// Hint
|
||||
std::string hint;
|
||||
// Result State reference
|
||||
State* state;
|
||||
// Keyboard Type
|
||||
Type type;
|
||||
// Keyboard flags
|
||||
Flags flags;
|
||||
int mode = 0; // def, caps, shift
|
||||
// def, caps, shift
|
||||
int mode = 0;
|
||||
// Stands for The Only One
|
||||
static int too;
|
||||
|
||||
// Tween for selector Movement
|
||||
Tween<vec2> selector;
|
||||
// Tween for Selector Size
|
||||
Tween<vec2> sel_szs;
|
||||
// Current Cell size
|
||||
vec2 cselszs;
|
||||
// selector index
|
||||
int raw_sel;
|
||||
|
||||
// Performance Optimisation
|
||||
// Prerendered Keytables
|
||||
LI::StaticObject::Ref keys[3];
|
||||
// Value to check if table is loadet
|
||||
bool keys_loadet = false;
|
||||
|
||||
// Some Animation
|
||||
// Remove Animation
|
||||
bool rem = false;
|
||||
/// Probably a float would've done the job as well ;)
|
||||
Tween<vec2> flymgr;
|
||||
// Secode Flymanager
|
||||
Tween<vec2> chflymgr;
|
||||
// Show Help
|
||||
bool show_help = true;
|
||||
};
|
||||
} // namespace PD
|
@ -23,24 +23,45 @@ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
||||
*/
|
||||
|
||||
#include <pd/lithium/renderer.hpp>
|
||||
#include <pd/core/color.hpp>
|
||||
#include <pd/core/tween.hpp>
|
||||
#include <pd/lithium/renderer.hpp>
|
||||
|
||||
namespace PD {
|
||||
/**
|
||||
* Message Manager
|
||||
*/
|
||||
class MessageMgr : public PD::SmartCtor<MessageMgr> {
|
||||
public:
|
||||
/**
|
||||
* Message Container
|
||||
*/
|
||||
class Container : public PD::SmartCtor<Container> {
|
||||
public:
|
||||
/**
|
||||
* Message Constructor
|
||||
* @param title Title
|
||||
* @param msg Message
|
||||
*/
|
||||
Container(const std::string& title, const std::string& msg);
|
||||
~Container() {}
|
||||
~Container() = default;
|
||||
|
||||
/** Render the Container */
|
||||
void Render(PD::LI::Renderer::Ref ren);
|
||||
/**
|
||||
* Update Animations by slot and delta
|
||||
* @param slot Slot
|
||||
* @param delta Deltatime
|
||||
*/
|
||||
void Update(int slot, float delta);
|
||||
/** Trigger Fly in Animation */
|
||||
void FlyIn();
|
||||
/** Trigger Change Position Animation */
|
||||
void ToBeMoved(int slot);
|
||||
/** Trigger Removed Animation */
|
||||
void ToBeRemoved();
|
||||
|
||||
/** Check if Message can be removed from list */
|
||||
bool ShouldBeRemoved() const { return (tbr && pos.IsFinished()) || kill; }
|
||||
|
||||
private:
|
||||
@ -55,14 +76,24 @@ class MessageMgr : public PD::SmartCtor<MessageMgr> {
|
||||
bool kill = false; // Instant Kill
|
||||
int s = 0; // Slot
|
||||
};
|
||||
/** Constructor to Link a Renderer reference */
|
||||
MessageMgr(PD::LI::Renderer::Ref r) { ren = r; }
|
||||
~MessageMgr() {}
|
||||
~MessageMgr() = default;
|
||||
|
||||
/**
|
||||
* Add a New Message
|
||||
* @param title Message Title
|
||||
* @param text Message Text
|
||||
*/
|
||||
void Push(const std::string& title, const std::string& text);
|
||||
/**
|
||||
* Update Messages
|
||||
* @param delta Deltatime
|
||||
*/
|
||||
void Update(float delta);
|
||||
|
||||
private:
|
||||
std::vector<Container::Ref> msgs;
|
||||
PD::LI::Renderer::Ref ren;
|
||||
std::vector<Container::Ref> msgs; // List of Messages
|
||||
PD::LI::Renderer::Ref ren; // Renderer Reference
|
||||
};
|
||||
} // namespace PD
|
@ -28,19 +28,30 @@ SOFTWARE.
|
||||
#include <pd/lithium/renderer.hpp>
|
||||
|
||||
namespace PD {
|
||||
/**
|
||||
* Overlay Template class
|
||||
*/
|
||||
class Overlay : public SmartCtor<Overlay> {
|
||||
public:
|
||||
Overlay() {}
|
||||
virtual ~Overlay() {}
|
||||
Overlay() = default;
|
||||
virtual ~Overlay() = default;
|
||||
|
||||
/**
|
||||
* Update Function for Overlay input and rendering
|
||||
* @param delta Deltatime
|
||||
* @param ren Renderer reference
|
||||
* @param inp Input Driver
|
||||
*/
|
||||
virtual void Update(float delta, LI::Renderer::Ref ren, Hid::Ref inp) = 0;
|
||||
|
||||
/** Check if killed to remove from Overlay Manager */
|
||||
bool IsKilled() const { return kill; }
|
||||
|
||||
protected:
|
||||
/** Internall Kill function to call from your Overlay */
|
||||
void Kill() { kill = true; }
|
||||
|
||||
private:
|
||||
bool kill = false;
|
||||
bool kill = false; ///< Should be killed or not
|
||||
};
|
||||
} // namespace PD
|
@ -28,20 +28,37 @@ SOFTWARE.
|
||||
#include <pd/overlays/overlay.hpp>
|
||||
|
||||
namespace PD {
|
||||
/**
|
||||
* Overlay Manager Class
|
||||
*/
|
||||
class OverlayMgr : public SmartCtor<OverlayMgr> {
|
||||
public:
|
||||
/**
|
||||
* Constructor
|
||||
* @param ren Renderer
|
||||
* @param inp Input Driver reference
|
||||
*/
|
||||
OverlayMgr(LI::Renderer::Ref ren, Hid::Ref inp) {
|
||||
this->ren = ren;
|
||||
this->inp = inp;
|
||||
}
|
||||
/** Deconstructor */
|
||||
~OverlayMgr() { overlays.clear(); }
|
||||
|
||||
/**
|
||||
* Append a New Overlay
|
||||
* @param overlay Overlay reference to push
|
||||
*/
|
||||
void Push(Overlay::Ref overlay);
|
||||
/**
|
||||
* Update Overlays
|
||||
* @paran delta Deltatime
|
||||
*/
|
||||
void Update(float delta);
|
||||
|
||||
private:
|
||||
std::vector<Overlay::Ref> overlays;
|
||||
LI::Renderer::Ref ren;
|
||||
Hid::Ref inp;
|
||||
std::vector<Overlay::Ref> overlays; ///< Overlay List
|
||||
LI::Renderer::Ref ren; ///< Renderer reference
|
||||
Hid::Ref inp; ///< Input Driver reference
|
||||
};
|
||||
} // namespace PD
|
@ -27,8 +27,25 @@ SOFTWARE.
|
||||
#include <pd/overlays/overlay.hpp>
|
||||
|
||||
namespace PD {
|
||||
/**
|
||||
* Performance Overlay
|
||||
*
|
||||
* - Framerate / Frametime
|
||||
* - Renderer Avarage Time
|
||||
* - Overlays Avarage Time
|
||||
* - UserApp Average Time
|
||||
* - **V**ertices and **I**ndices
|
||||
* - **D**Draw Commands and Draw **C**alls
|
||||
* - Text Map System Texts
|
||||
* - Auto static Text Texts
|
||||
*/
|
||||
class Performance : public Overlay {
|
||||
public:
|
||||
/**
|
||||
* Constructor
|
||||
* @param skill (if set to true the Overlay self kills)
|
||||
* @param screen Bottom or Top Screen
|
||||
*/
|
||||
Performance(bool& skill, bool& screen) {
|
||||
too++;
|
||||
if (too > 1) {
|
||||
@ -39,11 +56,24 @@ class Performance : public Overlay {
|
||||
*this->skill = false; // Make sure its false
|
||||
this->screen = &screen;
|
||||
}
|
||||
/** Deconstructor */
|
||||
~Performance() { too--; }
|
||||
|
||||
/**
|
||||
* Rendering Function
|
||||
* @param delta Deltatime
|
||||
* @param ren Renderer Reference
|
||||
* @param inp Input Driver Reference
|
||||
*/
|
||||
void Update(float delta, LI::Renderer::Ref ren, Hid::Ref inp) override;
|
||||
|
||||
private:
|
||||
/**
|
||||
* Render an Info line
|
||||
* @param pos Position reference (gets updated for next line)
|
||||
* @param text Text to Show
|
||||
* @param ren Renderer Reference
|
||||
*/
|
||||
void Line(vec2& pos, const std::string& text, LI::Renderer::Ref ren);
|
||||
// Trace String Average
|
||||
std::string TSA(const std::string& id);
|
||||
|
@ -23,14 +23,20 @@ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
||||
*/
|
||||
|
||||
#include <pd/drivers/hid.hpp>
|
||||
#include <pd/core/tween.hpp>
|
||||
#include <pd/drivers/hid.hpp>
|
||||
#include <pd/overlays/overlay.hpp>
|
||||
#include <pd/ui7/ui7.hpp>
|
||||
|
||||
namespace PD {
|
||||
/**
|
||||
* Settings Menu Overlay
|
||||
*/
|
||||
class SettingsMenu : public Overlay {
|
||||
public:
|
||||
/**
|
||||
* Constructor to setup Overlay
|
||||
*/
|
||||
SettingsMenu() {
|
||||
too++;
|
||||
if (too > 1) {
|
||||
@ -39,10 +45,15 @@ class SettingsMenu : public Overlay {
|
||||
}
|
||||
flymgr.From(vec2(0, 240)).To(vec2(0, 115)).In(0.3f).As(flymgr.EaseInQuad);
|
||||
}
|
||||
/** Deconstructor */
|
||||
~SettingsMenu() { too--; }
|
||||
|
||||
/** Rendering and Input Handler */
|
||||
void Update(float delta, LI::Renderer::Ref ren, Hid::Ref inp) override;
|
||||
|
||||
/**
|
||||
* Function to Trigger remove animation
|
||||
*/
|
||||
void Rem() {
|
||||
rem = true;
|
||||
flymgr.From(vec2(0, 115)).To(vec2(0, 240)).In(0.2f).As(flymgr.EaseOutQuad);
|
||||
|
@ -27,17 +27,27 @@ SOFTWARE.
|
||||
|
||||
namespace PD {
|
||||
namespace Music {
|
||||
/**
|
||||
* Decoder Template class
|
||||
*/
|
||||
class Decoder : public SmartCtor<Decoder> {
|
||||
public:
|
||||
Decoder() {}
|
||||
virtual ~Decoder() {}
|
||||
Decoder() = default;
|
||||
virtual ~Decoder() = default;
|
||||
|
||||
/** Template Init function */
|
||||
virtual int Init(const std::string& path) = 0;
|
||||
/** Template deinit function */
|
||||
virtual void Deinit() = 0;
|
||||
/** Template function to get sample rate */
|
||||
virtual u32 GetSampleRate() = 0;
|
||||
/** template function to get number of channels */
|
||||
virtual u8 GetChannels() = 0;
|
||||
/** template function to get buffer size */
|
||||
virtual size_t GetBufSize() = 0;
|
||||
/** template decode function */
|
||||
virtual u64 Decode(u16* buf_address) = 0;
|
||||
/** template function to get file sanples if exist */
|
||||
virtual size_t GetFileSamples() = 0;
|
||||
};
|
||||
} // namespace Music
|
||||
|
@ -27,25 +27,42 @@ SOFTWARE.
|
||||
|
||||
namespace PD {
|
||||
namespace Music {
|
||||
/**
|
||||
* Music Metadata Data Holder
|
||||
*/
|
||||
class MetaData {
|
||||
public:
|
||||
MetaData() {}
|
||||
~MetaData() {}
|
||||
MetaData() = default;
|
||||
~MetaData() = default;
|
||||
|
||||
/** Getter for name */
|
||||
std::string Name() const { return name; }
|
||||
/** Getter for album */
|
||||
std::string Album() const { return album; }
|
||||
/** Getter for year */
|
||||
std::string Year() const { return year; }
|
||||
/** Getter for Title */
|
||||
std::string Title() const { return title; }
|
||||
/** Getter for Artist */
|
||||
std::string Artist() const { return artist; }
|
||||
/** Getter for [what is this] */
|
||||
std::string Mdt() const { return mdt; }
|
||||
/** Gettr for file path */
|
||||
std::string Path() const { return path; }
|
||||
|
||||
/** Setter for Name */
|
||||
void Name(const std::string &v) { name = v; }
|
||||
/** Setter for Album */
|
||||
void Album(const std::string &v) { album = v; }
|
||||
/** Settr for Year */
|
||||
void Year(const std::string &v) { year = v; }
|
||||
/** Settr for Title */
|
||||
void Title(const std::string &v) { title = v; }
|
||||
/** Settr for Artist */
|
||||
void Artist(const std::string &v) { artist = v; }
|
||||
/** Settr for [what is this] */
|
||||
void Mdt(const std::string &v) { mdt = v; }
|
||||
/** Settr for Path */
|
||||
void Path(const std::string &v) { path = v; }
|
||||
|
||||
private:
|
||||
|
@ -29,17 +29,27 @@ SOFTWARE.
|
||||
|
||||
namespace PD {
|
||||
namespace Music {
|
||||
/**
|
||||
* MP3 Decoder
|
||||
*/
|
||||
class Mp3Decoder : public Decoder {
|
||||
public:
|
||||
Mp3Decoder() {}
|
||||
~Mp3Decoder() {}
|
||||
Mp3Decoder() = default;
|
||||
~Mp3Decoder() = default;
|
||||
|
||||
/** Init Funciton to load file and Init decoder */
|
||||
int Init(const std::string& path) override;
|
||||
/** Unload Decoder */
|
||||
void Deinit() override;
|
||||
/** Get Sample Rate */
|
||||
u32 GetSampleRate() override;
|
||||
/** Get Channels */
|
||||
u8 GetChannels() override;
|
||||
/** Get Buffer Size */
|
||||
size_t GetBufSize() override;
|
||||
/** Decode next data */
|
||||
u64 Decode(u16* buf_address) override;
|
||||
/** Get File Samples if exist */
|
||||
size_t GetFileSamples() override;
|
||||
|
||||
private:
|
||||
|
@ -29,6 +29,9 @@ SOFTWARE.
|
||||
|
||||
namespace PD {
|
||||
namespace Music {
|
||||
/**
|
||||
* Music Player
|
||||
*/
|
||||
class Player : public SmartCtor<Player> {
|
||||
public:
|
||||
Player() {}
|
||||
|
@ -1,46 +0,0 @@
|
||||
#pragma once
|
||||
|
||||
/*
|
||||
MIT License
|
||||
Copyright (c) 2024 - 2025 René Amthor (tobid7)
|
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||
of this software and associated documentation files (the "Software"), to deal
|
||||
in the Software without restriction, including without limitation the rights
|
||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||
copies of the Software, and to permit persons to whom the Software is
|
||||
furnished to do so, subject to the following conditions:
|
||||
|
||||
The above copyright notice and this permission notice shall be included in all
|
||||
copies or substantial portions of the Software.
|
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
||||
SOFTWARE.
|
||||
*/
|
||||
|
||||
#include <3ds.h>
|
||||
|
||||
#include <pd/common/common.hpp>
|
||||
#include <pd/common/memory.hpp>
|
||||
|
||||
namespace PD {
|
||||
class Sound : public SmartCtor<Sound> {
|
||||
public:
|
||||
Sound();
|
||||
~Sound();
|
||||
|
||||
void Play();
|
||||
void Stop();
|
||||
|
||||
private:
|
||||
u32 dataSize;
|
||||
ndspWaveBuf wavBuf;
|
||||
std::vector<u8, LinearAllocator<u8>> dat;
|
||||
int channel;
|
||||
};
|
||||
} // namespace PD
|
Loading…
Reference in New Issue
Block a user