中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

尼玛县| 六盘水市| 罗源县| 阜康市| 上虞市| 西乌珠穆沁旗| 香河县| 天祝| 庆城县| 津市市| 苏州市| 龙陵县| 灵璧县| 新源县| 曲沃县| 南昌市| 桂林市| 巴马| 锦州市| 平阴县| 大渡口区| 台中县| 大埔区| 都安| 华阴市| 股票| 碌曲县| 资源县| 栾川县| 明光市| 广灵县| 玉树县| 清丰县| 肃南| 伊宁县| 陆川县| 乳山市| 虎林市| 久治县| 县级市| 庆元县|