Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2010 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
Romain Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 17 | #ifndef ANDROID_HWUI_PATH_CACHE_H |
| 18 | #define ANDROID_HWUI_PATH_CACHE_H |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 19 | |
Romain Guy | fe48f65 | 2010-11-11 15:36:56 -0800 | [diff] [blame] | 20 | #include <utils/Vector.h> |
| 21 | |
Romain Guy | c15008e | 2010-11-10 11:59:15 -0800 | [diff] [blame] | 22 | #include "Debug.h" |
Romain Guy | ff26a0c | 2011-01-20 11:35:46 -0800 | [diff] [blame] | 23 | #include "ShapeCache.h" |
| 24 | |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 25 | namespace android { |
| 26 | namespace uirenderer { |
| 27 | |
Romain Guy | 9e10841 | 2010-11-09 14:35:20 -0800 | [diff] [blame] | 28 | /////////////////////////////////////////////////////////////////////////////// |
Romain Guy | 9e10841 | 2010-11-09 14:35:20 -0800 | [diff] [blame] | 29 | // Classes |
| 30 | /////////////////////////////////////////////////////////////////////////////// |
| 31 | |
Romain Guy | ff26a0c | 2011-01-20 11:35:46 -0800 | [diff] [blame] | 32 | struct PathCacheEntry: public ShapeCacheEntry { |
| 33 | PathCacheEntry(SkPath* path, SkPaint* paint): |
| 34 | ShapeCacheEntry(ShapeCacheEntry::kShapePath, paint) { |
| 35 | this->path = path; |
| 36 | } |
| 37 | |
| 38 | PathCacheEntry(): ShapeCacheEntry() { |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 39 | path = NULL; |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 40 | } |
| 41 | |
Romain Guy | 059e12c | 2012-11-28 17:35:51 -0800 | [diff] [blame^] | 42 | hash_t hash() const { |
| 43 | uint32_t hash = ShapeCacheEntry::hash(); |
| 44 | hash = JenkinsHashMix(hash, android::hash_type(path)); |
| 45 | return JenkinsHashWhiten(hash); |
| 46 | } |
| 47 | |
| 48 | int compare(const ShapeCacheEntry& r) const { |
| 49 | int deltaInt = ShapeCacheEntry::compare(r); |
| 50 | if (deltaInt != 0) return deltaInt; |
| 51 | |
Romain Guy | ff26a0c | 2011-01-20 11:35:46 -0800 | [diff] [blame] | 52 | const PathCacheEntry& rhs = (const PathCacheEntry&) r; |
Romain Guy | 059e12c | 2012-11-28 17:35:51 -0800 | [diff] [blame^] | 53 | return path - rhs.path; |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 54 | } |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 55 | |
Romain Guy | ff26a0c | 2011-01-20 11:35:46 -0800 | [diff] [blame] | 56 | SkPath* path; |
Romain Guy | b29cfbf | 2011-03-18 16:24:19 -0700 | [diff] [blame] | 57 | |
Romain Guy | ff26a0c | 2011-01-20 11:35:46 -0800 | [diff] [blame] | 58 | }; // PathCacheEntry |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 59 | |
Romain Guy | 059e12c | 2012-11-28 17:35:51 -0800 | [diff] [blame^] | 60 | inline hash_t hash_type(const PathCacheEntry& entry) { |
| 61 | return entry.hash(); |
| 62 | } |
| 63 | |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 64 | /** |
| 65 | * A simple LRU path cache. The cache has a maximum size expressed in bytes. |
| 66 | * Any texture added to the cache causing the cache to grow beyond the maximum |
| 67 | * allowed size will also cause the oldest texture to be kicked out. |
| 68 | */ |
Romain Guy | ff26a0c | 2011-01-20 11:35:46 -0800 | [diff] [blame] | 69 | class PathCache: public ShapeCache<PathCacheEntry> { |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 70 | public: |
Romain Guy | fb8b763 | 2010-08-23 21:05:08 -0700 | [diff] [blame] | 71 | PathCache(); |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 72 | |
| 73 | /** |
| 74 | * Returns the texture associated with the specified path. If the texture |
| 75 | * cannot be found in the cache, a new texture is generated. |
| 76 | */ |
| 77 | PathTexture* get(SkPath* path, SkPaint* paint); |
| 78 | /** |
Romain Guy | a2341a9 | 2010-09-08 18:04:33 -0700 | [diff] [blame] | 79 | * Removes an entry. |
| 80 | */ |
| 81 | void remove(SkPath* path); |
Romain Guy | fe48f65 | 2010-11-11 15:36:56 -0800 | [diff] [blame] | 82 | /** |
| 83 | * Removes the specified path. This is meant to be called from threads |
| 84 | * that are not the EGL context thread. |
| 85 | */ |
| 86 | void removeDeferred(SkPath* path); |
| 87 | /** |
| 88 | * Process deferred removals. |
| 89 | */ |
| 90 | void clearGarbage(); |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 91 | |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 92 | private: |
Romain Guy | fe48f65 | 2010-11-11 15:36:56 -0800 | [diff] [blame] | 93 | Vector<SkPath*> mGarbage; |
Romain Guy | a2341a9 | 2010-09-08 18:04:33 -0700 | [diff] [blame] | 94 | mutable Mutex mLock; |
Romain Guy | 7fbcc04 | 2010-08-04 15:40:07 -0700 | [diff] [blame] | 95 | }; // class PathCache |
| 96 | |
| 97 | }; // namespace uirenderer |
| 98 | }; // namespace android |
| 99 | |
Romain Guy | 5b3b352 | 2010-10-27 18:57:51 -0700 | [diff] [blame] | 100 | #endif // ANDROID_HWUI_PATH_CACHE_H |