[Qt学习笔记]Qt实现鼠标点击或移动时改变鼠标的样式以及自定义鼠标样式

1、鼠标样式介绍以及对应函数

在Qt中大概有20种左右的内置鼠标样式,一般使用setCursor(Qt::CursorShape shape)来进行设置,一般常用的有标准箭头、手型,双箭头等等形状,对于不同的操作系统下,鼠标的样式显示会略有差别,Qt内置的鼠标样式(CursorShape)如下:
鼠标样式.png

2、在鼠标事件中调用鼠标样式设置函数

 this->setMouseTracking(true);      //设置为不按下鼠标键触发moveEvent
 void mouseMoveEvent(QMouseEvent* event)
 {
     QPoint mousepos = event()->pos();
 
     //在坐标(0 ~ width,0 ~ height)范围内改变鼠标形状
     if(mousepos.rx() > 0 
        && mousepos.rx() < width
        && mousepos.ry() > 0
        && mousepos.ry() < height)
     {
            this->setCursor(Qt::CrossCursor);
     }
     else
     {
         this->setCursor(Qt::ArrowCursor);      //范围之外变回原来形状
     }
 }

这里通过setMouseTracking(true);这个函数来进行鼠标的跟随操作,当鼠标移动事件触发后判断进行鼠标样式的更改。

3、使用图片自定义鼠标样式

使用函数QCursor::QCursor(const QBitmap & bitmap, const QBitmap & mask, int hotX = -1, int hotY = -1),需要准备自定义鼠标样式的图片和自定义鼠标样式的掩码图片,hotX和hotY设置鼠标热点。甚至可以生成与背景具有反差效果的鼠标样式。该函数详细使用说明如下:
图片设定鼠标样式

CustomCursor::CustomCursor(QWidget *parent)
	: QMainWindow(parent)
{
	ui.setupUi(this);

	QBitmap bitmap("bitmap.png"); //背景透明的png格式图片
	QBitmap bitmap_mask("bitmap_mask.png");

	QCursor cursor(bitmap, bitmap_mask, -1, -1); //-1 -1表示鼠标热点在中心点
	setCursor(cursor); //设置自定义的鼠标样式
}

相关推荐

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-03-21 12:28:07       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-03-21 12:28:07       101 阅读
  3. 在Django里面运行非项目文件

    2024-03-21 12:28:07       82 阅读
  4. Python语言-面向对象

    2024-03-21 12:28:07       91 阅读

热门阅读

  1. OkHttp

    OkHttp

    2024-03-21 12:28:07      43 阅读
  2. git仓库拉取代码

    2024-03-21 12:28:07       41 阅读
  3. 蓝桥杯第14届模拟赛最大连通分块(dfs)

    2024-03-21 12:28:07       38 阅读
  4. 后端使用前端页面的很好的推荐Layui

    2024-03-21 12:28:07       38 阅读
  5. Github 2024-03-20 开源项目日报 Top10

    2024-03-21 12:28:07       42 阅读
  6. 前端学习资源整合

    2024-03-21 12:28:07       40 阅读