Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. QListView & item movement
Forum Updated to NodeBB v4.3 + New Features

QListView & item movement

Scheduled Pinned Locked Moved Unsolved General and Desktop
29 Posts 4 Posters 12.4k Views 2 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • A asanka424

    this will enable drops in each item in your model. what you should do is disabling it like this

    item->setFlags(item->flags() ^ Qt::ItemIsDropEnabled)

    kshegunovK Offline
    kshegunovK Offline
    kshegunov
    Moderators
    wrote on last edited by kshegunov
    #21

    @asanka424

    what you should do is disabling it like this

    item->setFlags(item->flags() ^ Qt::ItemIsDropEnabled)
    

    Beware of such handling of flags!

    It's a very wrong way to do it. If the flag is not set you'll actually enable it, additionally it doesn't work with compound flags! Suppose you have (in binary) a = 010 and b = 110, then a ^ b == 100 which is very different from the expected 000.

    The proper way to remove a set of bits is to AND the inversion: a & ~b == 000
    /and this can be rigorously proven to be different from a ^ b if you expand the xor in the other basic operations a ^ b = (a & ~b) | (~a & b)/

    Read and abide by the Qt Code of Conduct

    A 1 Reply Last reply
    1
    • S Offline
      S Offline
      shahriar25
      wrote on last edited by
      #22

      Hi @kshegunov . Thank you for correcting that I cahnged my code.
      I tried the item changed flag and the data of item but it didn't work. I really don't know what to do

      kshegunovK 1 Reply Last reply
      0
      • S shahriar25

        Hi @kshegunov . Thank you for correcting that I cahnged my code.
        I tried the item changed flag and the data of item but it didn't work. I really don't know what to do

        kshegunovK Offline
        kshegunovK Offline
        kshegunov
        Moderators
        wrote on last edited by
        #23

        @shahriar25
        Well I don't know, I can't spot anything plainly wrong, although there isn't much code to begin with. However, this line:

        queueView->setDragEnabled(false);
        

        does look suspicious, have you removed it as it had been suggested, because it's not clear from your answer to @asanka424's question.

        Read and abide by the Qt Code of Conduct

        1 Reply Last reply
        0
        • kshegunovK kshegunov

          @asanka424

          what you should do is disabling it like this

          item->setFlags(item->flags() ^ Qt::ItemIsDropEnabled)
          

          Beware of such handling of flags!

          It's a very wrong way to do it. If the flag is not set you'll actually enable it, additionally it doesn't work with compound flags! Suppose you have (in binary) a = 010 and b = 110, then a ^ b == 100 which is very different from the expected 000.

          The proper way to remove a set of bits is to AND the inversion: a & ~b == 000
          /and this can be rigorously proven to be different from a ^ b if you expand the xor in the other basic operations a ^ b = (a & ~b) | (~a & b)/

          A Offline
          A Offline
          asanka424
          wrote on last edited by
          #24

          @kshegunov
          Yes agree with you. I just replied for the context where I knew the flag is set.

          1 Reply Last reply
          0
          • S Offline
            S Offline
            shahriar25
            wrote on last edited by
            #25

            Hi @asanka424 @kshegunov
            Sorry for replying late.
            an interesting thing happened:
            when I set the flags of the items to
            queueModel->item(i)->setFlags(queueModel->item(i)->flags() & !Qt::ItemIsDropEnabled);
            the items get disabled!
            bot when I do:
            queueModel->item(i)->setFlags(queueModel->item(i)->flags() ^ Qt::ItemIsDropEnabled);
            the is no problem. I think I'm doing something wrong.

            ANd I will try:
            queueView->setDragEnabled(false);
            and get back with a result. thank all of you for answering again. I love this from and the people who answer the questions

            1 Reply Last reply
            0
            • S Offline
              S Offline
              shahriar25
              wrote on last edited by
              #26

              Hi,
              I tried this:
              queueView->setDragEnabled(false);
              and it didn't work.

              this problem isn't fixable :( :(

              1 Reply Last reply
              0
              • SGaistS Offline
                SGaistS Offline
                SGaist
                Lifetime Qt Champion
                wrote on last edited by
                #27

                One thing you can try: start by setting the view mode or don't set it at all since you are using the default mode.

                Interested in AI ? www.idiap.ch
                Please read the Qt Code of Conduct - https://forum.qt.io/topic/113070/qt-code-of-conduct

                1 Reply Last reply
                0
                • S Offline
                  S Offline
                  shahriar25
                  wrote on last edited by
                  #28

                  Hi,
                  I gave up moving the items by drag and droping them
                  Now I want to put move up and move down buttons
                  How can I move a selected index one item up or down?

                  1 Reply Last reply
                  0
                  • S Offline
                    S Offline
                    shahriar25
                    wrote on last edited by shahriar25
                    #29

                    Hi, I put two buttons for moving items up and down but when the buttons are pressed the listView goes out of focus and the selected items don't remain selected. how can I fix this?

                    and also how can I swap children of a QDomElement?

                    1 Reply Last reply
                    0

                    • Login

                    • Login or register to search.
                    • First post
                      Last post
                    0
                    • Categories
                    • Recent
                    • Tags
                    • Popular
                    • Users
                    • Groups
                    • Search
                    • Get Qt Extensions
                    • Unsolved