19 #ifndef DRUMSTICK_QWRK_H
20 #define DRUMSTICK_QWRK_H
24 #include <QScopedPointer>
89 void readFromStream(QDataStream *stream);
90 void readFromFile(
const QString& fileName);
91 QTextCodec* getTextCodec();
92 void setTextCodec(QTextCodec *codec);
98 int getKeySig()
const;
100 int getAutoSave()
const;
101 int getPlayDelay()
const;
102 bool getZeroCtrls()
const;
103 bool getSendSPP()
const;
104 bool getSendCont()
const;
105 bool getPatchSearch()
const;
106 bool getAutoStop()
const;
107 unsigned int getStopTime()
const;
108 bool getAutoRewind()
const;
109 int getRewindTime()
const;
110 bool getMetroPlay()
const;
111 bool getMetroRecord()
const;
112 bool getMetroAccent()
const;
113 int getCountIn()
const;
114 bool getThruOn()
const;
115 bool getAutoRestart()
const;
116 int getCurTempoOfs()
const;
117 int getTempoOfs1()
const;
118 int getTempoOfs2()
const;
119 int getTempoOfs3()
const;
120 bool getPunchEnabled()
const;
121 int getPunchInTime()
const;
122 int getPunchOutTime()
const;
123 int getEndAllTime()
const;
125 QByteArray getLastChunkRawData()
const;
126 double getRealTime(
long ticks)
const;
179 void signalWRKNote(
int track,
long time,
int chan,
int pitch,
int vol,
int dur);
251 void signalWRKSysex(
int bank,
const QString& name,
bool autosend,
int port,
const QByteArray& data);
306 const QString& name2,
307 int trackno,
int channel,
int pitch,
308 int velocity,
int port,
309 bool selected,
bool muted,
bool loop );
342 void signalWRKThru(
int mode,
int port,
int channel,
int keyPlus,
int velPlus,
int localPort);
422 int trackno,
int channel,
int pitch,
423 int velocity,
int port,
424 bool selected,
bool muted,
bool loop );
465 void signalWRKChord(
int track,
long time,
const QString& name,
const QByteArray& data);
489 quint16 to16bit(quint8 c1, quint8 c2);
490 quint32 to32bit(quint8 c1, quint8 c2, quint8 c3, quint8 c4);
494 QString readString(
int len);
495 QString readVarString();
496 void readRawData(
int size);
497 void readGap(
int size);
499 void seek(qint64 pos);
502 void processTrackChunk();
503 void processVarsChunk();
504 void processTimebaseChunk();
505 void processNoteArray(
int track,
int events);
506 void processStreamChunk();
507 void processMeterChunk();
508 void processTempoChunk(
int factor = 1);
509 void processSysexChunk();
510 void processSysex2Chunk();
511 void processNewSysexChunk();
512 void processThruChunk();
513 void processTrackOffset();
514 void processTrackReps();
515 void processTrackPatch();
516 void processTrackBank();
517 void processTimeFormat();
518 void processComments();
519 void processVariableRecord(
int max);
520 void processNewTrack();
521 void processSoftVer();
522 void processTrackName();
523 void processStringTable();
524 void processLyricsStream();
525 void processTrackVol();
526 void processNewTrackOffset();
527 void processMeterKeyChunk();
528 void processSegmentChunk();
529 void processNewStream();
530 void processUnknown(
int id);
531 void processEndChunk();
541 QScopedPointer<QWrkPrivate> d;
The QObject class is the base class of all Qt objects.
Cakewalk WRK file format (input only)
void signalWRKTrackPatch(int track, int patch)
Emitted after reading a track patch chunk.
void signalWRKText(int track, long time, int type, const QString &data)
Emitted after reading a text message.
void signalWRKTrack(const QString &name1, const QString &name2, int trackno, int channel, int pitch, int velocity, int port, bool selected, bool muted, bool loop)
Emitted after reading a track prefix chunk.
void signalWRKProgram(int track, long time, int chan, int patch)
Emitted after reading a Program change message.
void signalWRKChord(int track, long time, const QString &name, const QByteArray &data)
Emitted after reading a chord diagram chunk.
static const QByteArray HEADER
Cakewalk WRK file format header string id.
void signalWRKHeader(int verh, int verl)
Emitted after reading a WRK header.
void signalWRKSysexEvent(int track, long time, int bank)
Emitted after reading a System Exclusive event.
void signalWRKGlobalVars()
Emitted after reading the global variables chunk.
void signalWRKSoftVer(const QString &version)
Emitted after reading a software version chunk.
void signalWRKComments(const QString &data)
Emitted after reading a comments chunk.
void signalWRKTrackOffset(int track, int offset)
Emitted after reading a track offset chunk.
void signalWRKChanPress(int track, long time, int chan, int press)
Emitted after reading a Channel Aftertouch message.
void signalWRKStreamEnd(long time)
Emitted after reading the last event of a event stream.
void signalWRKKeyPress(int track, long time, int chan, int pitch, int press)
Emitted after reading a Polyphonic Aftertouch message.
void signalWRKVariableRecord(const QString &name, const QByteArray &data)
Emitted after reading a variable chunk.
void signalWRKTrackVol(int track, int vol)
Emitted after reading a track volume chunk.
void signalWRKStringTable(const QStringList &strs)
Emitted after reading a string event types chunk.
void signalWRKError(const QString &errorStr)
Emitted for a WRK file read error.
void signalWRKSegment(int track, long time, const QString &name)
Emitted after reading a segment prefix chunk.
void signalWRKTempo(long time, int tempo)
Emitted after reading a Tempo Change message.
void signalWRKExpression(int track, long time, int code, const QString &text)
Emitted after reading an expression indication (notation) chunk.
void signalWRKTimeSig(int bar, int num, int den)
Emitted after reading a WRK Time signature.
void signalWRKHairpin(int track, long time, int code, int dur)
Emitted after reading a hairpin symbol (notation) chunk.
void signalWRKPitchBend(int track, long time, int chan, int value)
Emitted after reading a Bender message.
void signalWRKEnd()
Emitted after reading the last chunk of a WRK file.
void signalWRKThru(int mode, int port, int channel, int keyPlus, int velPlus, int localPort)
Emitted after reading an Extended Thru parameters chunk.
void signalWRKNote(int track, long time, int chan, int pitch, int vol, int dur)
Emitted after reading a Note message.
void signalWRKUnknownChunk(int type, const QByteArray &data)
Emitted after reading an unknown chunk.
void signalWRKTrackBank(int track, int bank)
Emitted after reading a track bank chunk.
void signalWRKTrackName(int track, const QString &name)
Emitted after reading a track name chunk.
void signalWRKTimeBase(int timebase)
Emitted after reading the timebase chunk.
void signalWRKTimeFormat(int frames, int offset)
Emitted after reading a SMPTE time format chunk.
void signalWRKSysex(int bank, const QString &name, bool autosend, int port, const QByteArray &data)
Emitted after reading a System Exclusive Bank.
void signalWRKCtlChange(int track, long time, int chan, int ctl, int value)
Emitted after reading a Control Change message.
void signalWRKTrackReps(int track, int reps)
Emitted after reading a track offset chunk.
void signalWRKNewTrack(const QString &name, int trackno, int channel, int pitch, int velocity, int port, bool selected, bool muted, bool loop)
Emitted after reading a new track prefix.
void signalWRKKeySig(int bar, int alt)
Emitted after reading a WRK Key Signature.
WrkChunkType
Record types within a WRK file.
@ NTRKOFS_CHUNK
Track offset.
@ NTRACK_CHUNK
Track prefix.
@ TRKPATCH_CHUNK
Track patch.
@ STRTAB_CHUNK
Table of text event types.
@ NTEMPO_CHUNK
New Tempo map.
@ VARS_CHUNK
Global variables.
@ TRKBANK_CHUNK
Track bank.
@ COMMENTS_CHUNK
Comments.
@ SGMNT_CHUNK
Segment prefix.
@ SOFTVER_CHUNK
Software version which saved the file.
@ TRKNAME_CHUNK
Track name.
@ TIMEFMT_CHUNK
SMPTE time format.
@ END_CHUNK
Last chunk, end of file.
@ STREAM_CHUNK
Events stream.
@ TRACK_CHUNK
Track prefix.
@ TIMEBASE_CHUNK
Timebase. If present is the first chunk in the file.
@ TRKOFFS_CHUNK
Track offset.
@ NSYSEX_CHUNK
System exclusive bank.
@ THRU_CHUNK
Extended thru parameters.
@ SYSEX2_CHUNK
System exclusive bank.
@ NSTREAM_CHUNK
Events stream.
@ VARIABLE_CHUNK
Variable record chunk.
@ METERKEY_CHUNK
Meter/Key map.
@ MEMRGN_CHUNK
Memory region.
@ TRKREPS_CHUNK
Track repetitions.
@ TRKVOL_CHUNK
Track volume.
@ SYSEX_CHUNK
System exclusive bank.
@ LYRICS_CHUNK
Events stream with lyrics.
Drumstick visibility macros.