summaryrefslogtreecommitdiffstats
path: root/libs/hwui/OpenGLDebugRenderer.cpp
blob: fe75ca239a05f3d8600b8eb27de0d120fd0dfccc (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
 * Copyright (C) 2010 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#define LOG_TAG "OpenGLRenderer"

#include <utils/StopWatch.h>

#include "OpenGLDebugRenderer.h"

namespace android {
namespace uirenderer {

void OpenGLDebugRenderer::prepare(bool opaque) {
    mPrimitivesCount = 0;
    LOGD("========= Frame start =========");
    OpenGLRenderer::prepare(opaque);
}

void OpenGLDebugRenderer::finish() {
    LOGD("========= Frame end =========");
    LOGD("Primitives draw count = %d", mPrimitivesCount);
    OpenGLRenderer::finish();
}

void OpenGLDebugRenderer::composeLayer(sp<Snapshot> current, sp<Snapshot> previous) {
    mPrimitivesCount++;
    StopWatch w("composeLayer");
    return OpenGLRenderer::composeLayer(current, previous);
}

int OpenGLDebugRenderer::saveLayer(float left, float top, float right, float bottom,
        SkPaint* p, int flags) {
    mPrimitivesCount++;
    StopWatch w("saveLayer");
    return OpenGLRenderer::saveLayer(left, top, right, bottom, p, flags);
}

void OpenGLDebugRenderer::drawBitmap(SkBitmap* bitmap, float left, float top,
        SkPaint* paint) {
    mPrimitivesCount++;
    StopWatch w("drawBitmap");
    OpenGLRenderer::drawBitmap(bitmap, left, top, paint);
}

void OpenGLDebugRenderer::drawBitmap(SkBitmap* bitmap, SkMatrix* matrix,
        SkPaint* paint) {
    mPrimitivesCount++;
    StopWatch w("drawBitmapMatrix");
    OpenGLRenderer::drawBitmap(bitmap, matrix, paint);
}

void OpenGLDebugRenderer::drawBitmap(SkBitmap* bitmap, float srcLeft, float srcTop,
        float srcRight, float srcBottom, float dstLeft, float dstTop,
        float dstRight, float dstBottom, SkPaint* paint) {
    mPrimitivesCount++;
    StopWatch w("drawBitmapRect");
    OpenGLRenderer::drawBitmap(bitmap, srcLeft, srcTop, srcRight, srcBottom,
            dstLeft, dstTop, dstRight, dstBottom, paint);
}

void OpenGLDebugRenderer::drawPatch(SkBitmap* bitmap, const int32_t* xDivs, const int32_t* yDivs,
        const uint32_t* colors, uint32_t width, uint32_t height, int8_t numColors,
        float left, float top, float right, float bottom, SkPaint* paint) {
    mPrimitivesCount++;
    StopWatch w("drawPatch");
    OpenGLRenderer::drawPatch(bitmap, xDivs, yDivs, colors, width, height, numColors,
            left, top, right, bottom, paint);
}

void OpenGLDebugRenderer::drawColor(int color, SkXfermode::Mode mode) {
    mPrimitivesCount++;
    StopWatch w("drawColor");
    OpenGLRenderer::drawColor(color, mode);
}

void OpenGLDebugRenderer::drawRect(float left, float top, float right, float bottom,
        SkPaint* paint) {
    mPrimitivesCount++;
    StopWatch w("drawRect");
    OpenGLRenderer::drawRect(left, top, right, bottom, paint);
}

void OpenGLDebugRenderer::drawPath(SkPath* path, SkPaint* paint) {
    mPrimitivesCount++;
    StopWatch w("drawPath");
    OpenGLRenderer::drawPath(path, paint);
}

void OpenGLDebugRenderer::drawLines(float* points, int count, SkPaint* paint) {
    mPrimitivesCount++;
    StopWatch w("drawLines");
    OpenGLRenderer::drawLines(points, count, paint);
}

void OpenGLDebugRenderer::drawText(const char* text, int bytesCount, int count, float x, float y,
        SkPaint* paint) {
    mPrimitivesCount++;
    StopWatch w("drawText");
    OpenGLRenderer::drawText(text, bytesCount, count, x, y, paint);
}

}; // namespace uirenderer
}; // namespace android