blob: b5b3ef7dcbb434147e6e43d8b796bd436337f14e (
plain)
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
|
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
/*
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>
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_COMPOSITIONITEMIMPL_H_
#define _RG_COMPOSITIONITEMIMPL_H_
#include "CompositionRect.h"
#include "CompositionItem.h"
#include <qrect.h>
namespace Rosegarden
{
class Segment;
class CompositionItemImpl : public _CompositionItem {
public:
CompositionItemImpl(Segment& s, const CompositionRect&);
virtual bool isRepeating() const { return m_rect.isRepeating(); }
virtual QRect rect() const;
virtual void moveBy(int x, int y) { m_rect.moveBy(x, y); }
virtual void moveTo(int x, int y) { m_rect.setRect(x, y, m_rect.width(), m_rect.height()); }
virtual void setX(int x) { m_rect.setX(x); }
virtual void setY(int y) { m_rect.setY(y); }
virtual void setZ(unsigned int z) { m_z = z; }
virtual int x() { return m_rect.x(); }
virtual int y() { return m_rect.y(); }
virtual unsigned int z() { return m_z; }
virtual void setWidth(int w) { m_rect.setWidth(w); }
// use segment address as hash key
virtual long hashKey() { return (long)getSegment(); }
Segment* getSegment() { return &m_segment; }
const Segment* getSegment() const { return &m_segment; }
CompositionRect& getCompRect() { return m_rect; }
protected:
//--------------- Data members ---------------------------------
Segment& m_segment;
CompositionRect m_rect;
unsigned int m_z;
};
}
#endif
|