//for starf study
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include<QDebug>
#include<QRgba64>
//QRgba64结构包含64位RGB颜色。
//QRgba64是一个64位数据结构,包含四个16位颜色通道:红色、绿色、蓝色和alpha。
//当需要更高的精度时,QRgba64可以用作QRgb的替代品。
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
, ui(new Ui::MainWindow)
{
ui->setupUi(this);
QRgba64 Rgba64 = QRgba64(); //只能创建一个空的对象
Rgba64.setRed(55000);
Rgba64.setGreen(0);
Rgba64.setGreen(0);
Rgba64.setAlpha(0); //设置RGBA 为 65535 00 00 65535 那么将会是最红的红色
qDebug()<<Rgba64.red8()<<Rgba64.red();
qDebug()<<Rgba64.green8()<<Rgba64.green();
qDebug()<<Rgba64.blue8()<<Rgba64.blue();
qDebug()<<Rgba64.alpha8()<<Rgba64.alpha(); //获得该rgba64的各个参数,不带8的会获取16位的值,做了更精确的区分
qDebug()<<Rgba64.isOpaque(); //返回颜色是否完全不透明 只有当setAlpha 设置为65535 才会返回true
qDebug()<<Rgba64.isTransparent(); //返回颜色是否完全透明。 即setAlpha必须为0才可以返回true
QRgba64 Rg = Rgba64.premultiplied(); //返回带有alpha预乘的值
Rg = Rgba64.unpremultiplied(); //返回没有alpha预乘的值
uint rgb32 = Rgba64.toArgb32(); //转化为ARGB的标准格式
ushort rgb16 = Rgba64.toRgb16(); //转化为RGB 16位模式
}
MainWindow::~MainWindow()
{
delete ui;
}
QRgba64 所有方法功能(QT5.12)
最新推荐文章于 2023-01-04 16:44:38 发布