Вот фрагмент кода, показывающий мой сценарий:
Код: Выделить всё
from PyQt6.QtWidgets import*
from PyQt6.QtGui import *
from PyQt6.QtCore import *
import sys
class MainWindow(QMainWindow):
def __init__(self):
super().__init__()
self.setWindowTitle("My App")
self.varlayout = QGridLayout()
self.varlayout.addWidget(QLabel("Hello World"),1,1)
self.varlayout.addWidget(QLabel("Hello World"),2,2)
self.varlayout.addWidget(QLabel("Hello World"),3,3)
Move = QPushButton("Move",self)
Move.clicked.connect(self.MoveLabel)
self.varlayout.addWidget(Move,3,1)
self.widget = QWidget()
self.widget.setLayout(self.varlayout)
self.setCentralWidget(self.widget)
def MoveLabel(self):
self.child = self.varlayout.itemAtPosition(1,1).widget()
self.anim = QPropertyAnimation(self.child, b"pos")
self.anim.setDuration(500)
Pos = QPoint(3,1)
self.anim.setEndValue(Pos)
self.anim.start()
if __name__ == "__main__":
app = QApplication(sys.argv)
window = MainWindow()
window.show()
app.exec()
[img]https://i .sstatic.net/XYxB5ycg.png[/img]
Я представлял себе, что метод MoveLabel должен делать следующее:

Вместо этого он делает:

Покопавшись в документации, я обнаружил, что Qpoint иногда используется в качестве вектора, что, я думаю, и происходит в этом сценарии, но в то же время, похоже, он не следует математическим правилам векторов в соответствии с тем, как расположена сетка
Это заставляет меня задуматься что Qpoint относится к местоположению пикселя в верхнем левом углу.
Кроме того, насколько мне известно, ячейка в макете сетки не существует до тех пор, пока она не будет заполнена, но затем я запускаю возникла проблема, как переместить объект в пустую ячейку во время выполнения, если он вообще не существует.
Итак, сейчас я нахожусь на распутье:
- Я неправильно использую Qpoint в коде?
- Разве я не должен использовать Qpoint в этом сценарии?
- Есть ли другой способ добиться того, чего я хочу?
Подробнее здесь: https://stackoverflow.com/questions/788 ... ut-in-pyqt