2017-08-02 19:36:24 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2017 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef SkAndroidFrameworkUtils_DEFINED
|
|
|
|
#define SkAndroidFrameworkUtils_DEFINED
|
|
|
|
|
2019-04-23 17:05:21 +00:00
|
|
|
#include "include/core/SkRefCnt.h"
|
|
|
|
#include "include/core/SkTypes.h"
|
2017-08-02 19:36:24 +00:00
|
|
|
|
2018-11-13 15:26:34 +00:00
|
|
|
#ifdef SK_BUILD_FOR_ANDROID_FRAMEWORK
|
2017-08-02 19:36:24 +00:00
|
|
|
|
|
|
|
class SkCanvas;
|
2020-06-25 20:19:03 +00:00
|
|
|
struct SkIRect;
|
2018-12-18 22:38:18 +00:00
|
|
|
struct SkRect;
|
2018-11-27 20:33:38 +00:00
|
|
|
class SkSurface;
|
2017-08-02 19:36:24 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* SkAndroidFrameworkUtils expose private APIs used only by Android framework.
|
|
|
|
*/
|
|
|
|
class SkAndroidFrameworkUtils {
|
|
|
|
public:
|
|
|
|
|
|
|
|
#if SK_SUPPORT_GPU
|
|
|
|
/**
|
|
|
|
* clipWithStencil draws the current clip into a stencil buffer with reference value and mask
|
|
|
|
* set to 0x1. This function works only on a GPU canvas.
|
|
|
|
*
|
|
|
|
* @param canvas A GPU canvas that has a non-empty clip.
|
|
|
|
*
|
|
|
|
* @return true on success or false if clip is empty or not a GPU canvas.
|
|
|
|
*/
|
|
|
|
static bool clipWithStencil(SkCanvas* canvas);
|
|
|
|
#endif //SK_SUPPORT_GPU
|
2018-11-13 15:26:34 +00:00
|
|
|
|
|
|
|
static void SafetyNetLog(const char*);
|
2018-11-27 20:33:38 +00:00
|
|
|
|
|
|
|
static sk_sp<SkSurface> getSurfaceFromCanvas(SkCanvas* canvas);
|
2018-12-18 22:38:18 +00:00
|
|
|
|
|
|
|
static int SaveBehind(SkCanvas* canvas, const SkRect* subset);
|
2019-03-28 20:39:58 +00:00
|
|
|
|
2020-06-25 20:19:03 +00:00
|
|
|
// Operating within the canvas' clip stack, this resets the geometry of the clip to be an
|
|
|
|
// intersection with the device-space 'rect'. If 'rect' is null, this will use the rect that
|
|
|
|
// was last set using androidFramework_setDeviceClipRestriction on the canvas. If that was never
|
|
|
|
// set, it will restrict the clip to the canvas' dimensions.
|
|
|
|
//
|
|
|
|
// TODO: Eventually, make 'rect' non-optional and no longer store the restriction per canvas.
|
|
|
|
static void ReplaceClip(SkCanvas* canvas, const SkIRect* rect = nullptr);
|
|
|
|
|
2019-03-28 20:39:58 +00:00
|
|
|
/**
|
|
|
|
* Unrolls a chain of nested SkPaintFilterCanvas to return the base wrapped canvas.
|
|
|
|
*
|
|
|
|
* @param canvas A SkPaintFilterCanvas or any other SkCanvas subclass.
|
|
|
|
*
|
|
|
|
* @return SkCanvas that was found in the innermost SkPaintFilterCanvas.
|
|
|
|
*/
|
|
|
|
static SkCanvas* getBaseWrappedCanvas(SkCanvas* canvas);
|
2017-08-02 19:36:24 +00:00
|
|
|
};
|
|
|
|
|
2018-11-13 15:26:34 +00:00
|
|
|
#endif // SK_BUILD_FOR_ANDROID_ANDROID
|
2017-08-02 19:36:24 +00:00
|
|
|
|
|
|
|
#endif // SkAndroidFrameworkUtils_DEFINED
|