自定义switch实现以下两种方式

总体的xml

 

图1

 

图2

<Switch
    android:id="@+id/switc_time_type"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentRight="true"
    android:layout_centerVertical="true"
    android:layout_marginRight="@dimen/dp_15"
    android:background="@null"
    android:checked="true"
    android:thumb="@drawable/switch_selector_green"
    android:track="@drawable/switch_white_circle_selector" />

其中android:track是轨道, android:thumb是滑块,都在drawable中创建

switch_selector_green.xml:  滑块

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:drawable="@drawable/switch_white_circle_selected" android:state_checked="true"/>
    <item android:drawable="@drawable/switch_white_circle_normal" android:state_checked="false"/>

</selector>

switch_white_circle_selected.xml:选中的样式

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">

    <stroke android:color="#4CD579" android:width="2dp"/>

    <solid android:color="@color/white" />

    <size  android:width="20dp"
        android:height="20dp"/>

</shape>

switch_white_circle_normal.xml :未选中样式

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="oval">

    <stroke android:color="@color/white" android:width="2dp"/>

    <solid android:color="#AFBCC8" />

    <size  android:width="20dp"
        android:height="20dp"/>

</shape>

switch_white_circle_selector.xml  :轨道

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">

    <item android:drawable="@drawable/switch_bg_selected" android:state_checked="true"/>
    <item android:drawable="@drawable/switch_bg_normal" android:state_checked="false"/>

</selector>

switch_bg_selected.xml :选中时轨道样式

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">

    <solid android:color="#ff3985ff"/>
<!--    <size  android:width="42dp"-->
<!--        android:height="20dp"/>-->    此处放开,下面的stoke注释掉效果为图2效果反之为图1
    <stroke
        android:width="8dp"
        android:color="#00000000" />
    <corners android:radius="20dp"/>

</shape>

switch_bg_normal.xml :未选中是轨道样式

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">

    <solid android:color="#ffe7ecf4"/>
    <stroke
        android:width="8dp"
        android:color="#00000000" />
<!--    <size  android:width="42dp"-->
<!--        android:height="20dp"/>-->
    <corners android:radius="20dp"/>

</shape>

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Qt制作滑动开关的方式有多种,以下是其中的两种举例: 1. 使用QSlider和QCheckBox组合实现滑动开关 可以通过将QSlider的valueChanged信号与QCheckBox的setChecked槽函数连接,实现拖动QSlider时,QCheckBox的选中状态发生改变,从而达到滑动开关的效果。具体实现代码如下: ```cpp // 创建QSlider和QCheckBox对象 QSlider *slider = new QSlider(Qt::Horizontal); QCheckBox *checkBox = new QCheckBox("Switch"); // 将QSlider的valueChanged信号与QCheckBox的setChecked槽函数连接 connect(slider, &QSlider::valueChanged, checkBox, &QCheckBox::setChecked); // 将QSlider和QCheckBox添加到布局中 QHBoxLayout *layout = new QHBoxLayout; layout->addWidget(slider); layout->addWidget(checkBox); // 设置窗口布局 QWidget *widget = new QWidget; widget->setLayout(layout); setCentralWidget(widget); ``` 2. 自定义QWidget实现滑动开关 可以创建一个自定义QWidget,通过绘制背景、滑块和文字等元素,实现滑动开关的效果。具体实现代码如下: ```cpp class SwitchWidget : public QWidget { public: SwitchWidget(QWidget *parent = nullptr) : QWidget(parent) { setFixedSize(60, 30); m_checked = false; } void setChecked(bool checked) { m_checked = checked; update(); } protected: void paintEvent(QPaintEvent *) override { QPainter painter(this); // 绘制背景 painter.setPen(Qt::NoPen); painter.setBrush(QColor(200, 200, 200)); painter.drawRoundedRect(rect(), 15, 15); // 绘制滑块 painter.setBrush(m_checked ? QColor(100, 200, 100) : QColor(200, 100, 100)); painter.drawEllipse(QRect(5 + m_checked * 30, 5, 20, 20)); // 绘制文字 painter.setPen(Qt::white); painter.setFont(QFont("Arial", 8)); painter.drawText(QRect(0, 0, 60, 30), Qt::AlignCenter, m_checked ? "ON" : "OFF"); } void mousePressEvent(QMouseEvent *) override { m_checked = !m_checked; update(); } private: bool m_checked; }; // 创建SwitchWidget对象并添加到布局中 SwitchWidget *switchWidget = new SwitchWidget; QHBoxLayout *layout = new QHBoxLayout; layout->addWidget(switchWidget); // 设置窗口布局 QWidget *widget = new QWidget; widget->setLayout(layout); setCentralWidget(widget); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qq_41620230

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值