-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathxmdxhelper.h
82 lines (61 loc) · 2.3 KB
/
xmdxhelper.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/***************************************************************************
* This file is part of the TTK qmmp plugin project
* Copyright (C) 2015 - 2025 Greedysky Studio
* 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/>.
***************************************************************************/
#ifndef XMDXHELPER_H
#define XMDXHELPER_H
#include <QFile>
#include <qmmp/qmmp.h>
/*!
* @author Greedysky <[email protected]>
*/
class AbstractReader
{
public:
AbstractReader() = default;
virtual ~AbstractReader() = default;
virtual bool load(const QString &path) = 0;
virtual qint64 read(unsigned char *data, qint64 maxSize) = 0;
inline virtual int sampleRate() const { return 44100; }
inline qint64 totalTime() const { return m_length; }
inline QString title() const { return m_title; }
inline QString author() const { return m_author; }
protected:
int m_offset = 0;
qint64 m_length = 0;
QString m_title;
QString m_author;
};
/*!
* @author Greedysky <[email protected]>
*/
class XMDXHelper
{
public:
explicit XMDXHelper(const QString &path);
~XMDXHelper();
void deinit();
bool initialize();
inline qint64 totalTime() const { return m_input->totalTime(); }
inline int bitrate() const { return 8; }
inline int sampleRate() const { return m_input->sampleRate(); }
inline int channels() const { return 2; }
inline int depth() const { return 16; }
inline qint64 read(unsigned char *data, qint64 maxSize) { return m_input->read(data, maxSize); }
inline QString title() const { return m_input->title(); }
inline QString author() const { return m_input->author(); }
private:
QString m_path;
AbstractReader *m_input = nullptr;
};
#endif