Results 1 to 8 of 8

Thread: Drag and drop outside the application

  1. #1
    Join Date
    Feb 2006
    Location
    Oslo, Norway
    Posts
    6,264
    Thanks
    36
    Thanked 1,519 Times in 1,389 Posts
    Qt products
    Qt4
    Platforms
    MacOS X Unix/X11 Windows Symbian S60 Maemo/MeeGo

    Default Drag and drop outside the application

    Does anyone happen to have tried implementing a feature where you could drag and drop something outside the application, and a new window would be created as a result of the drop?

    There is a feature like that for example in opera browser as I recall. You can drag and drop a tab outside opera's window and then a new window is created.

    I have been playing around with this for a while but I can't figure out any working solution.
    I am connected to QDrag::targetChanged(QWidget*) signal and the target seems always to be null when moving a drag outside my window.
    Btw, I have tried to install an event filter on QApplication::desktop() but it seems to get never called..

    Any tip would be highly appreciated!

  2. #2
    Join Date
    Feb 2006
    Location
    Oslo, Norway
    Posts
    6,264
    Thanks
    36
    Thanked 1,519 Times in 1,389 Posts
    Qt products
    Qt4
    Platforms
    MacOS X Unix/X11 Windows Symbian S60 Maemo/MeeGo

    Default Re: Drag and drop outside the application

    I found a bit hackish way to do it. Not too elegant, but it's working at least on win2k+ (and somehow)..
    I created a transparent top level widget covering the whole desktop area, and of course, accepting drops..

    As window transparency needs a composition extension and manager on X11 and I didn't have the interest to start configuring them, I cannot say about Linux.

    Anyway, I wish I found a better way to solve this..

    Edit: oh, and in case anyone is interested to check it out:
    Attached Files Attached Files

  3. #3
    Join Date
    Feb 2006
    Location
    Oslo, Norway
    Posts
    6,264
    Thanks
    36
    Thanked 1,519 Times in 1,389 Posts
    Qt products
    Qt4
    Platforms
    MacOS X Unix/X11 Windows Symbian S60 Maemo/MeeGo

    Default Re: Drag and drop outside the application

    It is basically impossible to use QDrag. Since it's based on MIME types, there is always some application which is (too?) liberal to accept drags. Like for example firefox seems to accept almost anything.. Also, detecting the drop point might be problematic if there's nothing accepting it (a reliable enough location could be retrieved with QCursor::pos(), though).

    It seems to be fairly easy to do fancy "fake drag" effects by using QRubberBand the way QDockWidget does. So if anyone is ever stuck on the same problem, the answer is in QDockWidgetPrivate::mouse*Event().
    J-P Nurmi

  4. #4
    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: Drag and drop outside the application

    It could be that Opera's drag really holds a mime object, which is accepted by the desktop and that Opera is then run by the desktop manager to handle the data. It could be that I am wrong too You could write to Opera developers asking for help. They use Qt3, but I'm quite sure a simmilar mechanism will work for Qt4.

    There is an example application in Qt4 distribution which lists mime-types held by a drag if you perform a drop on the application's window. It's called droptarget or something simmilar.

  5. The following user says thank you to wysota for this useful post:

    jpn (24th August 2006)

  6. #5
    Join Date
    Feb 2006
    Location
    Oslo, Norway
    Posts
    6,264
    Thanks
    36
    Thanked 1,519 Times in 1,389 Posts
    Qt products
    Qt4
    Platforms
    MacOS X Unix/X11 Windows Symbian S60 Maemo/MeeGo

    Default Re: Drag and drop outside the application

    Quote Originally Posted by wysota
    There is an example application in Qt4 distribution which lists mime-types held by a drag if you perform a drop on the application's window. It's called droptarget or something simmilar.
    Good idea! I checked it out and it doesn't seem to be a real drag object. Or at least the dropsite example doesn't accept it nor show any info..

    By the way, Opera's drag works only in Windows. I'm not familiar with drag'n'drop stuff in WinAPI, but I get the feeling that it's not a real drag'n'drop at all..
    J-P Nurmi

  7. #6
    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: Drag and drop outside the application

    It could be that it is making a screenshot of the desktop and using it as an overlay so that it knows that the drop was made "outside" the main window (based on coordinates), so you might have not dropped on the dropsite window but a window on top of it, which seemed to look "invisible". It's a crude but effective way of doing such things.

  8. The following user says thank you to wysota for this useful post:

    jpn (25th August 2006)

  9. #7
    Join Date
    Feb 2006
    Location
    Oslo, Norway
    Posts
    6,264
    Thanks
    36
    Thanked 1,519 Times in 1,389 Posts
    Qt products
    Qt4
    Platforms
    MacOS X Unix/X11 Windows Symbian S60 Maemo/MeeGo

    Default Re: Drag and drop outside the application

    Quote Originally Posted by wysota
    It could be that it is making a screenshot of the desktop and using it as an overlay so that it knows that the drop was made "outside" the main window (based on coordinates), so you might have not dropped on the dropsite window but a window on top of it, which seemed to look "invisible". It's a crude but effective way of doing such things.
    This man is full of acute ideas! The only problem with this approach is that any animation or motion in other open applications would be ceased during the drag (unless the screenshot of the desktop is updated frequently, which might be a bit costly and cause flicker, I think). I tested Opera's drag once again and for example flash animations in mozilla keep going during the drag. So I believe it's just a custom top level widget in the same sense than QRubberBand in QDockWidget implementation.
    J-P Nurmi

  10. #8
    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: Drag and drop outside the application

    Yeah, could be. Or the mask keeps the contents of the "screenshot" widget from being visible, but surely using a top-level widget makes more sense.

Similar Threads

  1. drag and drop from outside qt application
    By elflord in forum Qt Programming
    Replies: 1
    Last Post: 16th February 2009, 15:40
  2. drag and drop QToolButton in QToolBar
    By NBilal in forum Qt Programming
    Replies: 1
    Last Post: 28th December 2008, 20:11
  3. Change cursor & status during Drag & Drop
    By ronlongo in forum Qt Programming
    Replies: 0
    Last Post: 1st December 2008, 16:56
  4. Drag and Drop QTableWidget and QTableView
    By scorpion11 in forum Qt Programming
    Replies: 5
    Last Post: 8th April 2008, 09:33
  5. Drag and drop revisited
    By Big Duck in forum Newbie
    Replies: 2
    Last Post: 30th June 2006, 16:41

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.