Почему QTextBrowser портит мой HTML-код? - PullRequest
0 голосов
/ 01 октября 2018

Я пытаюсь создать счета в формате PDF, так как мое требование довольно простое, я подумал об использовании HTML + QTextBrowser.Я написал функции, которые будут создавать HTML-код в соответствии с моими потребностями.Например, если я хочу вставить текст, для этого есть функция, для вставки таблицы я также создал функцию и так далее.Я устанавливаю этот HTML-код в QTextBrowser с помощью функции setHtml (), а затем пытаюсь создать PDF.Проблема в том, что я не получаю то, что ожидаю, проблема не в моем HTML-коде, так как я использовал тот же код и видел в браузере Chrome все в порядке.Но в тот момент, когда я использую его в функции setHtml, Qt модифицирует HTML-код, и результат нежелателен.Ниже я также публикую свой код с ожидаемыми и результирующими изображениями.

void PDF_API::Save(const QString &filePath)
{ 
    QTextDocument document;
    document.setHtml(HTMLCode); // HTMLCode is a QString obj that holds all my html code

    // Creates a copy in html to check the html code. Comment the code if not needed
    QFile file(QDir::currentPath()+"/report.html");
    if(file.open(QFile::WriteOnly))
    {
        file.write(HTMLCode.toStdString().c_str());
        file.close();
    }

    // Printing begins here
    QPrinter printer(QPrinter::PrinterResolution);
    printer.setOutputFormat(QPrinter::PdfFormat);
    printer.setPaperSize(QPrinter::Tabloid);
    printer.setOutputFileName(filePath);
    printer.setPageMargins(QMarginsF(0.1, 0.01, 0.1, 0.1));
    document.print(&printer);
}

Исходный код HTML, прежде чем установить его в QTextBrowser

"<html><body><p align=\"center\" style=\"color: #000000; font-family: Times New Roman; font-size: 12pt; line-height: 100%;\">  <b>CENTER </b> </p><hr><p style = \"text-align:left; color: #ff0000; font-family: Times New Roman; font-size: 14pt; line-height: 100%;\"> <b>Left Text</b> <span style = \"float:right; color: #ffff00; font-family: Times New Roman; font-size: 14pt; line-height: 100%;\"> <b>Right Text</b> </span> </p></body></html>"

Модифицированный код HTML, созданный QTextBrowser

"<!DOCTYPE HTML PUBLIC \"-//W3C//DTD HTML 4.0//EN\" \"http://www.w3.org/TR/REC-html40/strict.dtd\">\n<html><head><meta name=\"qrichtext\" content=\"1\" /><style type=\"text/css\">\np, li { white-space: pre-wrap; }\n</style></head><body style=\" font-family:'MS Shell Dlg 2'; font-size:8.25pt; font-weight:400; font-style:normal;\">\n<p align=\"center\" style=\" margin-top:12px; margin-bottom:12px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px; line-height:100%;\"><span style=\" font-family:'Times New Roman'; font-size:12pt; font-weight:600; color:#000000;\">CENTER </span></p>\n<hr />\n<p style=\" margin-top:12px; margin-bottom:12px; margin-left:0px; margin-right:0px; -qt-block-indent:0; text-indent:0px; line-height:100%;\"><span style=\" font-family:'Times New Roman'; font-size:14pt; font-weight:600; color:#ff0000;\">Left Text</span><span style=\" font-family:'Times New Roman'; font-size:14pt; color:#ff0000;\"> </span><span style=\" font-family:'Times New Roman'; font-size:14pt; font-weight:600; color:#ffff00;\">Right Text</span><span style=\" font-family:'Times New Roman'; font-size:14pt; color:#ffff00;\"> </span></p></body></html>"

Примечание :: Приведенный выше HTML-код показан на консоли отладки, которая содержалась в QString

Как видно в браузере Chrome с использованием исходного HTML-кода
enter image description here

Как видно из QTextBrowser enter image description here

Как я могу предотвратитьQTextBrowser испортить мой HTML-код и получить желаемый результат?

PS: Это случалось много раз прежде, так как раньше я требовал только распечатать PDF, я использовал внешний процесс wkhtmltopdf для создания PDF, но теперь в этом сценарии я хочуувидеть результат в самом приложении.

1 Ответ

0 голосов
/ 01 октября 2018

QTextBrowser поддерживает только подмножество HTML & CSS .Для полной поддержки попробуйте использовать QWebView.

...