Results 1 to 11 of 11

Thread: QGraphicsView and embeded widgets

  1. #1
    Join Date
    Jan 2007
    Location
    Paris
    Posts
    459
    Thanks
    98
    Thanked 3 Times in 3 Posts
    Qt products
    Qt4 Qt5

    Default QGraphicsView and embeded widgets

    Hey there,

    I have a QGraphicsView which contains another QGraphicsView embeded in a QGraphicsProxyWidget.

    Here is my insertWidget function :

    Qt Code:
    1. /* virtual */ void qkListBase::insertWidget(int index,
    2. QWidget * widget,
    3. int stretch,
    4. Qt::Alignment alignment)
    5. {
    6. if (contains(widget)) return;
    7.  
    8. Q_D(qkListBase);
    9.  
    10. QGraphicsProxyWidget * proxyWidget = scene()->addWidget(widget);
    11.  
    12. QPalette p(widget->palette());
    13. p.setColor(QPalette::Window, Qt::transparent);
    14. widget->setPalette(p);
    15.  
    16. qkListBasePrivate::item * Item = new qkListBasePrivate::item(proxyWidget);
    17. Item->proxyWidget = proxyWidget;
    18. Item->stretch = stretch;
    19. Item->alignment = alignment;
    20.  
    21. d->items.push_back(Item);
    22.  
    23. d->resetGeometry();
    24. }
    To copy to clipboard, switch view to plain text mode 

    - When I add a widget into my main QGraphicsView / scene : it works fine.
    - When I add a widget into a QGraphicsView inside my main QGraphicsView I get the following :

    Qt Code:
    1. warning: QPainter::begin: A paint device can only be painted by one painter at a time.
    2.  
    3. warning: QPainter::begin: A paint device can only be painted by one painter at a time.
    4.  
    5. warning: ASSERT: "state" in file kernel\qwidget.cpp, line 4470
    6.  
    7. warning: Invalid parameter passed to C runtime function.
    8.  
    9. warning: Invalid parameter passed to C runtime function.
    10.  
    11. warning: QPainter::begin: A paint device can only be painted by one painter at a time.
    To copy to clipboard, switch view to plain text mode 

    Anyone knows why ?

  2. #2
    Join Date
    Jan 2006
    Location
    Warsaw, Poland
    Posts
    33,360
    Thanks
    3
    Thanked 5,015 Times in 4,792 Posts
    Qt products
    Qt3 Qt4 Qt5 Qt/Embedded
    Platforms
    Unix/X11 Windows Android Maemo/MeeGo
    Wiki edits
    10

    Default Re: QGraphicsView and embeded widgets

    What is the point of having a graphicsview inside a graphicsview?

  3. #3
    Join Date
    Jan 2007
    Location
    Paris
    Posts
    459
    Thanks
    98
    Thanked 3 Times in 3 Posts
    Qt products
    Qt4 Qt5

    Default Re: QGraphicsView and embeded widgets

    Why not ? After all QGraphicsView is a widget like the others.

    I'm using QGraphicsView as a list item container for both Widgets and QGraphicsItems.
    Last edited by bunjee; 9th October 2008 at 10:13.

  4. #4
    Join Date
    Jan 2007
    Location
    Paris
    Posts
    459
    Thanks
    98
    Thanked 3 Times in 3 Posts
    Qt products
    Qt4 Qt5

    Default Re: QGraphicsView and embeded widgets

    I'm on Qt 4.4.3 Windows.

    Consider the following code :

    Qt Code:
    1. group->setScene(scene);
    2.  
    3. QGraphicsView * group2 = new QGraphicsView;
    4. group2->setScene(scene2);
    5.  
    6. group->scene()->addWidget(group2);
    7. QLineEdit * lineEdit = new QLineEdit;
    8. group2->scene()->addWidget(lineEdit); // <<< The trouble maker
    9.  
    10. group->show();
    To copy to clipboard, switch view to plain text mode 

    There is no way to add a widget inside a QGraphicsView that is embedded into another one.

  5. #5
    Join Date
    Jan 2006
    Location
    Warsaw, Poland
    Posts
    33,360
    Thanks
    3
    Thanked 5,015 Times in 4,792 Posts
    Qt products
    Qt3 Qt4 Qt5 Qt/Embedded
    Platforms
    Unix/X11 Windows Android Maemo/MeeGo
    Wiki edits
    10

    Default Re: QGraphicsView and embeded widgets

    Quote Originally Posted by bunjee View Post
    Why not ? After all QGraphicsView is a widget like the others.
    I'm asking about a reason, maybe there is a better way to do it.

    I'm using QGraphicsView as a list item container for both Widgets and QGraphicsItems.
    Why not use an item group instead?

  6. #6
    Join Date
    Jan 2007
    Location
    Paris
    Posts
    459
    Thanks
    98
    Thanked 3 Times in 3 Posts
    Qt products
    Qt4 Qt5

    Default Re: QGraphicsView and embeded widgets

    I'm looking for an explanation for :

    Why doesn't this work:

    Qt Code:
    1. group->setScene(scene);
    2.  
    3. QGraphicsView * group2 = new QGraphicsView;
    4. group2->setScene(scene2);
    5.  
    6. group->scene()->addWidget(group2);
    7. QLineEdit * lineEdit = new QLineEdit;
    8. group2->scene()->addWidget(lineEdit); // <<< The trouble maker
    9.  
    10. group->show();
    To copy to clipboard, switch view to plain text mode 

    If there is any.

  7. #7
    Join Date
    Jan 2006
    Location
    Warsaw, Poland
    Posts
    33,360
    Thanks
    3
    Thanked 5,015 Times in 4,792 Posts
    Qt products
    Qt3 Qt4 Qt5 Qt/Embedded
    Platforms
    Unix/X11 Windows Android Maemo/MeeGo
    Wiki edits
    10

    Default Re: QGraphicsView and embeded widgets

    Yes, I can imagine embedding a GV into a GV was not forseen by the team who implemented "widgets on graphics view". I really don't see why anyone would want to embed a widget into a graphicsview that is embedded into a graphicsview. You can have the same functionality with much simpler design...

  8. #8
    Join Date
    Jan 2007
    Location
    Paris
    Posts
    459
    Thanks
    98
    Thanked 3 Times in 3 Posts
    Qt products
    Qt4 Qt5

    Default Re: QGraphicsView and embeded widgets

    In that case that statement in Qt doc is not really true :

    The QGraphicsProxyWidget class provides a proxy layer for embedding a QWidget in a QGraphicsScene.
    QGraphicsProxyWidget embeds any QWidget-based widget
    They are simpler design, but they are a huge flexibility trade-off.

    What I'm trying to do is the following :

    I'm coding a custom graphicsView based list that supports the following :
    - Mixing QGraphicsItem and QWidget seamlessly.

    That way I'm getting the best of both world : having a QWidget enabled list that also supports QGraphicsItem in case I need 10 000 low memory items.
    (As you can see I don't like the concept of model view delegates).

    I've also developped my own QGroupBox based on my QGraphicsView list which also supports both QGraphicsItem and widget.

    Only problem is when I mix my list and my groupBox with a QWidget, QPainter error blows up.

    I think that might be a Qt 4.4.3 design flaw.
    Last edited by bunjee; 10th October 2008 at 01:18.

  9. #9
    Join Date
    Jan 2006
    Location
    Warsaw, Poland
    Posts
    33,360
    Thanks
    3
    Thanked 5,015 Times in 4,792 Posts
    Qt products
    Qt3 Qt4 Qt5 Qt/Embedded
    Platforms
    Unix/X11 Windows Android Maemo/MeeGo
    Wiki edits
    10

    Default Re: QGraphicsView and embeded widgets

    Quote Originally Posted by bunjee View Post
    In that case that statement in Qt doc is not really true :
    So open the appropriate source file of the reference and change "any" to "almost any" and then focus on finding solution to your problem.


    They are simpler design, but they are a huge flexibility trade-off.
    Somehow I don't see a tradeoff of substituting a graphicsview with a graphicsitem.

    Only problem is when I mix my list and my groupBox with a QWidget, QPainter error blows up.

    I think that might be a Qt 4.4.3 design flaw.
    You could probably call it a bug, but on the other hand I completely understand this "improper" behaviour. Again I suggest to substitute the internal view by an item containing other items. Keep in mind that "widgets on graphics view" is a relatively new and very complicated architecture that required many internal changes to Qt in various places. Don't expect it to do everything without problems. Your problem is probably because two different views at once try to paint the same widget which is an abnormal situation.

  10. #10
    Join Date
    Jan 2007
    Location
    Paris
    Posts
    459
    Thanks
    98
    Thanked 3 Times in 3 Posts
    Qt products
    Qt4 Qt5

    Default Re: QGraphicsView and embeded widgets

    So open the appropriate source file of the reference and change "any" to "almost any" and then focus on finding solution to your problem.
    Well the solution is to get hired by the trolls to modify QGraphicsView design... or report a bug :-). I don't see any valid solution that is not a hack.

    Somehow I don't see a tradeoff of substituting a graphicsview with a graphicsitem.
    Consider the following scenario : you're coding a KDE like desktop widget that supports various transformations and animations.
    - You inherit QGraphicsView.
    - Now you're adding your widget window items using scene()->addItem().
    - One of them happens to contain a QGraphicsView representing some random diagram... You're screwed.

    When you're looking at other modern GUI like say cocoa / core animation. They are some animations / interactions and opengl components that you simply cannot do properly using current Qt release. Because your whole widget is never based on some vectorial QGraphicsView representation. So most of your Qt app design is last century.

    Which will - hopefully - change in 4.5.

    Again I suggest to substitute the internal view by an item containing other items
    Yeah but if you do that you're reinventing the wheel for each specific "group" item, why can't we be generic ?

    And you cannot use a QGraphicsItem coupled with a QWidget in something else than QGraphicsView.

  11. #11
    Join Date
    Jan 2006
    Location
    Warsaw, Poland
    Posts
    33,360
    Thanks
    3
    Thanked 5,015 Times in 4,792 Posts
    Qt products
    Qt3 Qt4 Qt5 Qt/Embedded
    Platforms
    Unix/X11 Windows Android Maemo/MeeGo
    Wiki edits
    10

    Default Re: QGraphicsView and embeded widgets

    Quote Originally Posted by bunjee View Post
    You're screwed.
    So be sure not to do that. Qt is not perfect and it can't do everything. As for now we have to live with it.

    When you're looking at other modern GUI like say cocoa / core animation. They are some animations / interactions and opengl components that you simply cannot do properly using current Qt release.
    Well... I don't think they allow you to do some things graphics view enables you to do...

    Yeah but if you do that you're reinventing the wheel for each specific "group" item, why can't we be generic ?
    I don't see any reinventing the wheel here. You want an item containing other items. For me it looks like QGraphicsItemGroup.

    And you cannot use a QGraphicsItem coupled with a QWidget in something else than QGraphicsView.
    Yes, and you can't do many other things as well, like drawing widgets from external threads. Just accept it and focus on solving your problem

Bookmarks

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts
  •  
Digia, Qt and their respective logos are trademarks of Digia Plc in Finland and/or other countries worldwide.