QTextBrowser Class

QTextBrowserクラスは、ハイパーテキストナビゲーションを備えたリッチテキストブラウザを提供します。詳細...

Header: #include <QTextBrowser>
CMake: find_package(Qt6 REQUIRED COMPONENTS Widgets)
target_link_libraries(mytarget PRIVATE Qt6::Widgets)
qmake: QT += widgets
Inherits: QTextEdit

プロパティ

パブリック関数

QTextBrowser(QWidget *parent = nullptr)
int backwardHistoryCount() const
void clearHistory()
int forwardHistoryCount() const
QString historyTitle(int i) const
QUrl historyUrl(int i) const
bool isBackwardAvailable() const
bool isForwardAvailable() const
bool openExternalLinks() const
bool openLinks() const
QStringList searchPaths() const
void setOpenExternalLinks(bool open)
void setOpenLinks(bool open)
void setSearchPaths(const QStringList &paths)
QUrl source() const
QTextDocument::ResourceType sourceType() const

再実装パブリック関数

virtual QVariant loadResource(int type, const QUrl &name) override

パブリックスロット

virtual void backward()
virtual void forward()
virtual void home()
virtual void reload()
void setSource(const QUrl &url, QTextDocument::ResourceType type = QTextDocument::UnknownResource)

シグナル

void anchorClicked(const QUrl &link)
void backwardAvailable(bool available)
void forwardAvailable(bool available)
void highlighted(const QUrl &link)
void historyChanged()
void sourceChanged(const QUrl &src)

保護された関数

virtual void doSetSource(const QUrl &url, QTextDocument::ResourceType type = QTextDocument::UnknownResource)

再実装された保護された関数

virtual bool event(QEvent *e) override
virtual bool focusNextPrevChild(bool next) override
virtual void focusOutEvent(QFocusEvent *ev) override
virtual void keyPressEvent(QKeyEvent *ev) override
virtual void mouseMoveEvent(QMouseEvent *e) override
virtual void mousePressEvent(QMouseEvent *e) override
virtual void mouseReleaseEvent(QMouseEvent *e) override
virtual void paintEvent(QPaintEvent *e) override

詳しい説明

このクラスはQTextEdit (読み取り専用モード) を拡張し、ユーザがハイパーテキスト文書のリンクをたどれるように、いくつかのナビゲーション機能を追加しています。

編集可能なリッチテキストエディタをユーザに提供したい場合は、QTextEdit を使用してください。ハイパーテキスト・ナビゲーションのないテキスト・ブラウザが必要な場合はQTextEdit を使い、編集を無効にするにはQTextEdit::setReadOnly() を使ってください。小さなリッチテキストを表示するだけならQLabel を使ってください。

ドキュメントのソースと内容

QTextEdit の内容はsetHtml() またはsetPlainText() で設定されますが、QTextBrowser はsetSource() 関数も実装しており、名前付きドキュメントをソーステキストとして使用することができます。名前は、検索パスのリストと現在のドキュメントファクトリのディレクトリで検索されます。

文書名の末尾がアンカー (た と えば "#anchor" ) であ る と き は、 テ キ ス ト ブ ラ ウ ザは自動的にその位置へ (scrollToAnchor () を用いて) スク ロールします。ユーザーがハイパーリンクをクリックすると、ブラウザはリンクのhref 値を引数としてsetSource() 自身を呼び出します。sourceChanged() 信号に接続することで、現在のソースを追跡できます。

QTextBrowserは、戻るボタンと進むボタンを実装するために使用できる、backward ()とforward ()スロットを提供します。home() スロットは、テキストを最初に表示されたドキュメントに設定します。anchorClicked() シグナルは、ユーザーがアンカーをクリックした時に発行されます。ブラウザのデフォルトのナビゲーション動作をオーバーライドするには、setSource() 関数を呼び出して、このシグナルに接続されたスロットに新しいドキュメント・テキストを供給します。

Qt リソースシステムに保存されたドキュメントをロードする場合は、ロードする URL のスキームとしてqrc を使用します。例えば、ドキュメント・リソース・パス:/docs/index.html の場合、qrc:/docs/index.html を URL として使用し、setSource() を使用します。

QTextEdit およびQTextDocumentも参照して ください。

プロパティ Documentation

[read-only] modified : const bool

このプロパティは、テキスト・ブラウザのコンテンツが変更されているかどうかを保持します。

anchorClicked シグナルを発する代わりにQDesktopServices::openUrl() を使って外部ソースへのリンクをQTextBrowser が自動的に開くかどうかを指定する。リンクは、そのスキームがfileでもqrcでもない場合、外部とみなされる。

デフォルト値はfalseです。

アクセス関数:

bool openExternalLinks() const
void setOpenExternalLinks(bool open)

このプロパティは、QTextBrowser 、ユーザーがマウスやキーボードでアクティブにしようとしたリンクを自動的に開くかどうかを指定します。

このプロパティの値にかかわらず、anchorClicked シグナルは常に発信されます。

デフォルト値はtrueです。

アクセス関数:

bool openLinks() const
void setOpenLinks(bool open)

readOnly : const bool

このプロパティは、テキストブラウザが読み取り専用かどうかを保持します。

デフォルトでは、このプロパティはtrue です。

searchPaths : QStringList

このプロパティは、テキストブラウザがサポートコンテンツを見つけるために使用する検索パスを保持します。

QTextBrowser は、 画像 と 文書を検索す る ために こ の リ ス ト を使用 し ます。

デフ ォル ト では、 こ のプ ロ パテ ィ には空の文字列 リ ス ト が格納 さ れてい ます。

アクセス関数:

QStringList searchPaths() const
void setSearchPaths(const QStringList &paths)

source : QUrl

このプロパティは、表示されたドキュメントの名前を保持します。

ドキュメントが表示されていない場合、またはソースが不明な場合、これは無効なURLになります。

このプロパティを設定するときQTextBrowser は、値が絶対ファイルパスでない限り、現在のソースのsearchPaths プロパティとディレクトリのパスから、指定された名前のドキュメントを見つけようとします。また、オプションのアンカーをチェックし、それに応じてドキュメントをスクロールします。

ドキュメントの最初のタグが<qt type=detail> である場合、ドキュメントはブラウザウィンドウ自体に新しいドキュメントとしてではなく、ポップアップとして表示されます。そうでない場合、ドキュメントはテキストブラウザに通常通り表示され、ファイル名が既知のMarkdownファイル拡張子で終わっているかどうかに応じて、QTextDocument::setHtml()またはQTextDocument::setMarkdown()で、テキストは指定されたドキュメントの内容に設定されます。

自動タイプ検出を避けてタイプを明示的に指定したい場合は、このプロパティを設定するのではなく、setSource ()を呼び出します。

デフォルトでは、このプロパティには空のURLが含まれます。

アクセス関数:

QUrl source() const
void setSource(const QUrl &url, QTextDocument::ResourceType type = QTextDocument::UnknownResource)

[read-only] sourceType : const QTextDocument::ResourceType

このプロパティは、表示されているドキュメントのタイプを保持します。

文書が表示されていない場合、またはソースの型が不明な場合は、QTextDocument::UnknownResource 。それ以外の場合は、検出された型、またはsetSource() が呼び出されたときに指定された型を保持する。

アクセス関数:

QTextDocument::ResourceType sourceType() const

undoRedoEnabled : const bool

このプロパティは、テキスト・ブラウザが取り消し/やり直し操作をサポートしているかどうかを保持します。

デフォルトでは、このプロパティはfalse です。

メンバ関数 ドキュメント

[explicit] QTextBrowser::QTextBrowser(QWidget *parent = nullptr)

空のQTextBrowserを親parent で構築します。

[signal] void QTextBrowser::anchorClicked(const QUrl &link)

このシグナルは、ユーザーがアンカーをクリックした時に発行されます。アンカーが参照するURLは、link で渡されます。

openLinks プロパティがfalseに設定されているか、スロット接続でsetSource() を呼び出さない限り、ブラウザは自動的にlink で指定された場所へのナビゲーションを処理することに注意してください。このメカニズムは、ブラウザのデフォルトのナビゲーション機能をオーバーライドするために使用されます。

[virtual slot] void QTextBrowser::backward()

表示されるドキュメントを、ナビゲートリンクによって構築されたドキュメントのリスト内の前のドキュメントに変更します。前のドキュメントがない場合は何もしない。

forward() およびbackwardAvailable()も参照

[signal] void QTextBrowser::backwardAvailable(bool available)

このシグナルは、backward()の利用可否が変化したときに発せられる。available は、ユーザーがhome()にいるときに偽となり、そうでなければ真となる。

int QTextBrowser::backwardHistoryCount() const

履歴の遡った位置の数を返す。

void QTextBrowser::clearHistory()

訪問したドキュメントの履歴を消去し、前方および後方へのナビゲーションを無効にします。

backward() およびforward()も参照

[virtual protected] void QTextBrowser::doSetSource(const QUrl &url, QTextDocument::ResourceType type = QTextDocument::UnknownResource)

与えられたurl にあるドキュメントを、指定されたtype でロードしようと試みます。

setSource() は doSetSource を呼び出します。Qt 5 では、setSource(constQUrl &url) は仮想でした。Qt 6 では、doSetSource() が仮想化され、サブクラスでオーバーライドできるようになりました。

[override virtual protected] bool QTextBrowser::event(QEvent *e)

再インプリメント:QAbstractScrollArea::event(QEvent *event)。

[override virtual protected] bool QTextBrowser::focusNextPrevChild(bool next)

再リンプルメント:QTextEdit::focusNextPrevChild(bool next)。

[override virtual protected] void QTextBrowser::focusOutEvent(QFocusEvent *ev)

再リンプルメント:QTextEdit::focusOutEvent(QFocusEvent *e)。

[virtual slot] void QTextBrowser::forward()

表示されているドキュメントを、ナビゲートリンクによって構築されたドキュメントリストの次のドキュメントに変更します。次のドキュメントがない場合は何もしません。

backward() およびforwardAvailable()も参照してください

[signal] void QTextBrowser::forwardAvailable(bool available)

このシグナルは、forward()の可否が変化したときに発せられる。available は、ユーザがbackward()をナビゲートした後にtrueになり、ユーザがforward()をナビゲートまたは移動したときにfalseになる。

int QTextBrowser::forwardHistoryCount() const

履歴の前方のロケーション数を返す。

[signal] void QTextBrowser::highlighted(const QUrl &link)

このシグナルは、ユーザがドキュメント内のアンカーを選択したがアクティブにしていない場合に発せられる。アンカーが参照するURLはlink で渡される。

[signal] void QTextBrowser::historyChanged()

このシグナルは履歴が変更されたときに発せられる。

historyTitle() およびhistoryUrl()も参照してください

QString QTextBrowser::historyTitle(int i) const

HistoryItem のdocumentTitle() を返します。

入力戻り値
i < 0backward() 履歴
i == 0現在、QTextBrowser::source()を参照
i > 0forward() history
backaction.setToolTip(browser.historyTitle(-1));
forwardaction.setToolTip(browser.historyTitle(+1));

QUrl QTextBrowser::historyUrl(int i) const

HistoryItem の url を返します。

入力戻り値
i < 0backward() history
i == 0現在、QTextBrowser::source()を参照
i > 0forward() 履歴

[virtual slot] void QTextBrowser::home()

表示する文書を履歴の最初の文書に変更します。

bool QTextBrowser::isBackwardAvailable() const

テキストブラウザがbackward() を使って文書の履歴を遡れる場合はtrue を返す。

backwardAvailable() およびbackward()も参照

bool QTextBrowser::isForwardAvailable() const

テキストブラウザがforward() を使ってドキュメント履歴を進むことができる場合はtrue を返す。

forwardAvailable() およびforward()も参照

[override virtual protected] void QTextBrowser::keyPressEvent(QKeyEvent *ev)

再実装:QTextEdit::keyPressEvent(QKeyEvent *e)。

イベントev は、以下のキーボード・ショートカットを提供するために使用されます:

キーを押すアクション
Alt+左矢印backward()
Alt+右矢印forward()
Alt+上矢印home()

[override virtual] QVariant QTextBrowser::loadResource(int type, const QUrl &name)

再実装:QTextEdit::loadResource(int type, const QUrl &name).

この関数は、ドキュメントが読み込まれるときと、ドキュメント内の画像ごとに呼び出されます。type は、読み込まれるリソースのタイプを示します。リソースが読み込めない場合は無効なQVariant が返されます。

デフ ォル ト の実装ではtype は無視 さ れ、name を フ ァ イ ル名 と 解釈 し て リ ソ ース を見つけ よ う と し ます。絶対パスでない場合は、searchPaths プロパティのパスで、現在のソースと同じディレクトリにあるファイルを見つけようとします。成功すると、結果はQVariant となり、ファイルの内容がQByteArray に格納されます。

この関数を再実装すると、他のQVariant 型を返すことができます。以下の表に、リソース・タイプによってサポートされるバリアント・タイプを示します:

[override virtual protected] void QTextBrowser::mouseMoveEvent(QMouseEvent *e)

再実装:QTextEdit::mouseMoveEvent(QMouseEvent *e)。

[override virtual protected] void QTextBrowser::mousePressEvent(QMouseEvent *e)

再リプリメント:QTextEdit::mousePressEvent(QMouseEvent *e).

[override virtual protected] void QTextBrowser::mouseReleaseEvent(QMouseEvent *e)

再リンプルメント: (QMouseEvent *e):QTextEdit::mouseReleaseEvent(QMouseEvent *e).

[override virtual protected] void QTextBrowser::paintEvent(QPaintEvent *e)

再リンプルメント: (QMouseEvent *e)QTextEdit::paintEvent(QPaintEvent *event)。

[virtual slot] void QTextBrowser::reload()

現在のセットソースをリロードします。

[slot] void QTextBrowser::setSource(const QUrl &url, QTextDocument::ResourceType type = QTextDocument::UnknownResource)

与えられたurl にあるドキュメントを、指定されたtype でロードしようとします。

typeUnknownResource (デフォルト) の場合、ドキュメントタイプが検出されます: つまり、 url が.md,.mkd または.markdown の拡張子で終わっている場合、ドキュメントはQTextDocument::setMarkdown() を介してロードされます; そうでない場合はQTextDocument::setHtml() を介してロードされます。この検出は、type を明示的に指定することで回避できます。

注: source プロパティのセッター関数。

source()も参照

[signal] void QTextBrowser::sourceChanged(const QUrl &src)

このシグナルは、ソースが変更されたときに出力されます。src が新しいソースです。

ソースの変更は、setSource()、forward()、backward()、home() を呼び出したとき、またはユーザーがリンクをクリックしたり、同等のキーシーケンスを押したりしたときに、プログラム的に発生します。

本ドキュメントに含まれる文書の著作権は、それぞれの所有者に帰属します。 本書で提供されるドキュメントは、Free Software Foundation が発行したGNU Free Documentation License version 1.3に基づいてライセンスされています。 Qtおよびそれぞれのロゴは、フィンランドおよびその他の国におけるThe Qt Company Ltd.の 商標です。その他すべての商標は、それぞれの所有者に帰属します。