在实际项目中,我们往往想让指定的文字连接成一个整体,不让用户对显示的文字进行拆分复制等操作,只进行显示,也就是说,我们想让部分字符串以原子的形式显示给用户,例如,在即时通讯软件中,我们在群里@一个人是,当补全成功后,即为一个图片显示在编辑框中,如下图:
我们只能对@的这个人名整体进行操作,这就用到了接下来讲的东西:将字符串写入图片中显示并将图片保存到本地,其主要代码如下:
其效果如下图:
我们只能对@的这个人名整体进行操作,这就用到了接下来讲的东西:将字符串写入图片中显示并将图片保存到本地,其主要代码如下:
//===================================================================================
//保存路径(包括文件名)
QString tempImagePath="/Users/Tmp/test.png";
//图片上的字符串,例如 HELLO
QString imageText="HELLO";
QFont font;
//设置显示字体的大小
font.setPixelSize(13);
QFontMetrics fm(font);
int charWidth = fm.width(imageText);
charWidth = fm.boundingRect(imageText).width();
//指定图片大小为字体的大小
QSize size(charWidth+8, 15);
//以ARGB32格式构造一个QImage
QImage image(size, QImage::Format_ARGB32);
//填充图片背景,120/250为透明度
image.fill(qRgba(255, 255, 255, 0));
//为这个QImage构造一个QPainter
QPainter painter(&image);
//设置画刷的组合模式CompositionMode_SourceOut这个模式为目标图像在上。
//改变组合模式和上面的填充方式可以画出透明的图片。
painter.setCompositionMode(QPainter::CompositionMode_DestinationOver);
//改变画笔和字体
QPen pen = painter.pen();
pen.setColor( QColor(0, 141, 239));
painter.setPen(pen);
painter.setFont(font);
//将Hello写在Image的中心
painter.drawText(image.rect(), Qt::AlignCenter, imageText);
image.save(tempImagePath, "PNG", 100);
//===================================================================================
其效果如下图:
截图放入QQ中效果如下: