亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Qt農歷控件如何實現

發布時間:2021-12-15 10:36:55 來源:億速云 閱讀:229 作者:iii 欄目:互聯網科技

這篇文章主要介紹“Qt農歷控件如何實現”,在日常操作中,相信很多人在Qt農歷控件如何實現問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Qt農歷控件如何實現”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

一、前言

農歷控件在國產linux中必備的控件之一,畢竟要適應國人的習慣,你看win10系統的日歷,現在點開來直接就有農歷在上面,非常方便人性化,所以在很多用Qt做的項目中,也有農歷控件的應用場景,而Qt自帶的日歷控件比較簡單,仔細看過源碼的人也只知道,其實就是一堆微調框,下拉框,表格組成的,于是打算借用此方法造一個農歷控件,本控件的算法是倪大俠提供的,個人測試下來還是沒有問題的,造這個農歷控件最大的難點是如何根據日期計算農歷時間,再加上一些農歷的節氣之類的,這個網上估計也有很多的算法參考。

主要功能:

  1. 可設置邊框顏色/周末顏色/角標顏色/農歷節日顏色

  2. 可設置當前月文字顏色/其他月文字顏色/選中日期文字顏色/懸停日期文字顏色

  3. 可設置當前月農歷文字顏色/其他月農歷文字顏色/選中日期農歷文字顏色/懸停日期農歷文字顏色

  4. 可設置當前月背景顏色/其他月背景顏色/選中日期背景顏色/懸停日期背景顏色

  5. 可設置三種選中背景模式,矩形背景+圓形背景+圖片背景

  6. 可直接切換到上一年/下一年/上一月/下一月/轉到今天

  7. 可設置是否顯示農歷信息,不顯示則當做正常的日歷使用

  8. 支持1900年-2099年范圍

  9. 很方便改成多選日期

二、代碼思路

void LunarCalendarItem::paintEvent(QPaintEvent *)
{
    //繪制準備工作,啟用反鋸齒
    QPainter painter(this);
    painter.setRenderHints(QPainter::Antialiasing | QPainter::TextAntialiasing);

    //繪制背景和邊框
    drawBg(&painter);

    //優先繪制選中狀態,其次繪制懸停狀態
    if (select) {
        drawBgCurrent(&painter, selectBgColor);
    } else if (hover) {
        drawBgCurrent(&painter, hoverBgColor);
    }

    //繪制日期
    drawDay(&painter);

    //繪制農歷信息
    drawLunar(&painter);
}

void LunarCalendarItem::drawBg(QPainter *painter)
{
    painter->save();

    //根據當前類型選擇對應的顏色
    QColor bgColor = currentBgColor;
    if (dayType == DayType_MonthPre || dayType == DayType_MonthNext) {
        bgColor = otherBgColor;
    }

    painter->setPen(borderColor);
    painter->setBrush(bgColor);
    painter->drawRect(rect());

    painter->restore();
}

void LunarCalendarItem::drawBgCurrent(QPainter *painter, const QColor &color)
{
    int width = this->width();
    int height = this->height();
    int side = qMin(width, height);

    painter->save();

    painter->setPen(Qt::NoPen);
    painter->setBrush(color);

    //根據設定繪制背景樣式
    if (selectType == SelectType_Rect) {
        painter->drawRect(rect());
    } else if (selectType == SelectType_Circle) {
        int radius = side / 2 - 3;
        painter->drawEllipse(QPointF(width / 2, height / 2), radius, radius);
    } else if (selectType == SelectType_Triangle) {
        int radius = side / 3;
        QPolygon pts;
        pts.setPoints(3, 1, 1, radius, 1, 1, radius);
        painter->drawRect(rect());
        painter->setBrush(superColor);
        painter->drawConvexPolygon(pts);
    } else if (selectType == SelectType_Image) {
        //等比例縮放居中繪制
        QImage img(bgImage);
        if (!img.isNull()) {
            img = img.scaled(this->size(), Qt::KeepAspectRatio, Qt::SmoothTransformation);
            int x = (width - img.width()) / 2;
            int y = (height - img.height()) / 2;
            painter->drawImage(x, y, img);
        }
    }

    painter->restore();
}

void LunarCalendarItem::drawDay(QPainter *painter)
{
    int width = this->width();
    int height = this->height();
    int side = qMin(width, height);

    painter->save();

    //根據當前類型選擇對應的顏色
    QColor color = currentTextColor;
    if (dayType == DayType_MonthPre || dayType == DayType_MonthNext) {
        color = otherTextColor;
    } else if (dayType == DayType_WeekEnd) {
        color = weekColor;
    }

    if (select) {
        color = selectTextColor;
    } else if (hover) {
        color = hoverTextColor;
    }

    painter->setPen(color);

    if (showLunar) {
        QFont font;
        font.setPixelSize(side / 2.7);
        painter->setFont(font);

        QRect dayRect = QRect(0, 0, width, height / 1.7);
        painter->drawText(dayRect, Qt::AlignHCenter | Qt::AlignBottom, QString::number(date.day()));
    } else {
        QFont font;
        font.setPixelSize(side / 2);
        painter->setFont(font);

        QRect dayRect = QRect(0, 0, width, height);
        painter->drawText(dayRect, Qt::AlignCenter, QString::number(date.day()));
    }

    painter->restore();
}

void LunarCalendarItem::drawLunar(QPainter *painter)
{
    if (!showLunar) {
        return;
    }

    int width = this->width();
    int height = this->height();
    int side = qMin(width, height);

    painter->save();

    //判斷當前農歷文字是否節日,是節日且是當月則用農歷節日顏色顯示
    bool exist = (!listDayName.contains(lunar) && dayType != DayType_MonthPre && dayType != DayType_MonthNext);

    //根據當前類型選擇對應的顏色
    QColor color = currentLunarColor;
    if (dayType == DayType_MonthPre || dayType == DayType_MonthNext) {
        color = otherLunarColor;
    }

    if (select) {
        color = selectTextColor;
    } else if (hover) {
        color = hoverTextColor;
    } else if (exist) {
        color = lunarColor;
    }

    painter->setPen(color);

    QFont font;
    font.setPixelSize(side / 5);
    painter->setFont(font);    

    QRect lunarRect(0, height / 2, width, height / 2);
    painter->drawText(lunarRect, Qt::AlignCenter, lunar);

    painter->restore();
}

三、效果圖

Qt農歷控件如何實現

到此,關于“Qt農歷控件如何實現”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

qt
AI

鹤山市| 仪陇县| 台南县| 唐河县| 延庆县| 来宾市| 海晏县| 桂林市| 绍兴市| 塔城市| 周口市| 吴桥县| 西昌市| 鄂尔多斯市| 盐源县| 台南市| 繁峙县| 宁乡县| 鄯善县| 鸡泽县| 黄梅县| 简阳市| 和静县| 阜平县| 海林市| 抚州市| 亳州市| 蚌埠市| 四平市| 涞源县| 伊吾县| 封开县| 万载县| 林甸县| 象山县| 维西| 长宁县| 株洲市| 卢湾区| 博乐市| 桓仁|