blob: 3c5c71afb568ab33ebeb26518bc263d8311912ff [file] [log] [blame]
// Copyright 2017 PDFium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
#ifndef CORE_FXGE_DIB_CFX_DIBBASE_H_
#define CORE_FXGE_DIB_CFX_DIBBASE_H_
#include <vector>
#include "core/fxcrt/fx_coordinates.h"
#include "core/fxcrt/fx_memory_wrappers.h"
#include "core/fxcrt/retain_ptr.h"
#include "core/fxge/dib/fx_dib.h"
#include "third_party/base/span.h"
enum FXDIB_Channel {
FXDIB_Red = 1,
FXDIB_Green,
FXDIB_Blue,
FXDIB_Cyan,
FXDIB_Magenta,
FXDIB_Yellow,
FXDIB_Black,
FXDIB_Alpha
};
class CFX_ClipRgn;
class CFX_DIBitmap;
class PauseIndicatorIface;
// Base class for all Device-Independent Bitmaps.
class CFX_DIBBase : public Retainable {
public:
~CFX_DIBBase() override;
virtual uint8_t* GetBuffer() const;
virtual const uint8_t* GetScanline(int line) const = 0;
virtual bool SkipToScanline(int line, PauseIndicatorIface* pPause) const;
virtual void DownSampleScanline(int line,
uint8_t* dest_scan,
int dest_bpp,
int dest_width,
bool bFlipX,
int clip_left,
int clip_width) const = 0;
uint8_t* GetWritableScanline(int line) {
return const_cast<uint8_t*>(GetScanline(line));
}
int GetWidth() const { return m_Width; }
int GetHeight() const { return m_Height; }
FXDIB_Format GetFormat() const { return m_Format; }
uint32_t GetPitch() const { return m_Pitch; }
bool HasPalette() const { return !m_palette.empty(); }
pdfium::span<const uint32_t> GetPaletteSpan() const { return m_palette; }
const uint32_t* GetPaletteData() const { return m_palette.data(); }
int GetBPP() const { return GetBppFromFormat(m_Format); }
bool IsAlphaMask() const { return GetIsMaskFromFormat(m_Format); }
bool HasAlpha() const { return GetIsAlphaFromFormat(m_Format); }
bool IsCmykImage() const { return GetIsCmykFromFormat(m_Format); }
bool IsOpaqueImage() const { return !IsAlphaMask() && !HasAlpha(); }
size_t GetPaletteSize() const;
uint32_t GetPaletteArgb(int index) const;
void SetPaletteArgb(int index, uint32_t color);
// Copies into internally-owned palette.
void SetPalette(pdfium::span<const uint32_t> src_palette);
RetainPtr<CFX_DIBitmap> Clone(const FX_RECT* pClip) const;
RetainPtr<CFX_DIBitmap> CloneConvert(FXDIB_Format format);
RetainPtr<CFX_DIBitmap> StretchTo(int dest_width,
int dest_height,
const FXDIB_ResampleOptions& options,
const FX_RECT* pClip);
RetainPtr<CFX_DIBitmap> TransformTo(const CFX_Matrix& mtDest,
int* left,
int* top);
RetainPtr<CFX_DIBitmap> SwapXY(bool bXFlip, bool bYFlip) const;
RetainPtr<CFX_DIBitmap> FlipImage(bool bXFlip, bool bYFlip) const;
RetainPtr<CFX_DIBitmap> CloneAlphaMask() const;
// Copies into internally-owned mask.
bool SetAlphaMask(const RetainPtr<CFX_DIBBase>& pAlphaMask,
const FX_RECT* pClip);
bool GetOverlapRect(int& dest_left,
int& dest_top,
int& width,
int& height,
int src_width,
int src_height,
int& src_left,
int& src_top,
const CFX_ClipRgn* pClipRgn);
#if defined(_SKIA_SUPPORT_) || defined(_SKIA_SUPPORT_PATHS_)
void DebugVerifyBitmapIsPreMultiplied(void* buffer) const;
#endif
RetainPtr<CFX_DIBitmap> m_pAlphaMask;
protected:
CFX_DIBBase();
static bool ConvertBuffer(
FXDIB_Format dest_format,
uint8_t* dest_buf,
int dest_pitch,
int width,
int height,
const RetainPtr<CFX_DIBBase>& pSrcBitmap,
int src_left,
int src_top,
std::vector<uint32_t, FxAllocAllocator<uint32_t>>* pal);
void BuildPalette();
bool BuildAlphaMask();
int FindPalette(uint32_t color) const;
void GetPalette(uint32_t* pal, int alpha) const;
int m_Width = 0;
int m_Height = 0;
uint32_t m_Pitch = 0;
FXDIB_Format m_Format = FXDIB_Format::kInvalid;
std::vector<uint32_t, FxAllocAllocator<uint32_t>> m_palette;
};
#endif // CORE_FXGE_DIB_CFX_DIBBASE_H_