当前位置: 首页 > news >正文

c++qt

1.显示画布

#include "code.h"
#include <QtWidgets/QApplication>
#include<iostream>
#include<vector>
#include <QWindow>
#include <QGraphicsView>
#include <QGraphicsScene>using namespace std;//1.空格  2.墙  3.入口  4.终点  5.双入口
/*
1.入口
2.出口
3.出入口
4.下一个任务迷宫
5.没有障碍
6 有障碍
7.玩家位置
*/class Maze {
public:int row, col;//迷宫的行数和列数int layer;//所属层Maze();
};Maze::Maze() {this->row = row;this->col = col;
}class MazeManager { //迷宫管理器
public:int row;//玩家位置int col;//玩家位置MazeManager();vector<Maze> mazes; //存储多个迷宫
};MazeManager::MazeManager() {}class Canvas : public QGraphicsView {
public:Canvas(QWidget* parent = nullptr);private:QGraphicsScene* scene;
};class MainWindow : public QMainWindow
{
public:MainWindow(QWidget* parent = nullptr);void cnavasInit();Canvas* canvas; // 指向 Canvas 的指针
};void MainWindow::cnavasInit() {canvas = new Canvas(this); // 创建 Canvas 对象canvas->setGeometry(50, 50, 800, 800); //     // 设置 Canvas 的绝对位置和大小canvas->show();}Canvas::Canvas(QWidget* parent): QGraphicsView(parent), scene(new QGraphicsScene(this)) {// 设置背景颜色为白色setBackgroundBrush(Qt::white);// 设置场景setScene(scene);setRenderHint(QPainter::Antialiasing); // 开启抗锯齿setSceneRect(0, 0, 800*2, 800*2); // 设置场景大小// 添加一些图形项到场景scene->addRect(50, 50, 200, 100, QPen(Qt::blue), QBrush(Qt::cyan)); // 矩形scene->addEllipse(300, 50, 100, 100, QPen(Qt::red), QBrush(Qt::yellow)); // 椭圆scene->addLine(50, 200, 300, 200, QPen(Qt::green)); // 线条
}MainWindow::MainWindow(QWidget* parent): QMainWindow(parent)
{// 设置主窗口标题setWindowTitle("迷宫");this->resize(1600, 900);
}int main(int argc, char *argv[])
{QApplication a(argc, argv);MainWindow* mainWindow = new MainWindow();mainWindow->cnavasInit(); //显示画布mainWindow->show();return a.exec();
}

2.按钮函数

QString getStyle(int r,int g,int b) {QString styleSheet = QString("QPushButton {""background-color: rgb(%1, %2, %3);""color: black;" // 设置字体颜色为白色"font-weight: bold;" // 设置字体加粗"border: 1px solid black;" // 设置黑色边框,宽度为2像素"border-radius: 8px;" // 设置圆角边框,半径为8像素"}""QPushButton:hover {""background-color: rgb(128, 0, 128);" // 鼠标悬停时为紫色"}""QPushButton:pressed {""background-color: rgb(255, 0, 0);" // 鼠标点击时为红色"}").arg(r).arg(g).arg(b);return styleSheet;
}QPushButton* getButton(QWidget* parent, QString message,int r,int g,int b,int x,int y) {QPushButton* button = new QPushButton(message, parent);button->setGeometry(x, y, 100, 40);QFont font("微软雅黑", 12); // 字体名称和大小button->setFont(font);button->setStyleSheet(getStyle(r,g,b));return button;
}
http://www.lryc.cn/news/473532.html

相关文章:

  • 零跑汽车嵌入式面试题汇总及参考答案
  • LC:贪心题解
  • ubuntu交叉编译dbus库给arm平台使用
  • ansible开局配置-openEuler
  • 连锁收银系统的优势与挑战
  • 轻型民用无人驾驶航空器安全操控理论培训知识总结-多旋翼部分
  • springboot092安康旅游网站的设计与实现(论文+源码)_kaic
  • 优化 Git 管理:提升协作效率的最佳实践20241030
  • Cocos使用精灵组件显示相机内容
  • AListFlutter(手机alist)——一键安装,可在手机/电视上运行并挂载各个网盘
  • 2024快手面试算法题-生气传染
  • 组织如何防御日益增加的 API 攻击面
  • 如何防止U盘盗取电脑数据?
  • python爬虫抓取豆瓣数据教程
  • Mybatis 注意传递多种参数,不一定都有参数值,用xml如何写出查询语句
  • 【Windows】Redis 部署
  • 【经典】Vue中this指向问题??
  • Oracle数据泵(expdp)导入导出数据
  • 得物App 3D球鞋博物馆亮相两博会,打造沉浸式消费新体验
  • 深度学习中的迁移学习
  • 【深入浅出】深入浅出Bert(附面试题)
  • Docker-安装
  • 《盼归》
  • 第十九章 Vue组件之data函数
  • 【jvm】什么时候对象进入老年代
  • Vue.nextTick 使用指南:数据更新与 DOM 同步利器
  • 第三百零一节 Lucene教程 - Lucene索引文件
  • 动态规划 01背包(算法)
  • 使用常数指针作为函数参数
  • wps宏代码学习