自定义日历下拉框(Calendar Combo Box),日期选择器——Qt

前言

我难受了,我刚知道QDateEdit自带下拉框,而且还是在好心网友的提醒下,我抑郁了。但是我已经写了自定义了,就这样吧,其实自定义也没多复杂,当然,自带的超级简单。

代码及说明

官方自带的

要想QDateEdit(或QDateTimeEdit)为弹出日历的形式,则需要先设置setCalendarPopup(true),必须要先设置这个;然后将自定义的日历进行设置(setCalendarWidget(pCalendar))。

我发现一点就是这个不能设置只读模式(我只是想去掉光标,禁止键盘编辑),这样就是丧失了按钮的使能,所以怎么去掉这个光标呢,等待下一个大佬告诉我!!

日历MyCalendarWidget这部分,我已经在上一篇博客中介绍过了,这里就不再说了。

    ui->dateEdit->setCalendarPopup(true); //必须先设置这个
    MyCalendarWidget* pCalendar=new MyCalendarWidget;
    pCalendar->setFixedSize(248,200);
    pCalendar->initStyle(false);
    ui->dateEdit->setCalendarWidget(pCalendar);
    ui->dateEdit->setDate(QDate::currentDate());
    ui->dateEdit->setDisplayFormat("MM月dd日 ddd");
  

自定义的(就当我写着玩吧,给留一丝尊严)

那么,关于日历下拉这个效果怎么实现?我继承了QLineEdit,然后在里面加了一个按钮,控制日历的显示。为了让日历响应点击其他区域关闭的效果,我选择了用QMenu把日历QCalendarWidget包起来。

具体代码有:

#include<QLineEdit>
#include<QMenu>
#include<QToolButton>
#include"MyCalendarWidget.h"

class MyCalendarCombo:public QLineEdit
{
    Q_OBJECT
public:
    explicit MyCalendarCombo(QWidget *parent = Q_NULLPTR);
    ~MyCalendarCombo();

private slots:
    void showCalendar();
    void showDateText(const QDate &date);  
protected:
    void resizeEvent(QResizeEvent *event); //大小变化时,调整按钮的位置

private:
    QToolButton* m_pCalendarBtn;
    QMenu* m_pContextMenu;
    MyCalendarWidget *m_pCalendarWidget;


};
#include "MyCalendarCombo.h"
#include<QWidgetAction>
#include<QDebug>

#define BTN_Len 10
#define BTN_Margin 6

MyCalendarCombo::MyCalendarCombo(QWidget *parent):
    QLineEdit(parent)
{
    this->setReadOnly(true);

    m_pCalendarBtn=new QToolButton(this);

    m_pCalendarWidget=new MyCalendarWidget(this);
    m_pCalendarWidget->initStyle(false);
    m_pCalendarWidget->setFixedSize(248,200);
    connect(m_pCalendarWidget,&MyCalendarWidget::clicked,this,&MyCalendarCombo::showDateText);

    QWidgetAction* wAction=new QWidgetAction(this);
    wAction->setDefaultWidget(m_pCalendarWidget);

    m_pContextMenu=new QMenu(this);
    m_pContextMenu->setWindowFlag(Qt::NoDropShadowWindowHint);
    m_pContextMenu->addAction(wAction);
    connect(m_pCalendarBtn,SIGNAL(clicked(bool)),this,SLOT(showCalendar()));

    QDate date=m_pCalendarWidget->selectedDate();
    this->setText(date.toString("MM月dd日 ddd"));


}

MyCalendarCombo::~MyCalendarCombo()
{

}

void MyCalendarCombo::showCalendar()
{
    int x=this->x();
    int y=this->y()+this->height();
    QWidget* parentWidget=qobject_cast<QWidget*>(parent());
    QPoint pt=parentWidget->mapToGlobal(QPoint(x,y));
    m_pContextMenu->exec(pt);
}

void MyCalendarCombo::showDateText(const QDate& date)
{
    this->setText(date.toString("MM月dd日 ddd"));
    m_pContextMenu->close();
}

void MyCalendarCombo::resizeEvent(QResizeEvent *event)
{
    int x=this->width()-BTN_Len-BTN_Margin;
    int y=this->height()/2-BTN_Len/2;
    m_pCalendarBtn->setGeometry(x,y,BTN_Len,BTN_Len);
    //防止文本框输入内容位于按钮之下
    QMargins margins = this->textMargins();
    this->setTextMargins(margins.left(), margins.top(), margins.right()-BTN_Len-BTN_Margin, margins.bottom());
}

效果图

结束语

谢谢评论大佬的指点,这里祝你七夕节快乐,笔芯❥(^_-)

  • 8
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
//自定义日历可看上篇文章 QCalendarTimeEdit::QCalendarTimeEdit(QWidget *parent) : QLineEdit(parent) , m_calendarWidget(nullptr) , m_widget(nullptr) { m_minDateTime = QDateTime::currentDateTime(); { QTime maxtime; maxtime.setHMS(23, 59, 59); m_maxDateTime.setTime(maxtime); m_maxDateTime.setDate(QDate::currentDate().addDays(365)); } setContextMenuPolicy(Qt::NoContextMenu); } QCalendarTimeEdit::~QCalendarTimeEdit() { if (m_widget) { delete m_widget; m_widget = nullptr; } } void QCalendarTimeEdit::initControlcalendar() { m_widget = new BackPaintWidget(nullptr); m_widget->setObjectName("calendarFramWidget"); loadStyleSheet(m_widget, "CalendarWidget"); m_widget->setAttribute(Qt::WA_TranslucentBackground); m_widget->setWindowFlags(Qt::WindowStaysOnTopHint | Qt::FramelessWindowHint | Qt::SubWindow); QHBoxLayout* layout = new QHBoxLayout; layout->setMargin(8); layout->setSpacing(0); m_calendarWidget = new QCustomCalendarTimeWidget(m_widget); m_widget->setCalendarTimeWidget(m_calendarWidget); m_calendarWidget->setCalendarMinDate(m_minDateTime); m_calendarWidget->setCalendarMaxDate(m_maxDateTime); //m_calendarWidget->disconnect(SIGNAL(selectionChanged())); //m_calendarWidget->disconnect(SIGNAL(clicked(QDate))); layout->addWidget(m_calendarWidget); m_widget->setLayout(layout); connect(m_calendarWidget, &QCustomCalendarTimeWidget;::signalSetCalendarTime, [this](const QDateTime& date){ setText(date.toString("yyyy-MM-dd hh:mm:ss")); hideCalendarTimeWidget(); }); connect(m_calendarWidget, &QCustomCalendarTimeWidget;::signalClearDateTime, [this](){ clear(); hideCalendarTimeWidget(); }); hideCalendarTimeWidget(); } void QCalendarTimeEdit::setCalendarMinDate(const QDateTime &datetime;) { m_minDateTime = datetime; if (m_calendarWidget) { m_calendarWidget->setCalendarMinDate(m_minDateTime); } } void QCalendarTimeEdit::setCalendarMaxDate(const QDateTime &datetime;) { m_maxDateTime = datetime; if (m_calendarWidget) { m_calendarWidget->setCalendarMaxDate(m_maxDateTime); } } void QCalendarTimeEdit::popCalendarTimeWidget() { if (m_calendarWidget == nullptr) { initControlcalendar(); } QRect rect = qApp->desktop()->availableGeometry(0); QPoint gloadPos = mapToGlobal(QPoint(-8, this->height())); if (gloadPos.y() + m_calendarWidget->height() > rect.height()) { int y = gloadPos.y() - this->height() - m_calendarWidget->height(); gloadPos.setY(y); } m_widget->move(gloadPos); m_widget->show(); } void QCalendarTimeEdit::hideCalendarTimeWidget() { m_widget->hide(); } void QCalendarTimeEdit::mousePressEvent(QMouseEvent *event) { __super::mousePressEvent(event); if (event->button() == Qt::LeftButton) { popCalendarTimeWidget(); } } void QCalendarTimeEdit::keyPressEvent(QKeyEvent *event) { Q_UNUSED(event); }
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值