/*
* Copyright 2012 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkBitmapFactory_DEFINED
#define SkBitmapFactory_DEFINED
class SkBitmap;
class SkData;
/**
* General purpose factory for decoding bitmaps.
*
* Currently only provides a way to decode a bitmap or its dimensions from an SkData. Future plans
* include options to provide a bitmap which caches the pixel data.
*/
class SkBitmapFactory {
public:
enum Constraints {
/**
* Only decode the bounds of the bitmap. No pixels will be allocated.
*/
kDecodeBoundsOnly_Constraint,
/**
* Decode the bounds and pixels of the bitmap.
*/
kDecodePixels_Constraint,
};
/**
* Decodes an SkData into an SkBitmap.
* @param SkBitmap Already created bitmap to encode into.
* @param SkData Encoded SkBitmap data.
* @param constraint Specifications for how to do the decoding.
* @return True on success. If false, passed in SkBitmap is unmodified.
*/
static bool DecodeBitmap(SkBitmap*, const SkData*,
Constraints constraint = kDecodePixels_Constraint);
};
#endif // SkBitmapFactory_DEFINED