FontRenderer.h revision c08820f587ad94698691a6657e87712de07e484c
1694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy/*
2694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy * Copyright (C) 2010 The Android Open Source Project
3694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy *
4694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy * Licensed under the Apache License, Version 2.0 (the "License");
5694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy * you may not use this file except in compliance with the License.
6694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy * You may obtain a copy of the License at
7694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy *
8694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy *      http://www.apache.org/licenses/LICENSE-2.0
9694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy *
10694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy * Unless required by applicable law or agreed to in writing, software
11694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy * distributed under the License is distributed on an "AS IS" BASIS,
12694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy * See the License for the specific language governing permissions and
14694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy * limitations under the License.
15694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy */
16694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
175b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy#ifndef ANDROID_HWUI_FONT_RENDERER_H
185b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy#define ANDROID_HWUI_FONT_RENDERER_H
19694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
2096a5c4c7bab6718524de7253da8309143ab48befChris Craik#include "font/FontUtil.h"
2196a5c4c7bab6718524de7253da8309143ab48befChris Craik#include "font/CacheTexture.h"
2296a5c4c7bab6718524de7253da8309143ab48befChris Craik#include "font/CachedGlyphInfo.h"
2396a5c4c7bab6718524de7253da8309143ab48befChris Craik#include "font/Font.h"
2496a5c4c7bab6718524de7253da8309143ab48befChris Craik
25e3a9b24b5e3f9b2058486814a6d27729e51ad466Romain Guy#include <utils/LruCache.h>
261f5762e646bed2290934280464832782766ee68eMathias Agopian#include <utils/StrongPointer.h>
27694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
28694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy#include <SkPaint.h>
29694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
30694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy#include <GLES2/gl2.h>
31694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
32272a685f17cc4828257e521a6f62b7b17870f75eJohn Reck#include <vector>
33272a685f17cc4828257e521a6f62b7b17870f75eJohn Reck
34e4d9a01bfc7451afff1ed399a5801c7aa2af2831Dan Morrill#ifdef ANDROID_ENABLE_RENDERSCRIPT
35250b1cfc831fd2a271c09cab547efcc5e3d5f828Tim Murray#include "RenderScript.h"
36f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craiknamespace RSC {
37f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craik    class Element;
38f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craik    class RS;
39f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craik    class ScriptIntrinsicBlur;
40250b1cfc831fd2a271c09cab547efcc5e3d5f828Tim Murray    class sp;
41f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craik}
42e4d9a01bfc7451afff1ed399a5801c7aa2af2831Dan Morrill#endif
43f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craik
44694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guynamespace android {
45694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guynamespace uirenderer {
46694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
471e546815bbb736c50679a8aefc25f48561026fc5Victoria Leaseclass OpenGLRenderer;
481e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease
49828407356dd5c34a3e441604aaf895cbec7c7e66Chris Craikclass TextDrawFunctor {
501e546815bbb736c50679a8aefc25f48561026fc5Victoria Leasepublic:
51828407356dd5c34a3e441604aaf895cbec7c7e66Chris Craik    TextDrawFunctor(OpenGLRenderer* renderer, float x, float y, bool pureTranslate,
5296a5c4c7bab6718524de7253da8309143ab48befChris Craik            int alpha, SkXfermode::Mode mode, const SkPaint* paint)
5396a5c4c7bab6718524de7253da8309143ab48befChris Craik        : renderer(renderer)
5496a5c4c7bab6718524de7253da8309143ab48befChris Craik        , x(x)
5596a5c4c7bab6718524de7253da8309143ab48befChris Craik        , y(y)
5696a5c4c7bab6718524de7253da8309143ab48befChris Craik        , pureTranslate(pureTranslate)
5796a5c4c7bab6718524de7253da8309143ab48befChris Craik        , alpha(alpha)
5896a5c4c7bab6718524de7253da8309143ab48befChris Craik        , mode(mode)
5996a5c4c7bab6718524de7253da8309143ab48befChris Craik        , paint(paint) {
601e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease    }
611e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease
62e2bb380bc26749782c873e5488cfdf4e42b27346Chris Craik    void draw(CacheTexture& texture, bool linearFiltering);
631e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease
641e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease    OpenGLRenderer* renderer;
651e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease    float x;
661e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease    float y;
671e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease    bool pureTranslate;
681e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease    int alpha;
691e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease    SkXfermode::Mode mode;
70d218a92c0afb8c0d98135b20b52ac87236e1c935Chris Craik    const SkPaint* paint;
711e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease};
721e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease
73694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guyclass FontRenderer {
74694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guypublic:
75c08820f587ad94698691a6657e87712de07e484cChris Craik    FontRenderer(const uint8_t* gammaTable);
76694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy    ~FontRenderer();
77694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
78272a685f17cc4828257e521a6f62b7b17870f75eJohn Reck    void flushLargeCaches(std::vector<CacheTexture*>& cacheTextures);
799a8245629d69d81e0b62e52970feaf9c02580e75Chet Haase    void flushLargeCaches();
80694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
8159744b79ec302000802cd56d30a1bf70f0183c80Chris Craik    void setFont(const SkPaint* paint, const SkMatrix& matrix);
82e816baea651476aca4407200d4a5e629b9ab8dfaChet Haase
8359744b79ec302000802cd56d30a1bf70f0183c80Chris Craik    void precache(const SkPaint* paint, const char* text, int numGlyphs, const SkMatrix& matrix);
84cf51a4199835e9604aa4c8b3854306f8fbabbf33Romain Guy    void endPrecaching();
85e816baea651476aca4407200d4a5e629b9ab8dfaChet Haase
86671d6cf460531825a321edb200523d0faa7792c9Romain Guy    // bounds is an out parameter
87d218a92c0afb8c0d98135b20b52ac87236e1c935Chris Craik    bool renderPosText(const SkPaint* paint, const Rect* clip, const char *text,
88d218a92c0afb8c0d98135b20b52ac87236e1c935Chris Craik            uint32_t startIndex, uint32_t len, int numGlyphs, int x, int y, const float* positions,
89828407356dd5c34a3e441604aaf895cbec7c7e66Chris Craik            Rect* bounds, TextDrawFunctor* functor, bool forceFinish = true);
90527a3aace1dd72432c2e0472a570e030ad04bf16Chris Craik
919777173eb6c9eb97c7921c8288ebc65e3ab3ce6fRomain Guy    // bounds is an out parameter
92d218a92c0afb8c0d98135b20b52ac87236e1c935Chris Craik    bool renderTextOnPath(const SkPaint* paint, const Rect* clip, const char *text,
93d218a92c0afb8c0d98135b20b52ac87236e1c935Chris Craik            uint32_t startIndex, uint32_t len, int numGlyphs, const SkPath* path,
94828407356dd5c34a3e441604aaf895cbec7c7e66Chris Craik            float hOffset, float vOffset, Rect* bounds, TextDrawFunctor* functor);
95694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
96f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk    struct DropShadow {
97f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk        uint32_t width;
98f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk        uint32_t height;
99f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk        uint8_t* image;
100f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk        int32_t penX;
101f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk        int32_t penY;
102f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk    };
103f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk
104f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk    // After renderDropShadow returns, the called owns the memory in DropShadow.image
105f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk    // and is responsible for releasing it when it's done with it
106d218a92c0afb8c0d98135b20b52ac87236e1c935Chris Craik    DropShadow renderDropShadow(const SkPaint* paint, const char *text, uint32_t startIndex,
107e392c81f6b8f9ace0c0a48c9d4df117fda31fd13Derek Sollenberger            uint32_t len, int numGlyphs, float radius, const float* positions);
108f18136cb3c881a9d16c1a4f0f341732c276936bfAlex Sakhartchouk
109257ae3502cfad43df681b1783528d645bdabc63fRomain Guy    void setTextureFiltering(bool linearFiltering) {
1108087246d9964b11de8ce116bc63b156faa4197e0Romain Guy        mLinearFiltering = linearFiltering;
111c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy    }
112c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
1131e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease    uint32_t getCacheSize(GLenum format) const;
114c15008e72ec00ca20a271c3006dac649fd07533bRomain Guy
1159b1204baf4740b4d443e72157dea98571cf84e1fRomain Guyprivate:
116694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy    friend class Font;
117694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
118b45c0c9774bd19a9dbe77d149abae4e124b08bf6Romain Guy    const uint8_t* mGammaTable;
119b45c0c9774bd19a9dbe77d149abae4e124b08bf6Romain Guy
1202a47c14e2a6f152496b43104bc785c488583fd59Chet Haase    void allocateTextureMemory(CacheTexture* cacheTexture);
1219a8245629d69d81e0b62e52970feaf9c02580e75Chet Haase    void deallocateTextureMemory(CacheTexture* cacheTexture);
1227de0cb12d0e5fd64811da0b5d1ae0c0d58b86f86Chet Haase    void initTextTexture();
1231e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease    CacheTexture* createCacheTexture(int width, int height, GLenum format, bool allocate);
1247de0cb12d0e5fd64811da0b5d1ae0c0d58b86f86Chet Haase    void cacheBitmap(const SkGlyph& glyph, CachedGlyphInfo* cachedGlyph,
125f942cf10e04567f6b9456f6258e29c803b8bfb41Chet Haase            uint32_t *retOriginX, uint32_t *retOriginY, bool precaching);
126272a685f17cc4828257e521a6f62b7b17870f75eJohn Reck    CacheTexture* cacheBitmapInTexture(std::vector<CacheTexture*>& cacheTextures, const SkGlyph& glyph,
1271e546815bbb736c50679a8aefc25f48561026fc5Victoria Lease            uint32_t* startX, uint32_t* startY);
128694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
129694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy    void flushAllAndInvalidate();
130694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
131694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy    void checkInit();
132828407356dd5c34a3e441604aaf895cbec7c7e66Chris Craik    void initRender(const Rect* clip, Rect* bounds, TextDrawFunctor* functor);
133671d6cf460531825a321edb200523d0faa7792c9Romain Guy    void finishRender();
134694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
135272a685f17cc4828257e521a6f62b7b17870f75eJohn Reck    void issueDrawCommand(std::vector<CacheTexture*>& cacheTextures);
136694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy    void issueDrawCommand();
1379777173eb6c9eb97c7921c8288ebc65e3ab3ce6fRomain Guy    void appendMeshQuadNoClip(float x1, float y1, float u1, float v1,
1389777173eb6c9eb97c7921c8288ebc65e3ab3ce6fRomain Guy            float x2, float y2, float u2, float v2,
1399777173eb6c9eb97c7921c8288ebc65e3ab3ce6fRomain Guy            float x3, float y3, float u3, float v3,
1409777173eb6c9eb97c7921c8288ebc65e3ab3ce6fRomain Guy            float x4, float y4, float u4, float v4, CacheTexture* texture);
141d71dd367af604571c7d00ca473184a1b9240eca2Romain Guy    void appendMeshQuad(float x1, float y1, float u1, float v1,
142d71dd367af604571c7d00ca473184a1b9240eca2Romain Guy            float x2, float y2, float u2, float v2,
143d71dd367af604571c7d00ca473184a1b9240eca2Romain Guy            float x3, float y3, float u3, float v3,
1447de0cb12d0e5fd64811da0b5d1ae0c0d58b86f86Chet Haase            float x4, float y4, float u4, float v4, CacheTexture* texture);
1459777173eb6c9eb97c7921c8288ebc65e3ab3ce6fRomain Guy    void appendRotatedMeshQuad(float x1, float y1, float u1, float v1,
1469777173eb6c9eb97c7921c8288ebc65e3ab3ce6fRomain Guy            float x2, float y2, float u2, float v2,
1479777173eb6c9eb97c7921c8288ebc65e3ab3ce6fRomain Guy            float x3, float y3, float u3, float v3,
1489777173eb6c9eb97c7921c8288ebc65e3ab3ce6fRomain Guy            float x4, float y4, float u4, float v4, CacheTexture* texture);
149694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
1509b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy    void removeFont(const Font* font);
1519b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy
1529b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy    void checkTextureUpdate();
1539b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy
1549b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy    void setTextureDirty() {
1559b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy        mUploadTexture = true;
1569b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy    }
1579b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy
1587de0cb12d0e5fd64811da0b5d1ae0c0d58b86f86Chet Haase    uint32_t mSmallCacheWidth;
1597de0cb12d0e5fd64811da0b5d1ae0c0d58b86f86Chet Haase    uint32_t mSmallCacheHeight;
160eb32a499194119b3783b86c925172df02e5d2685Chet Haase    uint32_t mLargeCacheWidth;
161eb32a499194119b3783b86c925172df02e5d2685Chet Haase    uint32_t mLargeCacheHeight;
162694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
163272a685f17cc4828257e521a6f62b7b17870f75eJohn Reck    std::vector<CacheTexture*> mACacheTextures;
164272a685f17cc4828257e521a6f62b7b17870f75eJohn Reck    std::vector<CacheTexture*> mRGBACacheTextures;
165694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
16609147fbdc8206a0cac78bfe9083e7e15b3c5689cRomain Guy    Font* mCurrentFont;
167e3a9b24b5e3f9b2058486814a6d27729e51ad466Romain Guy    LruCache<Font::FontDescription, Font*> mActiveFonts;
168694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
1697de0cb12d0e5fd64811da0b5d1ae0c0d58b86f86Chet Haase    CacheTexture* mCurrentCacheTexture;
1707de0cb12d0e5fd64811da0b5d1ae0c0d58b86f86Chet Haase
171694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy    bool mUploadTexture;
172694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
173828407356dd5c34a3e441604aaf895cbec7c7e66Chris Craik    TextDrawFunctor* mFunctor;
17409147fbdc8206a0cac78bfe9083e7e15b3c5689cRomain Guy    const Rect* mClip;
1755b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    Rect* mBounds;
1765b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy    bool mDrawn;
17709147fbdc8206a0cac78bfe9083e7e15b3c5689cRomain Guy
178694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy    bool mInitialized;
17989a524ac2d4a36739e51b01b336c0bade77e2ee0Alex Sakhartchouk
180e8cb9c14309b0f01c0159efdf9a7198f44a62642Romain Guy    bool mLinearFiltering;
181e8cb9c14309b0f01c0159efdf9a7198f44a62642Romain Guy
182e4d9a01bfc7451afff1ed399a5801c7aa2af2831Dan Morrill#ifdef ANDROID_ENABLE_RENDERSCRIPT
183f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craik    // RS constructs
184250b1cfc831fd2a271c09cab547efcc5e3d5f828Tim Murray    RSC::sp<RSC::RS> mRs;
185250b1cfc831fd2a271c09cab547efcc5e3d5f828Tim Murray    RSC::sp<const RSC::Element> mRsElement;
186250b1cfc831fd2a271c09cab547efcc5e3d5f828Tim Murray    RSC::sp<RSC::ScriptIntrinsicBlur> mRsScript;
187e4d9a01bfc7451afff1ed399a5801c7aa2af2831Dan Morrill#endif
188f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craik
1899b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy    static void computeGaussianWeights(float* weights, int32_t radius);
1909b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy    static void horizontalBlur(float* weights, int32_t radius, const uint8_t *source, uint8_t *dest,
1911e45aae5de003657e5d18f74d34998f5de5db5b7Romain Guy            int32_t width, int32_t height);
1929b1204baf4740b4d443e72157dea98571cf84e1fRomain Guy    static void verticalBlur(float* weights, int32_t radius, const uint8_t *source, uint8_t *dest,
1931e45aae5de003657e5d18f74d34998f5de5db5b7Romain Guy            int32_t width, int32_t height);
194f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craik
195f2d8ccc15d7272b3416f73605c1f31d1d346bd40Chris Craik    // the input image handle may have its pointer replaced (to avoid copies)
196e392c81f6b8f9ace0c0a48c9d4df117fda31fd13Derek Sollenberger    void blurImage(uint8_t** image, int32_t width, int32_t height, float radius);
197694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy};
198694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
199694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy}; // namespace uirenderer
200694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy}; // namespace android
201694b519ac647fe998fd396fe0784cc8e179aadc4Romain Guy
2025b3b35296e8b2c8d3f07d32bb645d5414db41a1dRomain Guy#endif // ANDROID_HWUI_FONT_RENDERER_H
203