Home | History | Annotate | Download | only in core
      1 /*
      2  * Copyright 2011 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 SkBlitMask_DEFINED
      9 #define SkBlitMask_DEFINED
     10 
     11 #include "SkBitmap.h"
     12 #include "SkColor.h"
     13 #include "SkMask.h"
     14 
     15 class SkBlitMask {
     16 public:
     17     /**
     18      *  Returns true if the device config and mask format were supported.
     19      *  else return false (nothing was drawn)
     20      */
     21     static bool BlitColor(const SkBitmap& device, const SkMask& mask,
     22                           const SkIRect& clip, SkColor color);
     23 
     24     /**
     25      *  Function pointer that blits the mask into a device (dst) colorized
     26      *  by color. The number of pixels to blit is specified by width and height,
     27      *  but each scanline is offset by dstRB (rowbytes) and srcRB respectively.
     28      */
     29     typedef void (*ColorProc)(void* dst, size_t dstRB,
     30                               const void* mask, size_t maskRB,
     31                               SkColor color, int width, int height);
     32 
     33     /**
     34      *  Function pointer that blits a row of mask(lcd16) into a row of dst
     35      *  colorized by a single color. The number of pixels to blit is specified
     36      *  by width.
     37      */
     38     typedef void (*BlitLCD16RowProc)(SkPMColor dst[], const uint16_t src[],
     39                                      SkColor color, int width,
     40                                      SkPMColor opaqueDst);
     41 
     42     /**
     43      *  Function pointer that blits a row of src colors through a row of a mask
     44      *  onto a row of dst colors. The RowFactory that returns this function ptr
     45      *  will have been told the formats for the mask and the dst.
     46      */
     47     typedef void (*RowProc)(void* dst, const void* mask,
     48                             const SkPMColor* src, int width);
     49 
     50     /**
     51      *  Public entry-point to return a blitmask ColorProc.
     52      *  May return NULL if config or format are not supported.
     53      */
     54     static ColorProc ColorFactory(SkBitmap::Config, SkMask::Format, SkColor);
     55 
     56     /**
     57      *  Return either platform specific optimized blitmask ColorProc,
     58      *  or NULL if no optimized routine is available.
     59      */
     60     static ColorProc PlatformColorProcs(SkBitmap::Config, SkMask::Format, SkColor);
     61 
     62     /**
     63      *  Public entry-point to return a blitcolor BlitLCD16RowProc.
     64      */
     65     static BlitLCD16RowProc BlitLCD16RowFactory(bool isOpaque);
     66 
     67     /**
     68      *  Return either platform specific optimized blitcolor BlitLCD16RowProc,
     69      *  or NULL if no optimized routine is available.
     70      */
     71     static BlitLCD16RowProc PlatformBlitRowProcs16(bool isOpaque);
     72 
     73     enum RowFlags {
     74         kSrcIsOpaque_RowFlag    = 1 << 0
     75     };
     76 
     77     /**
     78      *  Public entry-point to return a blitmask RowProc.
     79      *  May return NULL if config or format are not supported.
     80      */
     81     static RowProc RowFactory(SkBitmap::Config, SkMask::Format, RowFlags);
     82 
     83     /**
     84      *  Return either platform specific optimized blitmask RowProc,
     85      *  or NULL if no optimized routine is available.
     86      */
     87     static RowProc PlatformRowProcs(SkBitmap::Config, SkMask::Format, RowFlags);
     88 };
     89 
     90 #endif
     91