source: trunk/examples/itemviews/editabletreemodel/treeitem.cpp@ 948

Last change on this file since 948 was 846, checked in by Dmitry A. Kuminov, 14 years ago

trunk: Merged in qt 4.7.2 sources from branches/vendor/nokia/qt.

File size: 4.4 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4** All rights reserved.
5** Contact: Nokia Corporation (qt-info@nokia.com)
6**
7** This file is part of the examples of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:BSD$
10** You may use this file under the terms of the BSD license as follows:
11**
12** "Redistribution and use in source and binary forms, with or without
13** modification, are permitted provided that the following conditions are
14** met:
15** * Redistributions of source code must retain the above copyright
16** notice, this list of conditions and the following disclaimer.
17** * Redistributions in binary form must reproduce the above copyright
18** notice, this list of conditions and the following disclaimer in
19** the documentation and/or other materials provided with the
20** distribution.
21** * Neither the name of Nokia Corporation and its Subsidiary(-ies) nor
22** the names of its contributors may be used to endorse or promote
23** products derived from this software without specific prior written
24** permission.
25**
26** THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
27** "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
28** LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
29** A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
30** OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
31** SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
32** LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
33** DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
34** THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
35** (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
36** OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE."
37** $QT_END_LICENSE$
38**
39****************************************************************************/
40
41/*
42 treeitem.cpp
43
44 A container for items of data supplied by the simple tree model.
45*/
46
47#include <QStringList>
48
49#include "treeitem.h"
50
51//! [0]
52TreeItem::TreeItem(const QVector<QVariant> &data, TreeItem *parent)
53{
54 parentItem = parent;
55 itemData = data;
56}
57//! [0]
58
59//! [1]
60TreeItem::~TreeItem()
61{
62 qDeleteAll(childItems);
63}
64//! [1]
65
66//! [2]
67TreeItem *TreeItem::child(int number)
68{
69 return childItems.value(number);
70}
71//! [2]
72
73//! [3]
74int TreeItem::childCount() const
75{
76 return childItems.count();
77}
78//! [3]
79
80//! [4]
81int TreeItem::childNumber() const
82{
83 if (parentItem)
84 return parentItem->childItems.indexOf(const_cast<TreeItem*>(this));
85
86 return 0;
87}
88//! [4]
89
90//! [5]
91int TreeItem::columnCount() const
92{
93 return itemData.count();
94}
95//! [5]
96
97//! [6]
98QVariant TreeItem::data(int column) const
99{
100 return itemData.value(column);
101}
102//! [6]
103
104//! [7]
105bool TreeItem::insertChildren(int position, int count, int columns)
106{
107 if (position < 0 || position > childItems.size())
108 return false;
109
110 for (int row = 0; row < count; ++row) {
111 QVector<QVariant> data(columns);
112 TreeItem *item = new TreeItem(data, this);
113 childItems.insert(position, item);
114 }
115
116 return true;
117}
118//! [7]
119
120//! [8]
121bool TreeItem::insertColumns(int position, int columns)
122{
123 if (position < 0 || position > itemData.size())
124 return false;
125
126 for (int column = 0; column < columns; ++column)
127 itemData.insert(position, QVariant());
128
129 foreach (TreeItem *child, childItems)
130 child->insertColumns(position, columns);
131
132 return true;
133}
134//! [8]
135
136//! [9]
137TreeItem *TreeItem::parent()
138{
139 return parentItem;
140}
141//! [9]
142
143//! [10]
144bool TreeItem::removeChildren(int position, int count)
145{
146 if (position < 0 || position + count > childItems.size())
147 return false;
148
149 for (int row = 0; row < count; ++row)
150 delete childItems.takeAt(position);
151
152 return true;
153}
154//! [10]
155
156bool TreeItem::removeColumns(int position, int columns)
157{
158 if (position < 0 || position + columns > itemData.size())
159 return false;
160
161 for (int column = 0; column < columns; ++column)
162 itemData.remove(position);
163
164 foreach (TreeItem *child, childItems)
165 child->removeColumns(position, columns);
166
167 return true;
168}
169
170//! [11]
171bool TreeItem::setData(int column, const QVariant &value)
172{
173 if (column < 0 || column >= itemData.size())
174 return false;
175
176 itemData[column] = value;
177 return true;
178}
179//! [11]
Note: See TracBrowser for help on using the repository browser.