General questions about Model in Qt (docs)
-
Hi guys and girls! I start learning model concept in Qt (MVD pattern). And reading documantations I'd like to clearify some question. So.
-
In Qt's docs says "The
QAbstractItemModel
class provides the abstract interface for item model classes". But what does really means "item model classes"? And whyQAbstractListModel
andQAbstractTableModel
are not "item model classes"? -
In Qt's docs about
QAbstractItemModel
: "Every item of data that can be accessed via a model has an associated model index". What is this item? I have picture from doc.
PS Sorry for posting picture like that but I did't find how to hide it under spoiler.
[edit: Fixed image link, SGaist]
-
-
@Xilit said in General questions about Model in Qt (docs):
Hi guys and girls! I start learning model concept in Qt (MVD pattern). And reading documantations I'd like to clearify some question. So.
- In Qt's docs says "The
QAbstractItemModel
class provides the abstract interface for item model classes". But what does really means "item model classes"?
It means a concrete class implementing the abstract model. Qt leaves the implementation to the user - this way you can use all kinds of data sources, like:
- QStringList
- custom object trees
- custom lists
- SQL databases
- JSON, CBOR, XML
- etc.
And why
QAbstractListModel
andQAbstractTableModel
are not "item model classes"?They are.
- In Qt's docs about
QAbstractItemModel
: "Every item of data that can be accessed via a model has an associated model index". What is this item? I have picture from doc.
Item is on the left.
PS Sorry for posting picture like that but I did't find how to hide it under spoiler.
- In Qt's docs says "The
-
Thank you! Just to be sure I understood all correctly.)
- "Item model classes" it's all classes that are inherited from
QAbstractItemModel
include your own (another words implementQAbstractItemModel
). - If
QAbstractListModel
andQAbstractTableModel
are "item model classes" they are also inherited fromQAbstractItemModel
, right? Thise classes just "special case" ofQAbstractListModel
if I can say so. Just for user convinience, like temlates. - So Pic1 is "Item" and Pic2 is "Model" which consists from bunch of "Items"?
- (Z(:^ Didn't understand what does it means. :)))
- "Item model classes" it's all classes that are inherited from
-
@Xilit said in General questions about Model in Qt (docs):
Thank you! Just to be sure I understood all correctly.)
- "Item model classes" it's all classes that are inherited from
QAbstractItemModel
include your own (another words implementQAbstractItemModel
).
I guess so. I have not written the docs ;-) My recommendation: try to write your own simple subclass QAbstractItemModel, based on QStringList data. Seeing how it works in practice will give you 100x more understanding without getting stuck at terminology.
- If
QAbstractListModel
andQAbstractTableModel
are "item model classes" they are also inherited fromQAbstractItemModel
, right? Thise classes just "special case" ofQAbstractListModel
if I can say so. Just for user convinience, like temlates.
Yes. You can check this in the documentation (at top of every class documentation there is a "inherts" section which states what give class inherits. Or, in Qt Creator, you can hit F2 when hovering over class name, to go to the header file, then you can see what it inherits from, too.
- So Pic1 is "Item" and Pic2 is "Model" which consists from bunch of "Items"?
You could say that, yes. Model is an abstract concept, it can have many definitions/ representations.
Item is a single piece of data, like one leaf of a tree, one cell in a table, one row in a list, one pixel on a screen etc. Model data is the whole tree, table, list, screen. The model (class in Qt) is a general access point to the data.
So all classes using the model (QTreeView, ListView in QML, and many many more) are asking the model for data, descriptions, asking the model to modify the data etc. These "higher" view classes do not know anything about the data - they don't know if it is a list, if it is taken from database or text file, nothing. All the info they have is what model class gives them.
That's why all models have to be based on QAbstractItemModel (directly or indirectly - you can subclass QAbstractTableModel if it fits your use case better), to have one common set of methods and access points.
- (Z(:^ Didn't understand what does it means. :)))
It's my signature. An emoticon of Napoleon. Because why not :P
- "Item model classes" it's all classes that are inherited from
-
Wow! Thank you so much!
"I have not written the docs ;-)" That's a pity! I wish you have. Your style of explanation is more understandable than docs have. Maybe Qt team should hire you.:)))
"It's my signature. An emoticon of Napoleon. Because why not :P"
Sorry, I thought it was written to my. I didn't notice that it was your signature. XD
Thank you my friend to help me out with docs!
-
Thanks, that's nice to hear. I always think my explanations are too complex :D
Happy coding!
-
I have another bunch of questions. I don't want to start new topic of newbiesh questions so I decided to continue write here.
- DOCS:
"Model indexes contain a pointer to the model that created them, and this prevents confusion when working with more than one model".
QAbstractItemModel *model = index.model();
What does .model() means? It must be a member of
QAbstractItemModel
class but I can't find such memeber inQAbstractItemModel
class. Maybe it should beQAbstractItemModel *model = model.index();
But there is no member index() with no parameters. Also I can't see Model indexes in this example.
- Another question.
I always thought that in C++ pure virtual function is obligatory for implementation in child classes. To illustrate that I've created class A with
virtual void myFunction() = 0;
and class B : public A (class B inherits class A). So class A is abstract (you can't create object of such class). Class B is not abstract so I can create object of class B... BUT! Only if I implement virtual function
virtual void myFunction() = 0;
in class B first. Maybe not implement, but just write like that:
void myFunction() override {};
Even without implementation. Only after that I can create object of class B. So implementation of virtual function is obligatory for child classes.
But when I made subclass from
QAbstractItemModel
with 5 virtual functions (index()
,parent()
,rowCount()
,columnCount()
, anddata()
) my project was build even when I commentedindex()
,rowCount()
,columnCount()
which are virtual. Why if I must implement all virtual functions?-
If I press F2 to name of class (for example
QStringListModel
) I go to header file. But where is cpp-files to see the impementation of it? -
Also I'd like to find out what is Qt-class is? I mean
Qt::green
orQt::TextFormat
? When you typeQt::
you have huge list of autocomplite. Is this superglobal class?
- DOCS:
-
@Xilit
model()
is not a member ofQAbstractItemModel
, it is an instance of it..QModelIndex::model()
(which is a member of theQModelIndex
class) returns the model the index belongs to. It should not be what you said it should be :) With few/rare exceptions, you can rely on the Qt doc pages being correct!Yes to everything you said about pure virtual (but not just virtual without pure, I think you know that.) So far as I can see they do need implementing in a sub-class, so if you truly derived from
QAbstractItemModel
you would need to implement. There are queries on the web showing others receiving compiler/linker errors when they fail to do so. I think you'd have to show your code. Thinking aloud, did you instantiate your sub-class? Without that I think it would remain pure virtual itself. As perQAbstractModel
class, it does not prevent compiling/linking, but you can't instantiate from it. -
Thank you!
Thinking aloud, did you instantiate your sub-class? Without that I think it would remain pure virtual itself.
I know that was very silly but I didn't create any object of this class.:( When I created it I've got error that I need implement some methods. I didn’t think that I would wait for this error so much.:D
Maybe someone can help me with 3-4 questions? Thank you!
-
@Xilit said in General questions about Model in Qt (docs):
- If I press F2 to name of class (for example QStringListModel) I go to header file. But where is cpp-files to see the impementation of it?
If you checked "Sources" during installation of Qt (in Qt installer) you should be able to go to the .cpp file after pressing F4.
But if you don't have Qt sources, then there is actually no .cpp file so Qt Creator cannot show it.
You can always look the file up, for example in Woboq code browser or by downloading Qt source code manually.
- Also I'd like to find out what is Qt-class is? I mean Qt::green or Qt::TextFormat? When you type Qt:: you have huge list of autocomplite. Is this superglobal class?
It's a namespace. See the docs.
-
Thank you!
That's strange. I've checked "Sources" during installation of Qt but after pressing F4 nothing happend. For exmple I created in my project
QAbstractItemModel *model;
, put cursor onQAbstractItemModel
and press F2 --> go to header (qabstractitemmodel.h
). And after pressing F4 nothing happened. Did I made something wrong?"It's a namespace. See the docs."
Got it. Thank you!
-
@Xilit said in General questions about Model in Qt (docs):
Thank you!
That's strange. I've checked "Sources" during installation of Qt but after pressing F4 nothing happend. For exmple I created in my project
QAbstractItemModel *model;
, put cursor onQAbstractItemModel
and press F2 --> go to header (qabstractitemmodel.h
). And after pressing F4 nothing happened. Did I made something wrong?Perhaps it does not work nowadays. Last time I tried this was a long time ago.
"It's a namespace. See the docs."
Got it. Thank you!
-
-
@Xilit said in General questions about Model in Qt (docs):
That's strange. I've checked "Sources" during installation of Qt but after pressing F4 nothing happend. For exmple I created in my projectQAbstractItemModel *model;, put cursor on QAbstractItemModel and press F2 --> go to header (qabstractitemmodel.h). And after pressing F4 nothing happened. Did I made something wrong?
I'm pretty sure, you have to add the path manually in the settings of QtCreator.
Settings -> Debugger -> General -> Add QtSources -