You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
rosegarden/src/gui/editors/notation/TrackHeader.h

218 lines
5.7 KiB

/*
Rosegarden
A MIDI and audio sequencer and musical notation editor.
This program is Copyright 2000-2008
Guillaume Laurent <glaurent@telegraph-road.org>,
Chris Cannam <cannam@all-day-breakfast.com>,
Richard Bown <richard.bown@ferventsoftware.com>
This file is Copyright 2007-2008
Yves Guillemot <yc.guillemot@wanadoo.fr>
The moral rights of Guillaume Laurent, Chris Cannam, and Richard
Bown to claim authorship of this work have been asserted.
Other copyrights also apply to some parts of this work. Please
see the AUTHORS file and individual file headers for details.
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 2 of the
License, or (at your option) any later version. See the file
COPYING included with this distribution for more information.
*/
#ifndef _RG_TRACKHEADER_H_
#define _RG_TRACKHEADER_H_
#include "base/NotationTypes.h"
#include "base/Track.h"
#include <tqsize.h>
#include <tqwidget.h>
#include <tqlabel.h>
#include <set>
class TQLabel;
namespace Rosegarden
{
class NotePixmapFactory;
class NotationView;
class ColourMap;
class Segment;
class TrackHeader : public TQLabel
{
TQ_OBJECT
public:
/**
* Create a new track header for track of id trackId.
* *parent is the parent widget, height the height of staff and
* ypos is the staff y position on canvas.
*/
TrackHeader(TQWidget *parent, TrackId trackId, int height, int ypos);
/**
* Draw a blue line around header when current is true
* (intended to highlight the "current" track).
*/
void setCurrent(bool current);
/**
* Examine staff at x position and gather data needed to draw
* the track header.
* Return the minimum width required to display the track header.
* maxWidth is the maximum width allowed to show text. Return width
* may be greater than maxWidth if needed to show clef and key signature.
* (Header have always to show complete clef and key signature).
*/
int lookAtStaff(double x, int maxWidth);
/**
* (Re)draw the header on the notation view using the data gathered
* by lookAtStaff() last call and the specified width.
*/
void updateHeader(int width);
/**
* Return the Id of the associated track.
*/
TrackId getId()
{ return m_track;
}
/**
* Return how many text lines may be written in the header (above
* the clef and under the clef).
* This data is coming from the last call of lookAtStaff().
*/
int getNumberOfTextLines() { return m_numberOfTextLines; }
/**
* Return the Clef to draw in the header
*/
Clef & getClef() { return m_clef; }
/**
* Get which key signature should be drawn in the header
* from the last call of lookAtStaff().
*/
Rosegarden::Key & getKey() { return m_key; }
/**
* Return true if a Clef (and a key signature) have to be drawn in the header
*/
bool isAClefToDraw()
{
return (m_status & SEGMENT_HERE) || (m_status & BEFORE_FIRST_SEGMENT);
}
/**
* Return the text to write in the header top
*/
TQString getUpperText() { return m_upperText; }
/**
* Return the transposition text
* (to be written at the end of the upper text)
*/
TQString getTransposeText() { return m_transposeText; }
/**
* Return the text to write in the header bottom
*/
TQString getLowerText() { return m_label; }
/**
* Return true if two segments or more are superimposed and are
* not using the same clef
*/
bool isClefInconsistent() { return m_status & INCONSISTENT_CLEFS; }
/**
* Return true if two segments or more are superimposed and are
* not using the same key signature
*/
bool isKeyInconsistent() { return m_status & INCONSISTENT_KEYS; }
/**
* Return true if two segments or more are superimposed and are
* not using the same label
*/
bool isLabelInconsistent() { return m_status & INCONSISTENT_LABELS; }
/**
* Return true if two segments or more are superimposed and are
* not using the same transposition
*/
bool isTransposeInconsistent()
{
return m_status & INCONSISTENT_TRANSPOSITIONS;
}
private :
/**
* Convert the transpose value to the instrument tune and
* return it in a printable string.
*/
void transposeValueToName(int transpose, TQString &transposeName);
// Status bits
static const int SEGMENT_HERE;
static const int SUPERIMPOSED_SEGMENTS;
static const int INCONSISTENT_CLEFS;
static const int INCONSISTENT_KEYS;
static const int INCONSISTENT_LABELS;
static const int INCONSISTENT_TRANSPOSITIONS;
static const int BEFORE_FIRST_SEGMENT;
TrackId m_track;
int m_height;
int m_ypos;
NotationView * m_notationView;
Clef m_lastClef;
Rosegarden::Key m_lastKey;
TQString m_lastLabel;
int m_lastTranspose;
TQString m_lastUpperText;
bool m_neverUpdated;
bool m_isCurrent;
int m_lastStatusPart;
int m_lastWidth;
Clef m_clef;
Rosegarden::Key m_key;
TQString m_label;
int m_transpose;
int m_status;
bool m_current;
TQString m_upperText;
TQString m_transposeText;
int m_numberOfTextLines;
// Used to sort the segments listed in the header toolTipText
struct SegmentCmp {
bool operator()(const Segment *s1, const Segment *s2) const;
};
typedef std::multiset<Segment *, SegmentCmp> SortedSegments;
// First segment on the track.
Segment * m_firstSeg;
timeT m_firstSegStartTime;
};
}
#endif