blob: d1b6658d073bac5c3603f806e5f36e441bbf319e [file] [log] [blame]
/*
* Copyright 2013 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkMatrixUtils_DEFINED
#define SkMatrixUtils_DEFINED
#include "SkMatrix.h"
/**
* Number of subpixel bits used in skia's bilerp.
* See SkBitmapProcState_procs.h and SkBitmapProcState_filter.h
*/
#define kSkSubPixelBitsForBilerp 4
/**
* Given a matrix and width/height, return true if the computed dst-rect would
* align such that there is a 1-to-1 coorspondence between src and dst pixels.
* This can be called by drawing code to see if drawBitmap can be turned into
* drawSprite (which is faster).
*
* The src-rect is defined to be { 0, 0, width, height }
*
* The "closeness" test is based on the subpixelBits parameter. Pass 0 for
* round-to-nearest behavior (e.g. nearest neighbor sampling). Pass the number
* of subpixel-bits to simulate filtering.
*/
bool SkTreatAsSprite(const SkMatrix&, int width, int height,
unsigned subpixelBits);
/**
* Calls SkTreatAsSprite() with default subpixelBits value to match Skia's
* filter-bitmap implementation (i.e. kSkSubPixelBitsForBilerp).
*/
static inline bool SkTreatAsSpriteFilter(const SkMatrix& matrix,
int width, int height) {
return SkTreatAsSprite(matrix, width, height, kSkSubPixelBitsForBilerp);
}
/** Decomposes the upper-left 2x2 of the matrix into a rotation (represented by
the cosine and sine of the rotation angle), followed by a non-uniform scale,
followed by another rotation. If there is a reflection, one of the scale
factors will be negative.
Returns true if successful. Returns false if the matrix is degenerate.
*/
bool SkDecomposeUpper2x2(const SkMatrix& matrix,
SkPoint* rotation1,
SkPoint* scale,
SkPoint* rotation2);
#endif