案例-旋转中心点案例

2 篇文章 0 订阅
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        div{
            width: 200px;
            height: 200px;
            border:1px solid #8669ae;
            margin:100px auto;
            overflow: hidden; /*看不见*/
        }
        div::after{
            content: "黑马";
            display: block;
            width: 100%;
            height: 100%;
            background-color: rosybrown;
            transform: rotate(180deg) ;
            transform-origin: left bottom;
            transition: all .5s;
        }
        div:hover::after{
            transform: rotate(0deg);
        }
    </style>
</head>
<body>
<div></div>
</body>
</html>

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 以下是一个简单的Qt自定义旋钮案例: 1. 创建一个新的Qt Widgets项目。 2. 在Qt设计师中添加一个QDial小部件。 3. 在QDial的属性编辑器中,将wrapping和notchesVisible属性设置为true。 4. 在项目文件夹中创建一个名为dial.h的新头文件,并添加以下内容: ``` #ifndef DIAL_H #define DIAL_H #include <QDial> class Dial : public QDial { Q_OBJECT public: explicit Dial(QWidget *parent = nullptr); protected: void paintEvent(QPaintEvent *event) override; }; #endif // DIAL_H ``` 5. 在dial.cpp文件中实现paintEvent函数: ``` #include "dial.h" #include <QPainter> Dial::Dial(QWidget *parent) : QDial(parent) { setMinimum(0); setMaximum(360); } void Dial::paintEvent(QPaintEvent *event) { Q_UNUSED(event); QPainter painter(this); painter.setRenderHint(QPainter::Antialiasing, true); painter.translate(width() / 2, height() / 2); painter.scale(width() / 200.0, height() / 200.0); painter.setPen(QPen(QColor(255, 255, 255), 2)); for (int i = 0; i < 360; i += 10) { painter.drawLine(0, -90, 0, -100); painter.rotate(10); } painter.setPen(QPen(QColor(255, 0, 0), 4)); painter.drawLine(0, 0, 0, -80); painter.rotate(value()); painter.drawLine(0, 0, 0, -60); } ``` 6. 在Qt设计师中将QDial小部件替换为自定义的Dial小部件。 7. 运行程序,你将看到一个带有旋钮指针的自定义旋钮。 这个例子中,我们继承了QDial类并重写了paintEvent函数来自定义旋钮的绘制。我们使用QPainter类来绘制刻度线和旋钮指针。我们还通过设置wrapping属性来允许旋钮无限旋转,并且设置notchesVisible属性来显示刻度线。 ### 回答2: 在Qt中实现自定义旋钮的案例,可以按照以下步骤进行: 1. 创建一个继承自QAbstractSlider的自定义旋钮类,命名为CustomDial。 2. 在CustomDial类的构造函数中,设置旋钮的默认值和范围,并初始化旋钮的样式。 3. 重写CustomDial类的paintEvent函数,用于绘制旋钮的外观。可以使用Qt的绘图函数来绘制一个圆形旋钮,以及表示旋钮当前值的指针。 4. 重写CustomDial类的mousePressEvent和mouseMoveEvent函数,用于捕捉鼠标事件并实现旋钮的交互。在mousePressEvent函数中,计算鼠标点击点相对于旋钮中心点的角度,并将当前值更新为对应角度所处的范围。在mouseMoveEvent函数中,根据鼠标移动的位置计算旋钮指针的角度,并更新旋钮的当前值。 5. 在主窗口中,创建一个CustomDial对象的实例,并将其布局到合适位置。可以使用QVBoxLayout或QHBoxLayout等布局管理器进行布局。 6. 在主窗口中,连接CustomDial对象的valueChanged信号到一个槽函数,用于获取旋钮的当前值并进行相应的处理。 通过以上步骤,我们可以实现一个基本的自定义旋钮控件。根据具体的需求,可以进一步添加其他功能,例如旋钮的刻度显示、数值精度控制等。同时,也可以根据需要进行样式的自定义,使旋钮更符合应用程序的整体风格。 ### 回答3: 在Qt中实现自定义旋钮可以使用QSlider和QDial两个控件进行结合来实现。具体步骤如下: 1. 创建一个继承自QDial的自定义旋钮控件Knob,并在构造函数中设置一些旋钮的基本属性,如最小值、最大值、初始值等。 2. 重写Knob的paintEvent函数,通过QPainter绘制出旋钮的外观样式。可以使用QPainter的drawArc、drawText等函数绘制旋钮的底部圆环、刻度值等。 3. 为Knob添加一个QSlider作为旋钮的指针,并设置指针的起始位置和角度等属性。可以使用QSlider的setStyleSheet函数为指针设置样式。 4. 在Knob中重新实现QSlider和QDial的一些事件处理函数,通过这些函数实现旋钮的旋转控制。例如,重写mousePressEvent和mouseMoveEvent函数,根据鼠标拖动的位置计算出旋钮目标角度,并通过QSlider的setValue函数来设置指针的位置。 5. 将Knob添加到主窗口中,设置其位置和大小等属性,就可以在界面上显示出自定义的旋钮了。 通过以上步骤,我们可以实现一个自定义的旋钮控件,并在Qt的界面中使用它来实现一些旋钮调节数值的功能。可以根据具体需求,调整旋钮的外观样式和功能细节。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值