低代码软件搭建自学第二天——构建拖拽功能

embedded/2024/12/25 22:55:04/

文章目录

  • 第 3 步:实现拖拽功能
    • 3.1 拖拽的基本概念
    • 3.2 创建基础拖拽界面
      • 代码示例:拖拽矩形
      • 运行结果:
    • 3.3 添加多个拖拽元素
      • 代码示例:多个拖拽元素
      • 运行结果:
    • 3.4 添加工具箱
      • 代码示例:工具箱 + 拖拽
      • 运行结果:
    • 3.5 画布缩放和平移
      • 代码示例:缩放和平移画布
      • 运行结果:
    • 下一步计划


继续学习 构建拖拽功能,这是类似 Visio 的核心功能,接下来学习如何实现 拖拽组件连线功能自由画布设计

第 3 步:实现拖拽功能

3.1 拖拽的基本概念

在 PyQt 中,可以通过 QGraphicsViewQGraphicsSceneQGraphicsItem 来实现拖拽和自由画布操作:

  • QGraphicsView:可视化窗口,用来显示画布。
  • QGraphicsScene:管理画布上的所有元素(图形、线条等)。
  • QGraphicsItem:画布上的每个图形元素(比如矩形、圆形、图片等),支持拖拽。

3.2 创建基础拖拽界面

我们先从简单的拖拽矩形开始。

代码示例:拖拽矩形

python">import sys
from PyQt6.QtWidgets import QApplication, QMainWindow, QGraphicsView, QGraphicsScene, QGraphicsRectItem
from PyQt6.QtCore import Qtclass MainWindow(QMainWindow):def __init__(self):super().__init__()self.setWindowTitle("拖拽矩形示例")self.setGeometry(100, 100, 800, 600)# 创建场景和视图self.scene = QGraphicsScene()  # 画布self.view = QGraphicsView(self.scene, self)  # 显示画布self.setCentralWidget(self.view)# 添加矩形图形项rect = QGraphicsRectItem(0, 0, 100, 100)  # 创建一个矩形rect.setBrush(Qt.GlobalColor.blue)  # 设置填充颜色rect.setFlag(QGraphicsRectItem.GraphicsItemFlag.ItemIsMovable)  # 设置可拖动self.scene.addItem(rect)  # 添加到画布中# 创建应用程序
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec())

运行结果:

  • 窗口中会显示一个矩形,用户可以用鼠标拖动它。
    在这里插入图片描述

3.3 添加多个拖拽元素

现在,我们在画布上添加多个拖拽组件(矩形、圆形等),并为它们设置不同的颜色和大小。

代码示例:多个拖拽元素

python">import sys
from PyQt6.QtWidgets import QApplication, QMainWindow, QGraphicsView, QGraphicsScene, QGraphicsRectItem, QGraphicsEllipseItem
from PyQt6.QtCore import Qtclass MainWindow(QMainWindow):def __init__(self):super().__init__()self.setWindowTitle("多个拖拽元素")self.setGeometry(100, 100, 800, 600)# 创建场景和视图self.scene = QGraphicsScene()self.view = QGraphicsView(self.scene, self)self.setCentralWidget(self.view)# 添加矩形rect = QGraphicsRectItem(0, 0, 100, 100)rect.setBrush(Qt.GlobalColor.blue)rect.setFlag(QGraphicsRectItem.GraphicsItemFlag.ItemIsMovable)self.scene.addItem(rect)# 添加圆形circle = QGraphicsEllipseItem(150, 150, 100, 100)  # 圆形circle.setBrush(Qt.GlobalColor.green)circle.setFlag(QGraphicsEllipseItem.GraphicsItemFlag.ItemIsMovable)self.scene.addItem(circle)# 添加另一个矩形rect2 = QGraphicsRectItem(300, 100, 150, 50)rect2.setBrush(Qt.GlobalColor.red)rect2.setFlag(QGraphicsRectItem.GraphicsItemFlag.ItemIsMovable)self.scene.addItem(rect2)# 创建应用程序
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec())

运行结果:

  • 画布上会显示三个图形:一个蓝色矩形、一个绿色圆形、一个红色矩形。
  • 用户可以用鼠标拖动这些元素到任意位置。
    在这里插入图片描述

3.4 添加工具箱

我们现在为界面添加一个简单的工具箱,允许用户从工具箱中拖拽组件到画布。

代码示例:工具箱 + 拖拽

python">import sys
from PyQt6.QtWidgets import (QApplication, QMainWindow, QGraphicsView, QGraphicsScene, QGraphicsRectItem,QDockWidget, QListWidget, QListWidgetItem
)
from PyQt6.QtCore import Qtclass MainWindow(QMainWindow):def __init__(self):super().__init__()self.setWindowTitle("工具箱 + 拖拽")self.setGeometry(100, 100, 800, 600)# 创建场景和视图self.scene = QGraphicsScene()self.view = QGraphicsView(self.scene, self)self.setCentralWidget(self.view)# 创建工具箱self.toolbox = QDockWidget("工具箱", self)self.addDockWidget(Qt.DockWidgetArea.LeftDockWidgetArea, self.toolbox)# 工具箱内容:列表self.list_widget = QListWidget()self.toolbox.setWidget(self.list_widget)# 添加工具箱选项for shape in ["矩形", "圆形"]:item = QListWidgetItem(shape)self.list_widget.addItem(item)# 连接工具箱事件self.list_widget.itemClicked.connect(self.add_item_to_scene)def add_item_to_scene(self, item):"""根据工具箱选项在画布上添加图形"""if item.text() == "矩形":rect = QGraphicsRectItem(0, 0, 100, 100)rect.setBrush(Qt.GlobalColor.blue)rect.setFlag(QGraphicsRectItem.GraphicsItemFlag.ItemIsMovable)self.scene.addItem(rect)elif item.text() == "圆形":circle = QGraphicsEllipseItem(0, 0, 100, 100)circle.setBrush(Qt.GlobalColor.green)circle.setFlag(QGraphicsEllipseItem.GraphicsItemFlag.ItemIsMovable)self.scene.addItem(circle)# 创建应用程序
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec())

运行结果:

  • 左侧是一个工具箱,包含 “矩形” 和 “圆形” 选项。
  • 点击工具箱中的选项,图形会出现在画布上,并且可以拖拽到任意位置。
    在这里插入图片描述

3.5 画布缩放和平移

为了让用户能够更方便地操作画布,我们添加画布的缩放和平移功能。

代码示例:缩放和平移画布

python">import sys
from PyQt6.QtWidgets import QApplication, QMainWindow, QGraphicsView, QGraphicsScene, QGraphicsRectItem
from PyQt6.QtCore import Qt
from PyQt6.QtGui import QWheelEventclass CustomGraphicsView(QGraphicsView):def __init__(self, scene):super().__init__(scene)def wheelEvent(self, event: QWheelEvent):"""鼠标滚轮缩放画布"""zoom_factor = 1.15if event.angleDelta().y() > 0:self.scale(zoom_factor, zoom_factor)  # 放大else:self.scale(1 / zoom_factor, 1 / zoom_factor)  # 缩小class MainWindow(QMainWindow):def __init__(self):super().__init__()self.setWindowTitle("画布缩放和平移")self.setGeometry(100, 100, 800, 600)# 创建场景和自定义视图self.scene = QGraphicsScene()self.view = CustomGraphicsView(self.scene)self.setCentralWidget(self.view)# 添加一个矩形rect = QGraphicsRectItem(0, 0, 100, 100)rect.setBrush(Qt.GlobalColor.blue)rect.setFlag(QGraphicsRectItem.GraphicsItemFlag.ItemIsMovable)self.scene.addItem(rect)# 创建应用程序
app = QApplication(sys.argv)
window = MainWindow()
window.show()
sys.exit(app.exec())

运行结果:

  • 用户可以用鼠标滚轮缩放画布。
  • 元素依然可以拖拽,画布整体可缩放。
    在这里插入图片描述

下一步计划

现在已经完成了:

  1. 拖拽组件到画布。
  2. 工具箱功能。
  3. 画布缩放和平移。

接下来,将学习如何 实现连线功能,用于连接画布上的不同组件(类似 Visio 的箭头连接功能)。


http://www.ppmy.cn/embedded/148735.html

相关文章

讲PPT 需要注意的事项

目录 1-逐字稿多少字? 2-在整个过程中要有学生上台展示的环节。(对于讲课适用) 3-多演练两遍,需要提前谋划好,走2-3遍,把时间卡好 4-PPT上的文字颜色要加强 5-PPT上的字号 6-逐字稿 1-逐字稿多少字&am…

Linux复习1——导论

世界三大操作系统:Windows、UNIX、Linux UNIX简洁、开放、可移植、价格高昂、闭源 Linux继承UNIX的优点、免费、开源 Linux的诞生:1991年,芬兰的一名大学生Linus Torvalds开发了linux内核 #开源的优点: 低风险:开…

数据结构经典算法总复习(上卷)

第一章&#xff1a;数据结构导论 无重要考点&#xff0c;仅需了解时间复杂度。 第二章&#xff1a;线性表 1.获得线性表第i个元素 void GetElem_sq(SqList L, int i, ElemType &e) {if (i<1 || i>L.length) ErrorMsg("Invalid i value"); //注意错误监…

android sqlite 数据库简单封装示例(java)

sqlite 数据库简单封装示例&#xff0c;使用记事本数据库表进行示例。 首先继承SQLiteOpenHelper 使用sql语句进行创建一张表。 public class noteDBHelper extends SQLiteOpenHelper {public noteDBHelper(Context context, String name, SQLiteDatabase.CursorFactory fact…

hpe服务器更新阵列卡firmware

背景 操作系统&#xff1a;RHEL7.8 hpe服务器经常出现硬盘断开&#xff0c;阵列卡重启问题&#xff0c;导致系统hang住。只能手动硬重启。 I/O error&#xff0c;dev sda smartpqi 0000:5c:00:0: resettiong scsi 1:1:0:1 smartpqi 0000:5c:00:0: reset of scsi 1:1:0:1:…

【数据结构】数据结构整体大纲

数据结构用来干什么的&#xff1f;很简单&#xff0c;存数据用的。 &#xff08;这篇文章仅介绍数据结构的大纲&#xff0c;详细讲解放在后面的每一个章节中&#xff0c;逐个击破&#xff09; 那为什么不直接使用数组、集合来存储呢 ——> 如果有成千上亿条数据呢&#xff…

flutter小tip—— initState 和 build(一)

在 Flutter 开发中&#xff0c;有很多最佳实践和开发建议可以帮助你提高代码的质量、性能和可维护性。以下是一些常见的开发建议 1. 避免在 build 方法中执行耗时操作 问题&#xff1a;build 方法会在每次状态更新&#xff08;setState&#xff09;时被调用&#xff0c;如果里…

黑盒RCE测试 异或测试

前言 了解了漏洞的原理之后就需要知道 他在哪能出现 并且被利用 这个还是很重要的 异或测试 使用异或&#xff08;XOR&#xff09;运算进行加密解密的原理_异或加密-CSDN博客 异或测试是在 白盒内执行的 一个例题看一下 输入什么都是会报错 这种情况就需要使用 异或计…