获取颜色对应的字符串

获取颜色的字符串

QString GetQColorStr(const QColor& t_color)
{
    int c_red = t_color.red();
    int c_green = t_color.green();
    int c_blue = t_color.blue();
    int c_alpha = t_color.alpha();

    QString color_str;
    color_str = "0x" + QString("%1%2%3%4").
        arg(t_color.alpha(), 2, 16, QLatin1Char('0'))
        .arg(t_color.red(), 2, 16, QLatin1Char('0'))
        .arg(t_color.green(), 2, 16, QLatin1Char('0'))
        .arg(t_color.blue(), 2, 16, QLatin1Char('0'));

    return color_str;
}

或者使用QT自带的方法获取ARGB字符串,以下是一个示例:

#include <QColor>
#include <QDebug>

int main() {
    QColor color(Qt::red);  // 创建一个红色 QColor 对象

    // 获取 ARGB 字符串表示颜色的值
    QString argbString = color.name(QColor::HexArgb);

    qDebug() << argbString;  // 打印 ARGB 字符串

    return 0;
}

根据字符串获取颜色

QColor GetQClrByStr(QString t_color)
{
    unsigned int argb = t_color.toUInt(bool(), 16);
    return QColor(
        (argb & 0x00FF0000) >> 16,
        (argb & 0x0000FF00) >> 8,
        (argb & 0x000000FF),
        (argb & 0xFF000000) >> 24);
}

获取当前样式中的字体颜色

首先获取对应widget的调色板QPalette,然后获取调色板中的字体颜色

  • 在控件paintEvent中可能会用到,因为要考虑样式表的颜色一致
  • 在设置QTableWidgetItem颜色和重置颜色的时候可能会用到,否则会出现样式表一改,就要调整代码的情况
  • 同样的,对于QTreeWidget也会有第二种情况

GPT问答

QColor可以使用多种颜色空间,包括:

  1. RGB颜色空间:使用红(R)、绿(G)、蓝(B)三个颜色通道来表示颜色。

  2. HSV颜色空间:使用色相(H)、饱和度(S)、亮度(V)三个维度来表示颜色。HSV颜色空间适用于人类对颜色的感知特点。

  3. CMYK颜色空间:使用青(C)、洋红(M)、黄(Y)、黑(K)四个颜色通道来表示颜色。CMYK颜色空间适用于打印领域。

  4. 颜色名称:可以使用预定义的颜色名称,如"red"、"yellow"、"green"等来表示颜色。

  5. 十六进制颜色码:使用六位十六进制数字表示颜色,如"#FF0000"表示红色、"#00FF00"表示绿色、"#0000FF"表示蓝色等。

QColor是一个用于管理颜色的类,它可以用于设置和获取RGB值、色相、饱和度、亮度等属性,也可以用于创建渐变和调色板。

以下是一些QColor的常用方法和示例用法:

  1. 设置颜色:
color = QColor(255, 0, 0)  # 红色
color = QColor("#FF0000")  # 红色
color.setRgb(255, 0, 0)   # 红色
color.setNamedColor("red") # 红色
  1. 获取颜色信息:
# 获取颜色的RGB值
r, g, b, a = color.getRgb()
# 获取颜色的16进制表示
hex_str = color.name()
# 获取颜色的色相、饱和度、亮度
h, s, l, a = color.getHsl()
  1. 判断颜色是否合法:
is_valid = color.isValid()
  1. 创建渐变:
# 创建线性渐变
gradient = QLinearGradient(0, 0, 0, height)
gradient.setColorAt(0, QColor(255, 255, 255))
gradient.setColorAt(1, QColor(0, 0, 0))
# 创建径向渐变
gradient = QRadialGradient(center, radius)
gradient.setColorAt(0, QColor(255, 255, 255))
gradient.setColorAt(1, QColor(0, 0, 0))
  1. 创建调色板:
palette = QPalette()
palette.setColor(QPalette.Background, QColor(255, 255, 255))  # 设置背景颜色
palette.setColor(QPalette.Button, QColor(0, 0, 0))           # 设置按钮颜色
palette.setColor(QPalette.ButtonText, QColor(255, 255, 255))  # 设置按钮文字颜色
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容