以下是一个使用Qt实现橡皮擦功能的完整示例:
#include <QApplication>
#include <QWidget>
#include <QPainter>
#include <QMouseEvent>
class Whiteboard : public QWidget {
public:
Whiteboard(QWidget *parent = nullptr) : QWidget(parent), drawing(false), erasing(false) {
setMouseTracking(true); // 接收鼠标移动事件
setFocusPolicy(Qt::StrongFocus); // 接收键盘焦点
}
protected:
void mousePressEvent(QMouseEvent* event) override {
if (event->button() == Qt::LeftButton && !erasing) {
startPoint = event->pos(); // 记录起始点
drawing = true; // 开启绘制模式
} else if (event->button() == Qt::RightButton && !drawing) {
erasing = true; // 开启橡皮擦模式
erasePoint(event->pos()); // 擦除当前位置的图形
}
}
void mouseReleaseEvent(QMouseEvent* event) override {
if (event->button() == Qt::LeftButton && drawing) {
endPoint = event->pos(); // 记录结束点
drawing = false; // 关闭绘制模式
drawLine(startPoint, endPoint); // 绘制线条
} else if (event->button() == Qt::RightButton && erasing) {
erasing = false; // 关闭橡皮擦模式
}
}
void mouseMoveEvent(QMouseEvent* event) override {
if (drawing) {
endPoint = event->pos(); // 实时更新结束点的位置
update(); // 刷新窗口,触发重绘事件
} else if (erasing) {
erasePoint(event->pos()); // 擦除当前位置的图形
}
}
void paintEvent(QPaintEvent*) override {
QPainter painter(this);
painter.drawLines(lines); // 绘制所有线条
}
void drawLine(const QPoint& start, const QPoint& end) {
lines.append(QLine(start, end)); // 添加线条到列表中
update(); // 刷新窗口,触发重绘事件
}
void erasePoint(const QPoint& point) {
for (int i = 0; i < lines.size(); ++i) {
if (lines[i].intersects(QRect(point - QPoint(5, 5), QSize(10, 10)))) {
lines.removeAt(i); // 移除与鼠标位置相交的线条
--i;
}
}
update(); // 刷新窗口,触发重绘事件
}
private:
bool drawing;
bool erasing;
QPoint startPoint;
QPoint endPoint;
QVector<QLine> lines;
};
int main(int argc, char *argv[]) {
QApplication app(argc, argv);
Whiteboard whiteboard;
whiteboard.show();
return app.exec();
}
上述代码中,在Whiteboard
类中添加了橡皮擦相关的逻辑。通过按下鼠标右键来启用橡皮擦模式,并在移动鼠标时调用erasePoint()
方法来擦除与鼠标位置相交的图形。
希望这个示例能满足您的需求!如果还有其他问题,请随时提问。
内容由零声教学AI助手提供,问题来源于学员提问