Home | History | Annotate | Download | only in core
      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 
      8 #ifndef SkStrokeRec_DEFINED
      9 #define SkStrokeRec_DEFINED
     10 
     11 #include "SkPaint.h"
     12 
     13 class SkPath;
     14 
     15 class SkStrokeRec {
     16 public:
     17     enum InitStyle {
     18         kHairline_InitStyle,
     19         kFill_InitStyle
     20     };
     21     SkStrokeRec(InitStyle style);
     22 
     23     SkStrokeRec(const SkStrokeRec&);
     24     explicit SkStrokeRec(const SkPaint&);
     25 
     26     enum Style {
     27         kHairline_Style,
     28         kFill_Style,
     29         kStroke_Style,
     30         kStrokeAndFill_Style
     31     };
     32 
     33     Style getStyle() const;
     34     SkScalar getWidth() const { return fWidth; }
     35     SkScalar getMiter() const { return fMiterLimit; }
     36     SkPaint::Cap getCap() const { return fCap; }
     37     SkPaint::Join getJoin() const { return fJoin; }
     38 
     39     bool isHairlineStyle() const {
     40         return kHairline_Style == this->getStyle();
     41     }
     42 
     43     bool isFillStyle() const {
     44         return kFill_Style == this->getStyle();
     45     }
     46 
     47     void setFillStyle();
     48     void setHairlineStyle();
     49     /**
     50      *  Specify the strokewidth, and optionally if you want stroke + fill.
     51      *  Note, if width==0, then this request is taken to mean:
     52      *      strokeAndFill==true -> new style will be Fill
     53      *      strokeAndFill==false -> new style will be Hairline
     54      */
     55     void setStrokeStyle(SkScalar width, bool strokeAndFill = false);
     56 
     57     void setStrokeParams(SkPaint::Cap cap, SkPaint::Join join, SkScalar miterLimit) {
     58         fCap = cap;
     59         fJoin = join;
     60         fMiterLimit = miterLimit;
     61     }
     62 
     63     /**
     64      *  Returns true if this specifes any thick stroking, i.e. applyToPath()
     65      *  will return true.
     66      */
     67     bool needToApply() const {
     68         Style style = this->getStyle();
     69         return (kStroke_Style == style) || (kStrokeAndFill_Style == style);
     70     }
     71 
     72     /**
     73      *  Apply these stroke parameters to the src path, returning the result
     74      *  in dst.
     75      *
     76      *  If there was no change (i.e. style == hairline or fill) this returns
     77      *  false and dst is unchanged. Otherwise returns true and the result is
     78      *  stored in dst.
     79      *
     80      *  src and dst may be the same path.
     81      */
     82     bool applyToPath(SkPath* dst, const SkPath& src) const;
     83 
     84     bool operator==(const SkStrokeRec& other) const {
     85             return fWidth == other.fWidth &&
     86                    fMiterLimit == other.fMiterLimit &&
     87                    fCap == other.fCap &&
     88                    fJoin == other.fJoin &&
     89                    fStrokeAndFill == other.fStrokeAndFill;
     90     }
     91 
     92 private:
     93     SkScalar        fWidth;
     94     SkScalar        fMiterLimit;
     95     SkPaint::Cap    fCap;
     96     SkPaint::Join   fJoin;
     97     bool            fStrokeAndFill;
     98 };
     99 
    100 #endif
    101