iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Qt如何编写自定义控件实现抽奖转盘
  • 805
分享到

Qt如何编写自定义控件实现抽奖转盘

2023-07-02 09:07:28 805人浏览 泡泡鱼
摘要

本文小编为大家详细介绍“Qt如何编写自定义控件实现抽奖转盘”,内容详细,步骤清晰,细节处理妥当,希望这篇“Qt如何编写自定义控件实现抽奖转盘”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。具体代码如下#ifndef

本文小编为大家详细介绍“Qt如何编写自定义控件实现抽奖转盘”,内容详细,步骤清晰,细节处理妥当,希望这篇“Qt如何编写自定义控件实现抽奖转盘”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

具体代码如下

#ifndef LOTTERYTURNTABLEWIDGET_H#define LOTTERYTURNTABLEWIDGET_H #include <QWidget> class LotteryTurntableWidget : public QWidget{    Q_OBJECT    Q_PROPERTY(int rotate READ getRotate WRITE setRotate MEMBER painterRotate)public:    LotteryTurntableWidget(QWidget *parent = nullptr);    ~LotteryTurntableWidget()override;    int getRotate();    void setRotate(int rotate); protected:    void paintEvent(QPaintEvent *event)override;    void mousePressEvent(QMouseEvent *event)override;    void mouseReleaseEvent(QMouseEvent *event)override; private:    QRect centerBtnRect;    bool isPressCenterBtn{false};    bool isRuning{false};    int painterRotate{0};    void onRotateFinished();    QList<Qt::GlobalColor> colorList;};#endif // LOTTERYTURNTABLEWIDGET_H
#include "lotteryturntablewidget.h"#include <QPainter>#include <QPaintEvent>#include <QPainterPath>#include <QTime>#include <QDebug>#include <QRandomGenerator>#include <QPropertyAnimation> LotteryTurntableWidget::LotteryTurntableWidget(QWidget *parent)    : QWidget(parent){    setPalette(Qt::white);    setMinimumSize(500,500);     colorList << Qt::red << Qt::yellow << Qt::green << Qt::cyan << Qt::blue << Qt::magenta << Qt::darkGreen << Qt::darkCyan;} LotteryTurntableWidget::~LotteryTurntableWidget(){} int LotteryTurntableWidget::getRotate(){    return painterRotate;} void LotteryTurntableWidget::setRotate(int rotate){    painterRotate = rotate;    update();} void LotteryTurntableWidget::paintEvent(QPaintEvent *event){    QPainter painter(this);    painter.setRenderHint(QPainter::Antialiasing,true);  //反走样开启    const auto rect = event->rect();    auto radius = std::min(rect.width(),rect.height()) / 2 - 25;     painter.save();    painter.translate(rect.center()); //将坐标系的原点设置为(r,r)     QPen pen;    pen.setColor(QColor("#F0630B"));    pen.setWidth(16);    painter.setPen(pen);    painter.drawEllipse(QPoint(0, 0), radius, radius);     pen.setColor(QColor("#FF4500"));    pen.setWidth(8);    painter.setPen(pen);    radius -= 8;    painter.drawEllipse(QPoint(0, 0), radius, radius);     pen.setColor(QColor("#B71606"));    pen.setWidth(40);    painter.setPen(pen);    radius -= 24;    painter.drawEllipse(QPoint(0, 0), radius, radius);     painter.save();    if(!isRuning)    {        painter.setPen(Qt::white);        painter.setBrush(Qt::white);    }    for (int i = 0; i < 20; ++i)    {        painter.rotate(18.0);        int smallEllipse;        if(i % 2 == 0)        {            if(isRuning)            {                if(painterRotate % 2 == 0)                {                    painter.setPen(Qt::red);                    painter.setBrush(Qt::red);                }                else                {                    painter.setPen(Qt::blue);                    painter.setBrush(Qt::blue);                }            }            smallEllipse = 15;        }        else        {            if(isRuning)            {                if(painterRotate % 2 == 0)                {                    painter.setPen(Qt::blue);                    painter.setBrush(Qt::blue);                }                else                {                    painter.setPen(Qt::red);                    painter.setBrush(Qt::red);                }            }            smallEllipse = 10;        }        painter.drawEllipse(QPoint(radius, 0), smallEllipse, smallEllipse);    }    painter.restore();     pen.setColor(QColor("#FFC228"));    pen.setWidth(20);    painter.setPen(pen);    radius -= 30;    painter.drawEllipse(QPoint(0, 0), radius, radius);     radius -= 10;    auto centerRect = QRect(-radius,-radius,radius * 2,radius * 2);     painter.setPen(Qt::transparent);    painter.save();    painter.rotate(18.0 * painterRotate);    for (int i = 0;i < 8;++i)    {        QPainterPath path;        path.moveTo(0,0);        path.arcTo(centerRect, 45 * i,45);        path.closeSubpath();        painter.fillPath(path,colorList[i]);    }        painter.restore();     QPainterPath trianglePath;//三角形    QPolyGon polygon;    polygon.append(QPoint(0,-radius * 0.55));    polygon.append(QPoint(-radius * 0.25,0));    polygon.append(QPoint(radius * 0.25,0));    trianglePath.addPolygon(polygon);    painter.setBrush(QColor("#EEDAA2"));    painter.drawPath(trianglePath);     painter.setBrush(QColor("#FDFAEA"));    radius = static_cast<int>(radius * 0.3);    painter.drawEllipse(QPoint(0, 0), radius, radius);     painter.setBrush(isPressCenterBtn ? QColor("#B91A0D").lighter() : QColor("#B91A0D"));//中间的按钮    radius -= 2;    painter.drawEllipse(QPoint(0, 0), radius, radius);     centerBtnRect = QRect(rect.width() / 2 - radius,rect.height() / 2 - radius,radius * 2,radius * 2);    painter.restore();} void LotteryTurntableWidget::mousePressEvent(QMouseEvent *event){    if(isRuning)    {        QWidget::mousePressEvent(event);        return;    }    QRegion ellipseRegion(centerBtnRect, QRegion::Ellipse);    isPressCenterBtn = ellipseRegion.contains(event->pos());    if(isPressCenterBtn)    {        isRuning = true;         QPropertyAnimation *animation = new QPropertyAnimation(this, "rotate");        animation->setEasinGCurve(QEasingCurve::InOutCubic);        animation->setDuration(3000);        animation->setStartValue(0);        animation->setEndValue(QRandomGenerator::global()->bounded(360) + 360 * 5);        connect(animation, &QAbstractAnimation::finished, this, &LotteryTurntableWidget::onRotateFinished);        animation->start(QAbstractAnimation::DeleteWhenStopped);        update();    }    QWidget::mousePressEvent(event);} void LotteryTurntableWidget::mouseReleaseEvent(QMouseEvent *event){    if(isPressCenterBtn)    {        isPressCenterBtn = false;        update();    }    QWidget::mouseReleaseEvent(event);} void LotteryTurntableWidget::onRotateFinished(){    isRuning = false;}

效果:

Qt如何编写自定义控件实现抽奖转盘

读到这里,这篇“Qt如何编写自定义控件实现抽奖转盘”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: Qt如何编写自定义控件实现抽奖转盘

本文链接: https://www.lsjlt.com/news/340879.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Qt编写自定义控件实现抽奖转盘
    本文实例为大家分享了Qt自定义控件实现抽奖转盘的具体代码,供大家参考,具体内容如下 #ifndef LOTTERYTURNTABLEWIDGET_H #define LOTTERYT...
    99+
    2024-04-02
  • Qt如何编写自定义控件实现抽奖转盘
    本文小编为大家详细介绍“Qt如何编写自定义控件实现抽奖转盘”,内容详细,步骤清晰,细节处理妥当,希望这篇“Qt如何编写自定义控件实现抽奖转盘”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。具体代码如下#ifndef...
    99+
    2023-07-02
  • Qt自定义控件实现仪表盘
    目录1.预览图2. 代码头文件源文件3. 用法1.预览图 2. 代码 头文件 #ifndef MOTORMETER_H #define MOTORMETER_H #include...
    99+
    2024-04-02
  • Android自定义View如何实现QQ运动积分转盘抽奖功能
    这篇文章主要讲解了Android自定义View如何实现QQ运动积分转盘抽奖功能,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。因为偶尔关注QQ运动, 看到QQ运动的积分抽奖界面比较有意思,所以就尝试用自定义Vie...
    99+
    2023-05-30
    android view roi
  • 如何实现Jquery转盘抽奖程序
    这篇文章主要介绍了如何实现Jquery转盘抽奖程序,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。基于Jquery的Javascript转盘抽...
    99+
    2024-04-02
  • 如何实现纯CSS3大转盘抽奖
    这篇文章给大家分享的是有关如何实现纯CSS3大转盘抽奖的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。HTML<section class="gb-whe...
    99+
    2024-04-02
  • vue如何实现大转盘抽奖功能
    这篇文章主要为大家展示了“vue如何实现大转盘抽奖功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“vue如何实现大转盘抽奖功能”这篇文章吧。效果图如下中奖提示代码如下<template&...
    99+
    2023-06-29
  • qt如何自定义可拖动控件
    要自定义可拖动的控件,可以按照以下步骤进行操作:1. 创建一个继承自QWidget或QFrame的自定义控件类,例如MyDragga...
    99+
    2023-10-10
    qt
  • 基于Qt实现可拖动自定义控件
    使用QT实现自定义类卡牌控件Card,使其能在父类窗口上使用鼠标进行拖动。 控件类头文件card.h #ifndef CARD_H #define CARD_H #include...
    99+
    2023-05-14
    Qt实现可拖动自定义控件 Qt 自定义控件 Qt控件
  • WPF自定义控件如何实现
    今天小编给大家分享一下WPF自定义控件如何实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。方式一:基于现有控件进行扩展,如...
    99+
    2023-07-05
  • 基于Qt怎么实现可拖动自定义控件
    本篇内容介绍了“基于Qt怎么实现可拖动自定义控件”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!使用QT实现自定义类卡牌控件Card,使其能在...
    99+
    2023-07-05
  • .NET自定义控件应该如何实现
    本篇内容介绍了“.NET自定义控件应该如何实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!.NET自定义控件有很多人其实不太适应去试用,一...
    99+
    2023-06-17
  • Android如何自定义实现日历控件
    这篇文章主要介绍Android如何自定义实现日历控件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下1. Calendar类2. 布局创建calendar_layout.xml<LinearLayou...
    99+
    2023-06-25
  • Qt实现自定义验证码输入框控件的方法
    目录前言UI布局:页面样式初始化:功能实现:前言 本文实现了自定义的验证码输入框控件。控件包括图标、输入框、获取验证码按钮、验证码获取倒计时标签。支持鼠标点击获取验证码按钮后开始显示...
    99+
    2024-04-02
  • Angular如何使用ControlValueAccessor实现自定义表单控件
    这篇文章主要介绍了Angular如何使用ControlValueAccessor实现自定义表单控件,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。本篇文章给大家介绍一下Angu...
    99+
    2023-06-14
  • android自定义控件如何实现简易时间轴
    这篇“android自定义控件如何实现简易时间轴”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“android自定义控件如何实现简易时间轴”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过...
    99+
    2023-06-28
  • Android如何实现一个倒计时自定义控件
    这篇“Android如何实现一个倒计时自定义控件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Android如何实现一个倒计...
    99+
    2023-06-29
  • QT中如何实现自定义quick-Popup弹出窗口
    小编给大家分享一下QT中如何实现自定义quick-Popup弹出窗口,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1.Popup介绍Popup是一个弹出窗口的控件...
    99+
    2023-06-20
  • 学会自己编写Mybatis插件(拦截器)实现自定义需求
    前言 最近在考虑写什么的时,想到自己在项目中使用过的mybatis的插件,就想趁这个机会聊一聊我们接触频繁的Mybatis. 如果是使用过Mybatis的小伙伴,那么我们接触过的第一个Mybatis的插件自然就是分页插件(Mybati...
    99+
    2023-08-31
    mybatis java mysql
  • 如何进行Qt 信号自定义槽函数的实现
    本篇文章为大家展示了如何进行Qt 信号自定义槽函数的实现,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Qt中实现自定义信号与槽函数,信号用于发送并触发槽函数,槽函数则是具体的功能实现,如下...
    99+
    2023-06-21
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作