1 /* 2 * Copyright 2012 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 #ifndef SkPathOpsRect_DEFINED 8 #define SkPathOpsRect_DEFINED 9 10 #include "SkPathOpsPoint.h" 11 12 class SkTCurve; 13 14 struct SkDRect { 15 double fLeft, fTop, fRight, fBottom; 16 17 void add(const SkDPoint& pt) { 18 fLeft = SkTMin(fLeft, pt.fX); 19 fTop = SkTMin(fTop, pt.fY); 20 fRight = SkTMax(fRight, pt.fX); 21 fBottom = SkTMax(fBottom, pt.fY); 22 } 23 24 bool contains(const SkDPoint& pt) const { 25 return approximately_between(fLeft, pt.fX, fRight) 26 && approximately_between(fTop, pt.fY, fBottom); 27 } 28 29 void debugInit(); 30 31 bool intersects(const SkDRect& r) const { 32 SkASSERT(fLeft <= fRight); 33 SkASSERT(fTop <= fBottom); 34 SkASSERT(r.fLeft <= r.fRight); 35 SkASSERT(r.fTop <= r.fBottom); 36 return r.fLeft <= fRight && fLeft <= r.fRight && r.fTop <= fBottom && fTop <= r.fBottom; 37 } 38 39 void set(const SkDPoint& pt) { 40 fLeft = fRight = pt.fX; 41 fTop = fBottom = pt.fY; 42 } 43 44 double width() const { 45 return fRight - fLeft; 46 } 47 48 double height() const { 49 return fBottom - fTop; 50 } 51 52 void setBounds(const SkDConic& curve) { 53 setBounds(curve, curve, 0, 1); 54 } 55 56 void setBounds(const SkDConic& curve, const SkDConic& sub, double tStart, double tEnd); 57 58 void setBounds(const SkDCubic& curve) { 59 setBounds(curve, curve, 0, 1); 60 } 61 62 void setBounds(const SkDCubic& curve, const SkDCubic& sub, double tStart, double tEnd); 63 64 void setBounds(const SkDQuad& curve) { 65 setBounds(curve, curve, 0, 1); 66 } 67 68 void setBounds(const SkDQuad& curve, const SkDQuad& sub, double tStart, double tEnd); 69 70 void setBounds(const SkTCurve& curve); 71 72 bool valid() const { 73 return fLeft <= fRight && fTop <= fBottom; 74 } 75 }; 76 77 #endif 78