Results 1 to 5 of 5

Thread: Reopen Form Widget after deletion

Hybrid View

Previous Post Previous Post   Next Post Next Post
  1. #1
    Join Date
    Jan 2008
    Location
    Alameda, CA, USA
    Posts
    5,335
    Qt products
    Qt5
    Platforms
    Windows
    Thanks
    317
    Thanked 871 Times in 858 Posts

    Default Re: Reopen Form Widget after deletion

    I read somewhere you could not store a Qwidget in a Qwidget. Is that true?
    Don't believe everything you read, especially if you read it "somewhere"...

    The whole architecture of building complex GUIs in Qt is based on storing QWidget pointers as members (and children) of other QWidgets. However, these are pointers. QWidgets are not copyable or assignable; that is, you cannot write code like:

    Qt Code:
    1.  
    2. a = b;
    3.  
    4. QWidget c = a;
    5.  
    6. // etc.
    To copy to clipboard, switch view to plain text mode 

    You can write code that manipulates QWidget pointers or references:

    Qt Code:
    1. QWidget * a = new QWidget();
    2. QWidget * b = new QWidget();
    3.  
    4. a = b; // a and b both point to the same QWidget instance; the previous b instance is lost and is a memory leak...
    5.  
    6. QWidget * c = a; // c now points to the same QWidget instance as a and b
    To copy to clipboard, switch view to plain text mode 

    You can do this, but it isn't generally recommended in most cases:

    Qt Code:
    1. class MyWidget : public QWidget
    2. {
    3. Q_OBJECT;
    4.  
    5. // ...
    6.  
    7. private:
    8. SomeOtherWidget a;
    9. };
    To copy to clipboard, switch view to plain text mode 

    The main reason why this isn't recommended is that having widgets (not widget pointers) as members of other widgets can interfere with the parent-child ownership relationships inherent in Qt. If you initialize "a" with a pointer to "this" (i.e. the MyWidget instance being constructed), then when the MyWidget instance goes out of scope, you could end up in a double destruction situation - "a" gets destroyed because it is a member variable of MyWidget, but the MyWidget instance also tries to destroy it because it is its child. One of those will lose. The only way to do it successfully is to construct "a" with no parent.

    When I would use something like this is if "SomeOtherWidget" is a QDialog or other complex widget that is expensive to construct or if I want its contents to persist from invocation to invocation. Then I can just re-use the instance each time I need to post the dialog, and it will retain all of the settings that it had when it was last invoked. If I want a fresh dialog with a default initialization each time, then I don't use this method, I create the dialog as a stack variable in the function that invokes it.
    <=== The Great Pumpkin says ===>
    Please use CODE tags when posting source code so it is more readable. Click "Go Advanced" and then the "#" icon to insert the tags. Paste your code between them.

  2. The following user says thank you to d_stranz for this useful post:

    Fivezero05 (12th August 2016)

  3. #2
    Join Date
    Aug 2016
    Posts
    5
    Qt products
    Qt5
    Platforms
    Windows
    Thanks
    4

    Default Re: Reopen Form Widget after deletion

    Thanks to d_stranz and anda_skoa, I was able to solve my problem :P Here is how i did it.

    frmMain represents the Qmainwindow.
    frmTest is the extra window I want to open and close. The variable for this is oTestFrame.

    frmMain.h
    Qt Code:
    1. ...
    2. private:
    3. frmTest * oTestFrame ; //how frmTest should be defined. This is a pointer.
    4. private slots:
    5. void onClosed();
    6. ...
    To copy to clipboard, switch view to plain text mode 
    frmMain.cpp
    Qt Code:
    1. frmMain::frmMain(QWidget *parent)
    2. : QMainWindow(parent)
    3. {
    4. ui.setupUi(this);
    5.  
    6. oTestFrame = new frmTest(); //for the first time, we initialize the object in the frmMain constructor. Now we can check if a form already exists or not
    7. }
    8.  
    9. void frmMain::on_btnOpenNew_clicked() //this can be anything. For this case, a button was used.
    10. {
    11. if (!oTestFrame->isActiveWindow()) //only one window can exist at all time.
    12. {
    13. oTestFrame->show();
    14. QObject::connect(oTestFrame, SIGNAL(destroyed()), this, SLOT(onClosed()));
    15. }
    16. }
    17.  
    18. void frmMain::onClosed()
    19. {
    20. QObject::disconnect(oTestFrame, SIGNAL(destroyed()), this, SLOT(onClosed())); //I don't really know for sure if this is necessary, after destruction, but hey, you never know
    21. oTestFrame = new frmTest(); //ready a new form te be opened. All previous changes are lost, which was the point.
    22.  
    23. }
    To copy to clipboard, switch view to plain text mode 

    frmTest.cpp : not a lot extra code is needed to let this work
    Qt Code:
    1. frmTest::frmTest(QWidget *parent)
    2. : QWidget(parent)
    3. {
    4. ui.setupUi(this);
    5. this->setAttribute(Qt::WA_DeleteOnClose, true); // This makes sure the form is destroyed after it is closed.
    6. }
    To copy to clipboard, switch view to plain text mode 

  4. #3
    Join Date
    Jan 2006
    Location
    Graz, Austria
    Posts
    8,416
    Qt products
    Qt3 Qt4 Qt5
    Platforms
    Unix/X11 Windows
    Thanks
    37
    Thanked 1,544 Times in 1,494 Posts

    Default Re: Reopen Form Widget after deletion

    I would change that to connect() right after creating the object.

    And there is no need to disconnect, the object is gone afterwards.

    Neither of which is even necessary if you use a QPointer to track the object and only create one when you need it.

    Qt Code:
    1. private:
    2. QPointer<frmTest> oTestFrame;
    To copy to clipboard, switch view to plain text mode 

    Qt Code:
    1. void frmMain::on_btnOpenNew_clicked()
    2. {
    3. if (!oTestFrame) {
    4. oTestFrame = new frmTest();
    5. oTestFrame->show();
    6. }
    7. }
    To copy to clipboard, switch view to plain text mode 

    Cheers,
    _

Similar Threads

  1. Reopen the MainWindow
    By thibs in forum Qt Programming
    Replies: 14
    Last Post: 14th February 2017, 00:58
  2. Replies: 0
    Last Post: 27th July 2016, 21:05
  3. how can i access other form widget
    By crissti_cta in forum Newbie
    Replies: 2
    Last Post: 14th December 2010, 20:51
  4. Replies: 5
    Last Post: 12th March 2010, 21:43
  5. Open one Form (widget)
    By vinny gracindo in forum Newbie
    Replies: 1
    Last Post: 7th October 2009, 13:13

Tags for this Thread

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
  •  
Qt is a trademark of The Qt Company.