Future of Kexi Table View

As a follow up of his promising Qt Quick Components for Desktop post, Jens shares with us results of his Qt Quick flavour of the QTableView class. This motivated me to think what would be most future-proof if not the best way of finally porting the old Qt3Support-based KexiTableView class which with all related classes builds up data/database-aware library utilized by Kexi for presenting tabular data in various contexts. It's so big and complex that I left this task as the very last item while enjoying porting Kexi to Qt 4.

It's definitely time to port and refresh this code. Qt3Support means a no-go for mobile targets and this is in part why Adam Pigg contributed with abstraction allowing to plug separate much simpler implementation of the tabular view.

What a coincidence, just a day before the Jens' post I enjoyed a discussion with Sebas.

The requirements for the new implementation are mostly the same as before, the table view contains a lot of data, sometimes more than spreadsheets, have custom delegates for viewing and editing, supports column sorting and row filtering. And the model view is database-oriented (current implementation appeared before Qt4 model/view was announced). There are plans for asynchronous data loading.

So my question was (also asked in the comments), regarding performance, whether to stay with Qt Graphics View like the original Plasma or look at QML/QtDeclarative. I definitely would like to avoid QScrollArea. The target is desktop usage, while only stripped-down version of this widget would be used on mobile devices.

So far it looks like using Qt Graphics View in a way how Plasma does so is the way to go, which Jens correctly calls "more static". If we look at the requirements, Qt Quick gives no particular benefits here, it can just serve as alternative implementation e.g. for simple mobile editors or just data viewers. In this case some model code could be shared as a nice exercise.

What do you think?

When would you see the new implementation is rather open question. For now the classic Qt3Support-based solution just works, what is important.

And in other news,


On the Qt5-feedback list, a Nokia employee expressly stated that QML "isn't really meant for" things like "visualization of large data sets", and instead, such use-cases would probably better fit with QGraphicsView, or direct use of the Qt Scene Graph (or any other scene graph):

By smls at Tue, 05/31/2011 - 20:53

Another interesting comment by a Nokia/Qt employee (Gunnar Sletta) about the use-case of visualizing huge items scenes of which only a small number is in view at the same time:

By smls at Wed, 06/01/2011 - 22:15

Thanks! Detailed explanation indeed.

By Jarosław Staniek at Thu, 06/02/2011 - 18:47