2011-07-28 14:26:00 +00:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright 2006 The Android Open Source Project
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
2008-12-17 15:59:43 +00:00
|
|
|
|
|
|
|
#ifndef SkBlitter_DEFINED
|
|
|
|
#define SkBlitter_DEFINED
|
|
|
|
|
|
|
|
#include "SkBitmap.h"
|
|
|
|
#include "SkMatrix.h"
|
|
|
|
#include "SkPaint.h"
|
|
|
|
#include "SkRefCnt.h"
|
|
|
|
#include "SkRegion.h"
|
|
|
|
#include "SkMask.h"
|
|
|
|
|
|
|
|
class SkBlitter {
|
|
|
|
public:
|
|
|
|
virtual ~SkBlitter();
|
|
|
|
|
|
|
|
virtual void blitH(int x, int y, int width);
|
2011-06-15 16:50:27 +00:00
|
|
|
virtual void blitAntiH(int x, int y, const SkAlpha* antialias,
|
|
|
|
const int16_t* runs);
|
2008-12-17 15:59:43 +00:00
|
|
|
virtual void blitV(int x, int y, int height, SkAlpha alpha);
|
|
|
|
virtual void blitRect(int x, int y, int width, int height);
|
|
|
|
virtual void blitMask(const SkMask&, const SkIRect& clip);
|
|
|
|
|
|
|
|
/* If the blitter just sets a single value for each pixel, return the
|
|
|
|
bitmap it draws into, and assign value. If not, return NULL and ignore
|
|
|
|
the value parameter.
|
|
|
|
*/
|
|
|
|
virtual const SkBitmap* justAnOpaqueColor(uint32_t* value);
|
|
|
|
|
|
|
|
// not virtual, just helpers
|
|
|
|
void blitMaskRegion(const SkMask& mask, const SkRegion& clip);
|
|
|
|
void blitRectRegion(const SkIRect& rect, const SkRegion& clip);
|
|
|
|
void blitRegion(const SkRegion& clip);
|
|
|
|
|
|
|
|
// factories
|
|
|
|
static SkBlitter* Choose(const SkBitmap& device,
|
|
|
|
const SkMatrix& matrix,
|
|
|
|
const SkPaint& paint) {
|
|
|
|
return Choose(device, matrix, paint, NULL, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static SkBlitter* Choose(const SkBitmap& device,
|
|
|
|
const SkMatrix& matrix,
|
|
|
|
const SkPaint& paint,
|
|
|
|
void* storage, size_t storageSize);
|
|
|
|
|
|
|
|
static SkBlitter* ChooseSprite(const SkBitmap& device,
|
|
|
|
const SkPaint&,
|
|
|
|
const SkBitmap& src,
|
|
|
|
int left, int top,
|
|
|
|
void* storage, size_t storageSize);
|
|
|
|
|
|
|
|
private:
|
|
|
|
};
|
|
|
|
|
|
|
|
/** This blitter silently never draws anything.
|
|
|
|
*/
|
|
|
|
class SkNullBlitter : public SkBlitter {
|
|
|
|
public:
|
2011-10-03 16:01:10 +00:00
|
|
|
virtual void blitH(int x, int y, int width) SK_OVERRIDE;
|
|
|
|
virtual void blitAntiH(int x, int y, const SkAlpha[],
|
|
|
|
const int16_t runs[]) SK_OVERRIDE;
|
|
|
|
virtual void blitV(int x, int y, int height, SkAlpha alpha) SK_OVERRIDE;
|
|
|
|
virtual void blitRect(int x, int y, int width, int height) SK_OVERRIDE;
|
|
|
|
virtual void blitMask(const SkMask&, const SkIRect& clip) SK_OVERRIDE;
|
|
|
|
virtual const SkBitmap* justAnOpaqueColor(uint32_t* value) SK_OVERRIDE;
|
2008-12-17 15:59:43 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/** Wraps another (real) blitter, and ensures that the real blitter is only
|
|
|
|
called with coordinates that have been clipped by the specified clipRect.
|
|
|
|
This means the caller need not perform the clipping ahead of time.
|
|
|
|
*/
|
|
|
|
class SkRectClipBlitter : public SkBlitter {
|
|
|
|
public:
|
|
|
|
void init(SkBlitter* blitter, const SkIRect& clipRect) {
|
|
|
|
SkASSERT(!clipRect.isEmpty());
|
|
|
|
fBlitter = blitter;
|
|
|
|
fClipRect = clipRect;
|
|
|
|
}
|
|
|
|
|
|
|
|
// overrides
|
2011-10-03 16:01:10 +00:00
|
|
|
virtual void blitH(int x, int y, int width) SK_OVERRIDE;
|
|
|
|
virtual void blitAntiH(int x, int y, const SkAlpha[],
|
|
|
|
const int16_t runs[]) SK_OVERRIDE;
|
|
|
|
virtual void blitV(int x, int y, int height, SkAlpha alpha) SK_OVERRIDE;
|
|
|
|
virtual void blitRect(int x, int y, int width, int height) SK_OVERRIDE;
|
|
|
|
virtual void blitMask(const SkMask&, const SkIRect& clip) SK_OVERRIDE;
|
|
|
|
virtual const SkBitmap* justAnOpaqueColor(uint32_t* value) SK_OVERRIDE;
|
2008-12-17 15:59:43 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
SkBlitter* fBlitter;
|
|
|
|
SkIRect fClipRect;
|
|
|
|
};
|
|
|
|
|
|
|
|
/** Wraps another (real) blitter, and ensures that the real blitter is only
|
|
|
|
called with coordinates that have been clipped by the specified clipRgn.
|
|
|
|
This means the caller need not perform the clipping ahead of time.
|
|
|
|
*/
|
|
|
|
class SkRgnClipBlitter : public SkBlitter {
|
|
|
|
public:
|
|
|
|
void init(SkBlitter* blitter, const SkRegion* clipRgn) {
|
|
|
|
SkASSERT(clipRgn && !clipRgn->isEmpty());
|
|
|
|
fBlitter = blitter;
|
|
|
|
fRgn = clipRgn;
|
|
|
|
}
|
|
|
|
|
|
|
|
// overrides
|
2011-10-03 16:01:10 +00:00
|
|
|
virtual void blitH(int x, int y, int width) SK_OVERRIDE;
|
|
|
|
virtual void blitAntiH(int x, int y, const SkAlpha[],
|
|
|
|
const int16_t runs[]) SK_OVERRIDE;
|
|
|
|
virtual void blitV(int x, int y, int height, SkAlpha alpha) SK_OVERRIDE;
|
|
|
|
virtual void blitRect(int x, int y, int width, int height) SK_OVERRIDE;
|
|
|
|
virtual void blitMask(const SkMask&, const SkIRect& clip) SK_OVERRIDE;
|
|
|
|
virtual const SkBitmap* justAnOpaqueColor(uint32_t* value) SK_OVERRIDE;
|
2008-12-17 15:59:43 +00:00
|
|
|
|
|
|
|
private:
|
|
|
|
SkBlitter* fBlitter;
|
|
|
|
const SkRegion* fRgn;
|
|
|
|
};
|
|
|
|
|
|
|
|
class SkBlitterClipper {
|
|
|
|
public:
|
|
|
|
SkBlitter* apply(SkBlitter* blitter, const SkRegion* clip,
|
|
|
|
const SkIRect* bounds = NULL);
|
|
|
|
|
|
|
|
private:
|
|
|
|
SkNullBlitter fNullBlitter;
|
|
|
|
SkRectClipBlitter fRectBlitter;
|
|
|
|
SkRgnClipBlitter fRgnBlitter;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|