このページでは

C

画像デコーダーの統合

概要

Qt Quick Ultraliteが知らないカスタムフォーマットの画像アセットのために、画像デコーダーは、これらの画像をデコードできるようにする簡単な実装APIを提供します。Qt Quick Ultraliteエンジンは、画像フォーマットに応じて適切なデコーダを自動的に選択します。

画像は、前処理やプロジェクト内での宣言なしにSDカードから読み込むことができます。アセットがFlashに保存されているかSDカードに保存されているかにかかわらず、実装するAPIは1つだけです。

カスタム画像デコーダーは、アセットがユースケースに特化したフォーマットで保存される場合に便利です。デコードは実装者の完全な制御下にあり、デバイスで利用可能なハードウェア・アクセラレーションを利用することができます。

任意の画像フォーマットを読み込むには、初期化段階で画像デコーダーの実装をアプリケーションに登録する必要があります。リソースまたはディスク(file://)からの画像が表示されるたびに、Qt Quick Ultraliteは、その画像がビルトインのアセットフォーマットを持っているかどうかをチェックします。そうでない場合、登録されているすべての画像デコーダが使用され、登録された順に画像がデコードされます。画像をデコードできると報告された最初のデコーダが使用されます。リソースにデコード可能な画像がある場合、Qul::initPlatform()を呼び出す前に、デコーダの登録を行う必要があります。

Qt Quick Ultralite 用の画像デコーダーの実装

カスタム画像デコーダは、Qul::PlatformInterface::ImageDecoder クラスを実装する必要があります。加速ハードウェア JPEG デコーダーの実装例は、imagedecoder の例にあります。

次のコードは、このクラスの実装例を示しています:

class MyDecoder : public Qul::PlatformInterface::ImageDecoder
{
public:
    bool imageInformation(RequestDataCallback &callback,
                          int16_t *width,
                          int16_t *height,
                          Qul::PixelFormat *actualPixelFormat,
                          Qul::PixelFormat optimalOpaquePixelFormat,
                          Qul::PixelFormat optimalAlphaPixelFormat);
    int decodeImage(RequestDataCallback &callback,
                    unsigned char *outbuffer,
                    uint32_t outbufferSize,
                    Qul::PixelFormat pixelFormat,
                    uint32_t requiredBytesPerLine);
}
bool MyDecoder::imageInformation(RequestDataCallback &callback,
                                 int16_t *width,
                                 int16_t *height,
                                 Qul::PixelFormat *actualPixelFormat,
                                 Qul::PixelFormat optimalOpaquePixelFormat,
                                 Qul::PixelFormat optimalAlphaPixelFormat)
{
    unsigned char buffer[1024];
    uint32_t offset 0; // Start from beginning of the file

    callback.read(buffer, offset, 8)

    // Check if this decoder is able to decode the image
    if (buffer[0] != 0x89 || buffer[1] != 0x50 … ) { // PNG format header: 89 50 4E 47 0D 0A 1A 0A
        return false; // Return early when the format is unknown
    }

    // Read more data from the image to determine the size and pixel format.
    callback.read(buffer, offset, sizeof(buffer))
    *width = getImageWidth(buffer);
    *height = getImageHeight(buffer);
    *actualPixelFormat = getOptimalImageFormat(buffer, optimalOpaquePixelFormat, optimalAlphaPixelFormat);

    return true;
}
int MyDecoder::decodeImage(RequestDataCallback &callback,
                           unsigned char *outbuffer,
                           uint32_t outbufferSize,
                           Qul::PixelFormat pixelFormat,
                           uint32_t requiredBytesPerLine)
{
    unsigned char *allocatedBuffer = NULL;

    allocatedBuffer = callback.rawData();
    if (!allocatedBuffer) {
        // The data is not in addressable memory and might need to be fetched
        uint32_t bufferSize = callback.totalAvailableDataSize();
        allocatedBuffer = (unsigned char *) Qul::Platform::qul_malloc(bufferSize);
        callback.readData(allocatedBuffer, 0, bufferSize);
    }

    hardware_decode(allocatedBuffer, bufferSize, outbuffer, outbufferSize);
    Qul::Platform::qul_free(allocatedBuffer);

    return 0;
}

実装された画像デコーダーをQt Quick Ultralite に知らせるには、アプリケーションに登録する必要があります。

static MyDecoder decoder;
Qul::Application::addImageDecoder(&decoder);

特定の Qt ライセンスの下で利用可能です。
詳細をご覧ください。