Image QML Type

画像を表示します。もっと見る...

Import Statement: import QtQuick
Inherits:

Item

Inherited By:

AnimatedImage

プロパティ

詳細説明

Imageタイプは画像を表示します。

画像のソースは、source プロパティを使用して URL として指定します。画像は、PNG や JPEG のようなビットマップ形式や SVG のようなベクターグラフィック形式など、Qt がサポートする標準画像形式のいずれかで提供することができます。アニメーション画像を表示する必要がある場合は、AnimatedSprite またはAnimatedImage を使用してください。

widthheight プロパティが指定されていない場合、イメージは自動的に読み込まれたイメージのサイズを使用します。デフォルトでは、アイテムの幅と高さを指定すると、画像はそのサイズに拡大縮小されます。この動作は、fillMode プロパティを設定することで変更することができ、代わりに画像を引き伸ばして並べることができます。

"@nx" high DPI syntax を指定することも可能です。

使用例

次の例は、Imageタイプの最も簡単な使い方です。

import QtQuick

Image {
    source: "pics/qtlogo.png"
}


圧縮テクスチャファイル

基礎となるグラフィックスAPIの実装がランタイムでサポートしている場合、イメージは圧縮テクスチャファイルで提供することもできます。内容は単純なRGB(A)フォーマットの2Dテクスチャでなければなりません。サポートされる圧縮スキームは、基盤となるドライバとGPUによってのみ制限されます。以下のコンテナファイル形式がサポートされています:

  • PKM (Qt 5.10 以降)
  • KTX (Qt 5.11 以降)
  • ASTC (Qt 5.13 以降)

注意: テクスチャファイル内の画像の意図された垂直方向は、一般的によく定義されていません。テクスチャ圧縮ツールによって、いつ入力画像の垂直反転を行うかのデフォルトやオプションが異なります。テクスチャファイルの画像が上下逆さまに表示される場合、アセットコンディショニングプロセスで反転を切り替える必要があるかもしれません。または、transform プロパティで適切な変換を適用するか、mirrorVertically プロパティを設定することで、Image 要素自体を反転させることもできます:

transform: [ Translate { y: -myImage.height }, Scale { yScale: -1 } ]

または

mirrorVertically: true

注意: 半透明のオリジナル画像を Qt Quick で正しく表示するには、テクスチャ圧縮の前にアルファの事前乗算が必要です。これは、次の ImageMagick コマンドラインで実行できます:

convert foo.png \( +clone -alpha Extract \) -channel RGB -compose Multiply -composite foo_pm.png

KTX などのコンテナ形式と、コンテナファイルに格納されている実際のテクスチャデータの形式を混同しないでください。たとえば、KTX ファイルの読み込みは、実行時に使用される GPU ドライバに関係なく、すべてのプラットフォームでサポートされています。しかし、これはファイル内のデータで使用される圧縮テクスチャフォーマットがランタイムでサポートされることを保証するものではありません。例えば、KTX ファイルがETC2 RGBA8 というフォーマットで圧縮されたデータを含み、実行時に使用される 3D グラフィックス API 実装がETC2 圧縮テクスチャをサポートしていない場合、Image 項目は何も表示しません。

注意: 圧縮テクスチャフォーマットのサポートは Qt の管理下にはなく、圧縮テクスチャデータがターゲッ ト環境に適したフォーマットで提供されるかどうかは、アプリケーションやデバイスの開発者次第 です。

圧縮フォーマットのサポートがプラットフォームに特有であると思わないでください。また、特定のプラットフォームで使用されているドライバや3D API実装に固有である可能性もあります。実際には、同じプラットフォーム(たとえば、Windows)上の異なる3DグラフィックスAPI(たとえば、VulkanとOpenGL)の実装は、同じハードウェアのための同じベンダーから、圧縮されたテクスチャフォーマットの異なるセットを提供するかもしれません。

デスクトップ環境(Windows、macOS、Linux)だけをターゲットにする場合、一般的な推奨は、DXTn/BCn フォーマットの使用を検討することです。これらのプラットフォーム上のDirect 3D、Vulkan、OpenGL、およびMetalの実装の中で、これらのフォーマットが最も広くサポートされている傾向があるからです。対照的に、モバイルデバイスや組み込みデバイスをターゲットとする場合、ETC2 またはASTC フォーマットがより良い選択となる可能性が高いです。なぜなら、これらのフォーマットは通常、これらのハードウェア上の OpenGL ES 実装によってサポートされているからです。

デスクトップ、モバイル、および組み込みハードウェアを横断して実行する予定のアプリケーションは、圧縮されたテクスチャの使用を慎重に計画し、設計する必要があります。従って、アプリケーションはプラットフォームに基づいて分岐し、そこで適切なフォーマットで圧縮テクスチャを使用するか、場合によっては圧縮テクスチャの使用をスキップする必要があるでしょう。

ファイル拡張子の自動検出

source URL が存在しないローカルファイルまたはリソースを示している場合、Image 要素はファイル拡張子の自動検出を試みます。サポートされている画像ファイル拡張子のいずれかをsource URL に追加して既存のファイルを見つけることができれば、そのファイルが読み込まれます。

ファイル検索では、まず圧縮されたテクスチャコンテナファイル拡張子の検索を試みます。検索に失敗すると、conventional image file types のファイル拡張子で検索を試みます:

// Assuming the "pics" directory contains the following files:
//   dog.jpg
//   cat.png
//   cat.pkm

Image {
    source: "pics/cat.png"     // loads cat.png
}

Image {
    source: "pics/dog"         // loads dog.jpg
}

Image {
    source: "pics/cat"         // normally loads cat.pkm, but if no OpenGL, loads cat.png instead.
}

この機能により、異なるターゲットプラットフォーム上で、異なるタイプのイ メージアセットファイルのデプロイが容易になります。これは、アプリケーションのパフォーマンスを調整したり、異なるグラフィックハードウェアに適応させたりするのに便利です。

この機能は Qt 5.11 で導入されました。

パフォーマンス

デフォルトでは、ローカルで利用可能なイメージは即座にロードされ、ロードが完了するまでユーザーインターフェースはブロックされます。大きな画像を読み込む場合は、asynchronous プロパティを有効にして、優先順位の低いスレッドで画像を読み込む方が望ましい場合があります。

画像がローカル・リソースではなくネットワークから取得された場合は、自動的に非同期でロードされ、progressstatus プロパティが適宜更新されます。

イメージは内部でキャッシュされ共有されるため、複数のイメージアイテムが同じsource を持つ場合、イメージのコピーは1つだけ読み込まれます。

注意: QMLのユーザーインターフェースにおいて、画像はしばしば最大のメモリ使用量となります。ユーザインタフェースの一部を構成しない画像は、sourceSize プロパティによってそのサイズを制限することが推奨されます。これは、外部ソースから読み込んだり、ユーザが提供したりするコンテンツでは特に重要です。

Qt Quick Examples - Image Elements,QQuickImageProvider,QImageReader::setAutoDetectImageFormat()も参照してください

プロパティの説明

paintedHeight : real [read-only]

paintedWidth : real [read-only]

これらのプロパティは、実際に描画される画像のサイズを保持します。ほとんどの場合、widthheight と同じですが、Image.PreserveAspectFitImage.PreserveAspectCrop を使用する場合、paintedWidthpaintedHeight は、Image アイテムのwidthheight よりも小さくなったり大きくなったりします。


horizontalAlignment : enumeration

verticalAlignment : enumeration

画像の水平方向と垂直方向の配置を設定します。デフォルトでは、画像は中央揃えになります。

horizontalAlignment の有効な値はImage.AlignLeftImage.AlignRightImage.AlignHCenter です。verticalAlignment の有効な値はImage.AlignTopImage.AlignBottomImage.AlignVCenter です。


currentFrame : int

frameCount : int [read-only]

currentFrame は現在表示 さ れてい る フ レーム。デフォルトは 。画像に複数のフレームが含まれている場合は、 と の間の数値を設定することで、別のフレームを表示することができます。0 0 frameCount - 1

frameCount は画像のフレーム数です。たいていの画像にはフレームが1つしかありません。


asynchronous : bool

ローカルファイルシステム上の画像を別スレッドで非同期に読み込むかどうかを指定します。デフォルト値はfalseで、画像が読み込まれる間ユーザーインターフェイスのスレッドがブロックされます。asynchronous を true に設定すると、画像がすぐに表示されることよりも、レスポンシブなユーザインタフェースを維持する方が望ましい場合に便利です。

このプロパティは、ローカルファイルシステムから読み込まれた画像に対してのみ有効であることに注意してください。ネットワークリソース(HTTPなど)を介して読み込まれた画像は、常に非同期で読み込まれます。


autoTransform : bool

このプロパティは、EXIFオリエンテーションなどの画像変換メタデータを画像に自動的に適用するかどうかを保持します。

デフォルトでは、このプロパティは false に設定されています。


cache : bool

画像をキャッシュするかどうかを指定します。デフォルト値はtrueです。cache を false に設定すると、大きな画像を扱うときに便利です。小さな 'ui 要素' 画像を犠牲にしてキャッシュされないようにするためです。


fillMode : enumeration

このプロパティを設定することで、ソース画像のサイズがアイテムと異なる場合の動作を定義できます。

定数説明
Image.Stretch画像がフィットするように拡大縮小される
Image.PreserveAspectFit画像は切り抜きなしでフィットするように一様に拡大縮小されます。
Image.PreserveAspectCrop画像は、必要に応じてトリミングされながら、均等に拡大縮小されます。
Image.Tile画像を水平方向と垂直方向に複製します。
Image.TileVertically画像が水平方向に引き伸ばされ、垂直方向にタイル状に並べられる
Image.TileHorizontally画像が垂直方向に引き伸ばされ、水平方向にタイル状に配置される。
Image.Pad画像は変換されない

ストレッチ(デフォルト)
Image {
    width: 130; height: 100
    source: "qtlogo.png"
}

PreserveAspectFit
Image {
    width: 130; height: 100
    fillMode: Image.PreserveAspectFit
    source: "qtlogo.png"
}

プリザーブアスペクトクロップ
Image {
    width: 130; height: 100
    fillMode: Image.PreserveAspectCrop
    source: "qtlogo.png"
    clip: true
}

タイル
Image {
    width: 120; height: 120
    fillMode: Image.Tile
    horizontalAlignment: Image.AlignLeft
    verticalAlignment: Image.AlignTop
    source: "qtlogo.png"
}

タイル垂直
Image {
    width: 120; height: 120
    fillMode: Image.TileVertically
    verticalAlignment: Image.AlignTop
    source: "qtlogo.png"
}

水平タイル
Image {
    width: 120; height: 120
    fillMode: Image.TileHorizontally
    verticalAlignment: Image.AlignLeft
    source: "qtlogo.png"
}

デフォルトでは、clipfalse であることに注意してください。これは、fillMode がPreserveAspectCrop に設定されていても、アイテムがその境界矩形の外側に描画される可能性があることを意味します。

Qt Quick Examples - Image Elementsも参照してください


mipmap : bool

このプロパティは、拡大縮小や変形時に画像がミップマップフィルタリングを使用するかどうかを保持します。

ミップマップフィルタリングは、平滑化よりも縮小時の視覚的品質が向上しますが、(画像の初期化時とレンダリング時の両方で)パフォーマンスが犠牲になる可能性があります。

デフォルトでは、このプロパティは false に設定されています。

smoothも参照してください


mirror : bool

このプロパティは、画像を水平方向に反転させる(事実上ミラー画像を表示する)かどうかを保持します。

デフォルト値は false です。


mirrorVertically : bool [since 6.2]

このプロパティは、画像を垂直方向に反転させる(実質的にミラー画像を表示する)かどうかを保持します。

デフォルト値は false です。

このプロパティは Qt 6.2 で導入されました。


progress : real [read-only]

このプロパティは、0.0 (何もロードされていない) から 1.0 (完了) までの、画像のロードの進行状況を保持します。

statusも参照してください


retainWhileLoading : bool [since 6.8]

このプロパティは、source プロパティが変更され、読み込みが非同期で行われる場合の動作を定義します。これは、asynchronous プロパティがtrue に設定されている場合、または画像がローカル・ファイル・システム上にない場合です。

retainWhileLoadingfalse (デフォルト)の場合、古い画像は即座に破棄され、新しい画像のロード中にコンポーネントはクリアされます。true に設定すると、古い画像は保持され、新しい画像の準備ができるまで表示されたままになります。

このプロパティを有効にすると、新しい画像の読み込みに時間がかかる場合にちらつきを避けることができます。その代償として、新しい画像がロードされている間、二重のバッファリングのためにメモリが余分に使用されます。

このプロパティは Qt 6.8 で導入されました。


smooth : bool

このプロパティは、拡大縮小や変形時に画像をスムースフィルタリングするかどうかを保持します。スムースフィルタリングはより良いビジュアル品質を提供しますが、ハードウェアによっては遅くなる場合があります。画像が自然なサイズで表示される場合、このプロパティは視覚的にもパフォーマンス的にも影響を与えません。

デフォルトでは、このプロパティはtrueに設定されています。

mipmapも参照してください


source : url

Image は、Qt でサポートされている URL スキームから読み込まれる、Qt でサポートされているすべての画像フォーマットを扱うことができます。

URL は、絶対 URL でも、コンポーネントの URL からの相対 URL でもかまいません。

QQuickImageProviderCompressed Texture FilesAutomatic Detection of File Extensionも参照して ください。


sourceClipRect : rect

このプロパティが設定されている場合、ロードされるソース画像の矩形領域が保持されます。

sourceClipRectsourceSize プロパティと連動し、画像の一部だけを読み込む必要がある場合にシステムリソースを節約します。

Rectangle {
    width: ...
    height: ...

    Image {
       anchors.fill: parent
       source: "reallyBigImage.svg"
       sourceSize.width: 1024
       sourceSize.height: 1024
       sourceClipRect: Qt.rect(100, 100, 512, 512)
    }
}

上の例では、まず概念的に SVG グラフィックを 1024x1024 に拡大縮小し、次に上端と左端から 100 ピクセルの位置から 512x512 ピクセルの関心領域を切り出している。このようにsourceSize がスケールを決定するが、実際の出力画像は 512x512 ピクセルである。

画像フォーマットによっては、指定した領域だけをレンダリングすることでCPU時間を節約できるものもあります。また、画像全体を最初に読み込んでから、指定した領域に切り抜く必要があるものもある。

このプロパティをクリアして画像全体を再読み込みするには、sourceClipRectundefined に設定します。

注意 :このプロパティを動的に変更すると、画像ソースがディスクキャッシュにない場合、ネットワークからも再読み込みされる可能性があります。

注意: サブピクセルクリッピングはサポートされていません:与えられた矩形はQImageReader::setScaledClipRect() に渡されます。


sourceSize : size

このプロパティは、フルフレーム画像のスケーリングされた幅と高さを保持します。

画像の描画をスケーリングするwidthheight プロパティとは異なり、このプロパティは、大きな画像が必要以上にメモリを使用しないように、読み込まれた画像に対して保存されるピクセルの最大数を設定します。例えば、イメージのwidthheight の値に関係なく、メモリ上のイメージが 1024x1024 ピクセルより大きくならないようにします:

Rectangle {
    width: ...
    height: ...

    Image {
       anchors.fill: parent
       source: "reallyBigImage.jpg"
       sourceSize.width: 1024
       sourceSize.height: 1024
    }
}

画像の実寸が sourceSize よ り 大 き い と き は、 画像は縮小 さ れます。サイズの1つの次元だけが0より大きく設定されている場合、もう1つの次元は、ソース画像のアスペクト比を維持するように比例して設定されます。(fillMode はこれとは無関係です)。

sourceSize.widthとsourceSize.heightの両方が設定されている場合、画像は指定されたサイズ内に収まるように縮小され(PreserveAspectCropまたはPreserveAspectFitが使用されていない限り、切り抜き/フィットに最適なサイズに合わせて縮小されます)、画像の縦横比が維持されます。拡大縮小後の画像の実際のサイズは、Item::implicitWidthItem::implicitHeight で知ることができます。

ソースが本質的にスケーラブルな画像(SVGなど)の場合、このプロパティは本質的なサイズに関係なく、読み込まれる画像のサイズを決定します。SVGのレンダリングは画像に比べて遅いので、このプロパティを動的に変更することは避けてください。

ソースが非拡張画像(例えば JPEG)の場合、読み込まれる画像はこのプロパティが指定するサイズより大きくはならない。いくつかのフォーマット(現在のところ JPEG のみ)では、画像全体が実際にメモリに読み込まれることはない。

sourceClipRect プロパティも設定されている場合、sourceSize がスケールを決定しますが、クリップ矩形のサイズにクリップされます。

sourceSize をundefined に設定することで、画像の自然なサイズにクリアできます。

注意: このプロパティを動的に変更すると、画像ソースがディスクキャッシュにない場合、ネットワークから再読み込みされる可能性があります。

Qt Quick Examples - Pointer Handlersも参照してください


status : enumeration [read-only]

このプロパティは、画像のロード状態を保持します。以下のいずれかになります:

定数説明
Image.Null画像が設定されていない
Image.Ready画像が読み込まれた
Image.Loading画像は現在ロード中です。
Image.Error画像の読み込み中にエラーが発生した

このステータスを使用して、最新情報を提供するか、ステータスの変更に何らかの形で応答してください。例えば、次のようなことができます:

  • 状態変化を引き起こす:
    State { name: 'loaded'; when: image.status == Image.Ready }
  • onStatusChanged シグナルハンドラを実装する:
    Image {
        id: image
        onStatusChanged: if (image.status == Image.Ready) console.log('Loaded')
    }
  • ステータス値にバインドする:
    Text { text: image.status == Image.Ready ? 'Loaded' : 'Not loaded' }

progressも参照して ください。


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