1fe7144a07
This introduces a way to trace each entry in the glyph index array to a specific index in the original text passed to QTextLayout, as well as a convenience function to access the original string from the QGlyphRun. The index information is stored in the logClusters array internally in Qt, but it contains the inverse information: For each character in the output string, it contains an index into the glyph array. In order to get the string indexes for each glyph, which makes a lot more sense in the context of the QGlyphRun API, we need to do a little search to construct the data. To avoid adding unnecessary allocations, we make the new APIs opt-in. If you do not specify anything, you will only get the glyph indexes and glyph positions as before. However, you can now specify exactly which parts of the layout to extract using an optional flags parameter. This also adds a manual test which can be very handy to visualize QTextLayouts and how they are split into QGlyphRuns. Fixes: QTBUG-103932 Change-Id: Ie4288fff338b9482aba0aba29fc7e1e59fa60900 Reviewed-by: Lars Knoll <lars@knoll.priv.no>
43 lines
893 B
C++
43 lines
893 B
C++
// Copyright (C) 2022 The Qt Company Ltd.
|
|
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR GPL-3.0-only WITH Qt-GPL-exception-1.0
|
|
|
|
#ifndef VIEW_H
|
|
#define VIEW_H
|
|
|
|
#include <QWidget>
|
|
#include <QTextOption>
|
|
|
|
class QTextLayout;
|
|
class View : public QWidget
|
|
{
|
|
Q_OBJECT
|
|
public:
|
|
explicit View(QWidget *parent = nullptr);
|
|
~View() override;
|
|
|
|
void updateLayout(const QString &sourceString,
|
|
float width,
|
|
QTextOption::WrapMode mode,
|
|
const QFont &font);
|
|
|
|
QSize sizeHint() const override;
|
|
|
|
QTextLayout *layout() const { return m_layout; }
|
|
|
|
public slots:
|
|
void setVisualizedBounds(const QRegion ®ion)
|
|
{
|
|
m_bounds = region;
|
|
update();
|
|
}
|
|
|
|
protected:
|
|
void paintEvent(QPaintEvent *e) override;
|
|
|
|
private:
|
|
QTextLayout *m_layout = nullptr;
|
|
QRegion m_bounds;
|
|
};
|
|
|
|
#endif // VIEW_H
|