在各种软件系统中,数据打印也是常用的功能之一,一般来说会对查询的数据结果导出到excel,还会对查询的数据结果直接打印,在Qt中提供了打印机类QPrinter,在printsupport组件中,可以将文本内容传入QTextDocument,然后调用QTextDocument的print方法来打印数据,QTextDocument支持html格式的文本,这样拓展性就很大了,我们所知道的表格边框颜色等,都是可以用html的语法来表示,不过貌似支持的html内容不是很多,只是部分,样式也是支持部分,但是也已经够用,常用的表格、边框、颜色、边距、字体等,都具备,那就ok了。
在上一篇文章中导出数据使用的xml格式的数据,而导出pdf使用的就是打印类中的打印到pdf文件,用的就是html格式的数据,同理,打印数据也是用这种格式,和导出到pdf唯一的区别就是导出到pdf设置输出格式为PDF,printer.setOutputFormat(QPrinter::PdfFormat); 然后设置输出文件保存位置printer.setOutputFileName(fileName);其实组织的内容是完全一样的,据说新版的qt打算封装一个独立的QtPdf模块,不知道下一个版本会不会放出来,这样就可以跨平台的操作编辑pdf文件了。
皮肤开源:https://gitee.com/feiyangqingyun/QWidgetDemo https://github.com/feiyangqingyun/QWidgetDemo
文件名称:styledemo
体验地址:https://gitee.com/feiyangqingyun/QWidgetExe https://github.com/feiyangqingyun/QWidgetExe
文件名称:bin_sams.zip
#include "printapi.h"
#include "qmutex.h"
#include "qprintpreviewdialog.h"
#include "qtextdocument.h"
#include "qtextobject.h"
QScopedPointer PrintAPI::self;
PrintAPI *PrintAPI::Instance()
{
if (self.isNull()) {
static QMutex mutex;
QMutexLocker locker(&mutex);
if (self.isNull()) {
self.reset(new PrintAPI);
}
}
return self.data();
}
PrintAPI::PrintAPI(QObject *parent) : QObject(parent)
{
}
void PrintAPI::print(const QString &title, const QString &subTitle, const QList &columnNames,
const QList &columnWidths, const QStringList &content, bool landscape, bool check,
int checkColumn, const QString &checkType, const QString &checkValue, const QPrinter::PageSize &pageSize)
{
//计算行数列数
int columnCount = columnNames.count();
int rowCount = content.count();
//清空原有数据,确保每次都是新的数据
html.clear();
//表格开始
html.append("");
//标题占一行,居中显示
if (title.length() > 0) {
html.append(QString("").arg(columnCount));
html.append(title);
html.append(" ");
}
//副标题占一行,左对齐显示
if (subTitle.length() > 0) {
html.append(QString("").arg(columnCount));
html.append(subTitle);
html.append(" ");
}
//循环写入字段名,字段名占一行,居中显示
if (columnCount > 0) {
html.append("");
for (int i = 0; i < columnCount; i++) {
html.append(QString("").arg(columnWidths.at(i)));
html.append(columnNames.at(i));
html.append(" ");
}
html.append(" ");
}
//循环一行行构建数据
for (int i = 0; i < rowCount; i++) {
QStringList value = content.at(i).split(";");
html.append("");
//过滤内容,如果启用了过滤数据,则将符合条件的数据突出颜色显示
bool existCheck = false;
if (check) {
if (checkType == "==") {
if (value.at(checkColumn) == checkValue) {
existCheck = true;
}
} else if (checkType == ">") {
if (value.at(checkColumn) > checkValue) {
existCheck = true;
}
} else if (checkType == ">=") {
if (value.at(checkColumn) >= checkValue) {
existCheck = true;
}
} else if (checkType == "<") {
if (value.at(checkColumn) < checkValue) {
existCheck = true;
}
} else if (checkType == "<=") {
if (value.at(checkColumn) <= checkValue) {
existCheck = true;
}
} else if (checkType == "!=") {
if (value.at(checkColumn) != checkValue) {
existCheck = true;
}
}
}
if (existCheck) {
for (int j = 0; j < columnCount; j++) {
html.append(QString("").arg(columnWidths.at(j)));
html.append(value.at(j));
html.append(" ");
}
} else {
for (int j = 0; j < columnCount; j++) {
html.append(QString("").arg(columnWidths.at(j)));
html.append(value.at(j));
html.append(" ");
}
}
html.append(" ");
}
html.append("
");
//调用打印机打印
QPrinter printer;
//设置输出格式
printer.setOutputFormat(QPrinter::NativeFormat);
//设置纸张规格
printer.setPageSize(pageSize);
//设置横向纵向及页边距
if (landscape) {
printer.setOrientation(QPrinter::Landscape);
printer.setPageMargins(10, 10, 10, 10, QPrinter::Millimeter);
} else {
printer.setOrientation(QPrinter::Portrait);
printer.setPageMargins(10, 10, 10, 11, QPrinter::Millimeter);
}
QPrintPreviewDialog preview(&printer);
preview.setStyleSheet("QToolButton{background:none;margin:2px;padding:0px;border-width:0px;border-radius:0px;}QLineEdit{border-width:0px;}");
preview.setWindowTitle("打印预览");
preview.setWindowFlags(Qt::WindowStaysOnTopHint);
connect(&preview, SIGNAL(paintRequested(QPrinter *)), this, SLOT(printView(QPrinter *)));
preview.showMaximized();
preview.exec();
}
void PrintAPI::print(const QString &title, const QList &columnNames, const QList &columnWidths,
const QStringList &subTitle1, const QStringList &subTitle2,
const QStringList &content, bool landscape, bool check,
int checkColumn, const QString &checkType, const QString &checkValue, const QPrinter::PageSize &pageSize)
{
//计算列数
int columnCount = columnNames.count();
//清空原有数据,确保每次都是新的数据
html.clear();
//表格开始
html.append("");
//标题占一行,居中显示
if (title.length() > 0) {
html.append(QString("")
.arg(columnCount));
html.append(title);
html.append(" ");
}
//循环添加副标题/字段名/内容
int count = content.count();
for (int i = 0; i < count; i++) {
//加个空行隔开
html.append(QString("").arg(columnCount));
html.append(" ");
//副标题1
if (subTitle1.count() > 0 && subTitle1.count() > i) {
if (subTitle1.at(i).length() > 0) {
html.append(QString("")
.arg(columnCount));
html.append(subTitle1.at(i));
html.append(" ");
}
}
//副标题2
if (subTitle2.count() > 0 && subTitle2.count() > i) {
if (subTitle2.at(i).length() > 0) {
html.append(QString("")
.arg(columnCount));
html.append(subTitle2.at(i));
html.append(" ");
}
}
//逐个添加字段名称
if (columnCount > 0) {
html.append("");
for (int i = 0; i < columnCount; i++) {
html.append(QString("")
.arg(columnWidths.at(i)));
html.append(columnNames.at(i));
html.append(" ");
}
html.append(" ");
}
QStringList list = content.at(i).split(";");
//逐个添加数据
int rowCount = list.count();
for (int j = 0; j < rowCount; j++) {
html.append("");
QString temp = list.at(j);
QStringList value = temp.split("|");
int valueCount = value.count();
//过滤内容,如果启用了过滤数据,则将符合条件的数据突出颜色显示
bool existCheck = false;
if (check) {
if (checkType == "==") {
if (value.at(checkColumn) == checkValue) {
existCheck = true;
}
} else if (checkType == ">") {
if (value.at(checkColumn) > checkValue) {
existCheck = true;
}
} else if (checkType == ">=") {
if (value.at(checkColumn) >= checkValue) {
existCheck = true;
}
} else if (checkType == "<") {
if (value.at(checkColumn) < checkValue) {
existCheck = true;
}
} else if (checkType == "<=") {
if (value.at(checkColumn) <= checkValue) {
existCheck = true;
}
} else if (checkType == "!=") {
if (value.at(checkColumn) != checkValue) {
existCheck = true;
}
}
}
if (existCheck) {
for (int k = 0; k < valueCount - 1; k++) {
html.append(QString("").arg(columnWidths.at(k)));
html.append(value.at(k));
html.append(" ");
}
} else {
for (int k = 0; k < valueCount; k++) {
html.append(QString("").arg(columnWidths.at(k)));
html.append(value.at(k));
html.append(" ");
}
}
html.append(" ");
}
}
html.append("
");
//调用打印机打印
QPrinter printer;
//设置输出格式
printer.setOutputFormat(QPrinter::NativeFormat);
//设置纸张规格
printer.setPageSize(pageSize);
//设置横向纵向及页边距
if (landscape) {
printer.setOrientation(QPrinter::Landscape);
printer.setPageMargins(10, 10, 10, 10, QPrinter::Millimeter);
} else {
printer.setOrientation(QPrinter::Portrait);
printer.setPageMargins(10, 10, 10, 11, QPrinter::Millimeter);
}
QPrintPreviewDialog preview(&printer);
preview.setStyleSheet("QToolButton{background:none;margin:2px;padding:0px;border-width:0px;border-radius:0px;}QLineEdit{border-width:0px;}");
preview.setWindowTitle("打印预览");
preview.setWindowFlags(Qt::WindowStaysOnTopHint);
connect(&preview, SIGNAL(paintRequested(QPrinter *)), this, SLOT(printView(QPrinter *)));
preview.showMaximized();
preview.exec();
}
void PrintAPI::printView(QPrinter *printer)
{
QTextDocument textDocument;
textDocument.setHtml(html.join(""));
textDocument.setPageSize(printer->pageRect().size());
textDocument.print(printer);
}