Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 /* | |
| 2 * Copyright 2014 Google Inc. | |
| 3 * | |
| 4 * Use of this source code is governed by a BSD-style license that can be | |
| 5 * found in the LICENSE file. | |
| 6 */ | |
| 7 | |
| 8 #ifndef SkTextMapState_DEFINED | |
| 9 #define SkTextMapState_DEFINED | |
| 10 | |
| 11 #include "SkPoint.h" | |
| 12 #include "SkMatrix.h" | |
| 13 | |
| 14 class SkTextMapState { | |
|
jvanverth1
2014/06/12 14:33:00
I think this should be called SkTextMapStateProc,
| |
| 15 public: | |
| 16 SkTextMapState(const SkMatrix& matrix, SkScalar y, int scalarsPerPosition) | |
| 17 : fMatrix(matrix) | |
| 18 , fProc(matrix.getMapXYProc()) | |
| 19 , fY(y) | |
| 20 , fScaleX(fMatrix.getScaleX()) | |
| 21 , fTransX(fMatrix.getTranslateX()) { | |
| 22 SkASSERT(1 == scalarsPerPosition || 2 == scalarsPerPosition); | |
| 23 if (1 == scalarsPerPosition) { | |
| 24 unsigned mtype = fMatrix.getType(); | |
| 25 if (mtype & (SkMatrix::kAffine_Mask | SkMatrix::kPerspective_Mask)) { | |
| 26 fMapCase = kX; | |
| 27 } else { | |
| 28 fY = SkScalarMul(y, fMatrix.getScaleY()) + | |
| 29 fMatrix.getTranslateY(); | |
| 30 if (mtype & SkMatrix::kScale_Mask) { | |
| 31 fMapCase = kOnlyScaleX; | |
| 32 } else { | |
| 33 fMapCase = kOnlyTransX; | |
| 34 } | |
| 35 } | |
| 36 } else { | |
| 37 fMapCase = kXY; | |
| 38 } | |
| 39 } | |
| 40 | |
| 41 void operator()(const SkScalar pos[], SkPoint* loc) const; | |
| 42 | |
| 43 private: | |
| 44 const SkMatrix& fMatrix; | |
| 45 enum { | |
| 46 kXY, | |
| 47 kOnlyScaleX, | |
| 48 kOnlyTransX, | |
| 49 kX | |
| 50 } fMapCase; | |
| 51 const SkMatrix::MapXYProc fProc; | |
| 52 SkScalar fY; // Ignored by kXY case. | |
| 53 SkScalar fScaleX, fTransX; // These are only used by Only... cases. | |
| 54 }; | |
| 55 | |
| 56 inline void SkTextMapState::operator()(const SkScalar pos[], SkPoint* loc) const { | |
| 57 switch(fMapCase) { | |
| 58 case kXY: | |
| 59 fProc(fMatrix, pos[0], pos[1], loc); | |
| 60 break; | |
| 61 case kOnlyScaleX: | |
| 62 loc->set(SkScalarMul(fScaleX, *pos) + fTransX, fY); | |
| 63 break; | |
| 64 case kOnlyTransX: | |
| 65 loc->set(*pos + fTransX, fY); | |
| 66 break; | |
| 67 default: | |
| 68 SkASSERT(false); | |
| 69 case kX: | |
| 70 fProc(fMatrix, *pos, fY, loc); | |
| 71 break; | |
| 72 } | |
| 73 } | |
| 74 | |
| 75 #endif | |
| 76 | |
| OLD | NEW |