blob: 5cb4ea8ce670b30c90eec35455b65befd5c65d0c [file] [log] [blame]
reed@google.comdc6c8ba2013-07-18 21:14:04 +00001/*
2 * Copyright 2013 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
reed@google.comeed6f1b2013-07-18 19:53:31 +00008#ifndef SkMipMap_DEFINED
9#define SkMipMap_DEFINED
10
reed9d93c2e2014-10-08 05:17:12 -070011#include "SkCachedData.h"
reed67b09bf2016-01-16 18:50:35 -080012#include "SkPixmap.h"
reed@google.comeed6f1b2013-07-18 19:53:31 +000013#include "SkScalar.h"
fmalita921d7ac2016-01-22 11:45:39 -080014#include "SkSize.h"
reed@google.comeed6f1b2013-07-18 19:53:31 +000015
16class SkBitmap;
reed9d93c2e2014-10-08 05:17:12 -070017class SkDiscardableMemory;
reed@google.comeed6f1b2013-07-18 19:53:31 +000018
reed9d93c2e2014-10-08 05:17:12 -070019typedef SkDiscardableMemory* (*SkDiscardableFactoryProc)(size_t bytes);
20
21class SkMipMap : public SkCachedData {
reed@google.comeed6f1b2013-07-18 19:53:31 +000022public:
reed67b09bf2016-01-16 18:50:35 -080023 static SkMipMap* Build(const SkPixmap& src, SkDiscardableFactoryProc);
reed9d93c2e2014-10-08 05:17:12 -070024 static SkMipMap* Build(const SkBitmap& src, SkDiscardableFactoryProc);
reed@google.comeed6f1b2013-07-18 19:53:31 +000025
cblumef95ff4a2016-06-02 09:01:48 -070026 // Determines how many levels a SkMipMap will have without creating that mipmap.
cblumee2412d52016-02-17 14:53:23 -080027 static int ComputeLevelCount(int baseWidth, int baseHeight);
28
cblumef95ff4a2016-06-02 09:01:48 -070029 // Determines the size of a given mipmap level.
30 static SkSize ComputeLevelSize(int baseWidth, int baseHeight, int level);
31
reed@google.comeed6f1b2013-07-18 19:53:31 +000032 struct Level {
reed67b09bf2016-01-16 18:50:35 -080033 SkPixmap fPixmap;
fmalita921d7ac2016-01-22 11:45:39 -080034 SkSize fScale; // < 1.0
reed@google.comeed6f1b2013-07-18 19:53:31 +000035 };
skia.committer@gmail.coma7991982013-07-19 07:00:57 +000036
fmalita33ed3ad2016-02-09 08:20:18 -080037 bool extractLevel(const SkSize& scale, Level*) const;
cblumee2412d52016-02-17 14:53:23 -080038 int countLevels() const;
39 bool getLevel(int index, Level*) const;
reed@google.comeed6f1b2013-07-18 19:53:31 +000040
reed9d93c2e2014-10-08 05:17:12 -070041protected:
mtklein36352bf2015-03-25 18:17:31 -070042 void onDataChange(void* oldData, void* newData) override {
halcanary96fcdcc2015-08-27 07:41:13 -070043 fLevels = (Level*)newData; // could be nullptr
reed9d93c2e2014-10-08 05:17:12 -070044 }
reed@google.comd94697c2013-07-24 14:31:33 +000045
reed@google.comeed6f1b2013-07-18 19:53:31 +000046private:
47 Level* fLevels;
48 int fCount;
49
50 // we take ownership of levels, and will free it with sk_free()
reed9d93c2e2014-10-08 05:17:12 -070051 SkMipMap(void* malloc, size_t size) : INHERITED(malloc, size) {}
52 SkMipMap(size_t size, SkDiscardableMemory* dm) : INHERITED(size, dm) {}
reed@google.comeed6f1b2013-07-18 19:53:31 +000053
reed9d93c2e2014-10-08 05:17:12 -070054 static size_t AllocLevelsSize(int levelCount, size_t pixelSize);
55
56 typedef SkCachedData INHERITED;
reed@google.comeed6f1b2013-07-18 19:53:31 +000057};
58
59#endif