diff options
author | reed@android.com <reed@android.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2009-08-20 21:29:45 +0000 |
---|---|---|
committer | reed@android.com <reed@android.com@2bbb7eff-a529-9590-31e7-b0007b416f81> | 2009-08-20 21:29:45 +0000 |
commit | 755dd4773dad70d5fbe3f8bb091eaf268ea752c7 (patch) | |
tree | 7698065909cd29615198c39ca99e83bbe95525f5 | |
parent | 8430cd15bc6b826fa5f1661c55f0a7bab9770a7c (diff) |
respect dither setting in index8->565 sprite case
git-svn-id: http://skia.googlecode.com/svn/trunk@328 2bbb7eff-a529-9590-31e7-b0007b416f81
-rw-r--r-- | samplecode/SampleDitherBitmap.cpp | 80 | ||||
-rw-r--r-- | src/core/SkSpriteBlitter_RGB16.cpp | 4 |
2 files changed, 84 insertions, 0 deletions
diff --git a/samplecode/SampleDitherBitmap.cpp b/samplecode/SampleDitherBitmap.cpp new file mode 100644 index 0000000000..bd604cf84c --- /dev/null +++ b/samplecode/SampleDitherBitmap.cpp @@ -0,0 +1,80 @@ +#include "SampleCode.h" +#include "SkColorPriv.h" +#include "SkView.h" +#include "SkCanvas.h" +#include "SkUtils.h" + +static SkBitmap make_bitmap() { + SkBitmap bm; + SkColorTable* ctable = new SkColorTable(256); + + SkPMColor* c = ctable->lockColors(); + for (int i = 0; i < 256; i++) { + c[i] = SkPackARGB32(0xFF, 0, 0, i); + } + ctable->unlockColors(true); + bm.setConfig(SkBitmap::kIndex8_Config, 256, 32); + bm.allocPixels(ctable); + ctable->unref(); + + bm.lockPixels(); + for (int y = 0; y < bm.height(); y++) { + uint8_t* p = bm.getAddr8(0, y); + for (int x = 0; x < 256; x++) { + p[x] = x; + } + } + bm.unlockPixels(); + return bm; +} + +class DitherBitmapView : public SkView { + SkBitmap fBM8; + SkBitmap fBM32; +public: + DitherBitmapView() { + fBM8 = make_bitmap(); + fBM8.copyTo(&fBM32, SkBitmap::kARGB_8888_Config); + } + +protected: + // overrides from SkEventSink + virtual bool onQuery(SkEvent* evt) { + if (SampleCode::TitleQ(*evt)) { + SampleCode::TitleR(evt, "DitherBitmap"); + return true; + } + return this->INHERITED::onQuery(evt); + } + + void drawBG(SkCanvas* canvas) { + canvas->drawColor(0xFFDDDDDD); + } + + static void draw2(SkCanvas* canvas, const SkBitmap& bm) { + SkPaint paint; + + canvas->drawBitmap(bm, 0, 0, &paint); + paint.setDither(true); + canvas->drawBitmap(bm, 0, SkIntToScalar(bm.height() + 10), &paint); + } + + virtual void onDraw(SkCanvas* canvas) { + drawBG(canvas); + + canvas->translate(SkIntToScalar(20), SkIntToScalar(20)); + + draw2(canvas, fBM8); + canvas->translate(0, SkIntToScalar(fBM8.height() *3)); + draw2(canvas, fBM32); + } + +private: + typedef SkView INHERITED; +}; + +////////////////////////////////////////////////////////////////////////////// + +static SkView* MyFactory() { return new DitherBitmapView; } +static SkViewRegister reg(MyFactory); + diff --git a/src/core/SkSpriteBlitter_RGB16.cpp b/src/core/SkSpriteBlitter_RGB16.cpp index 3ccc03b78a..4dcd73dd09 100644 --- a/src/core/SkSpriteBlitter_RGB16.cpp +++ b/src/core/SkSpriteBlitter_RGB16.cpp @@ -356,6 +356,10 @@ SkSpriteBlitter* SkSpriteBlitter::ChooseD16(const SkBitmap& source, } break; case SkBitmap::kIndex8_Config: + if (paint.isDither()) { + // we don't support dither yet in these special cases + break; + } if (source.isOpaque()) { if (255 == alpha) { SK_PLACEMENT_NEW_ARGS(blitter, Sprite_D16_SIndex8_Opaque, |