blob: 8f91046610fca83e77fde65a8505f6f9912ab68d [file] [log] [blame]
// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef PDF_DRAW_UTILS_H_
#define PDF_DRAW_UTILS_H_
#include <stdint.h>
#include <vector>
#include "ppapi/cpp/image_data.h"
#include "ppapi/cpp/rect.h"
namespace chrome_pdf {
const uint8_t kOpaqueAlpha = 0xFF;
const uint8_t kTransparentAlpha = 0x00;
void AlphaBlend(const pp::ImageData& src,
const pp::Rect& src_rc,
pp::ImageData* dest,
const pp::Point& dest_origin,
uint8_t alpha_adjustment);
// Fill rectangle with gradient horizontally or vertically. Start is a color of
// top-left point of the rectangle, end color is a color of
// top-right (horizontal==true) or bottom-left (horizontal==false) point.
void GradientFill(pp::ImageData* image,
const pp::Rect& rc,
uint32_t start_color,
uint32_t end_color,
bool horizontal);
// Fill dirty rectangle with gradient, where gradient color set for corners of
// gradient rectangle. Parts of the dirty rect outside of gradient rect will
// be unchanged.
void GradientFill(pp::Instance* instance,
pp::ImageData* image,
const pp::Rect& dirty_rc,
const pp::Rect& gradient_rc,
uint32_t start_color,
uint32_t end_color,
bool horizontal,
uint8_t transparency);
// Copy one image into another. If stretch is true, the result occupy the entire
// dest_rc. If stretch is false, dest_rc.point will be used as an origin of the
// result image. Copy will ignore all pixels with transparent alpha from the
// source image.
void CopyImage(const pp::ImageData& src, const pp::Rect& src_rc,
pp::ImageData* dest, const pp::Rect& dest_rc,
bool stretch);
// Fill in rectangle with specified color.
void FillRect(pp::ImageData* image, const pp::Rect& rc, uint32_t color);
// Shadow Matrix contains matrix for shadow rendering. To reduce amount of
// calculations user may choose to cache matrix and reuse it if nothing changed.
class ShadowMatrix {
public:
// Matrix parameters.
// depth - how big matrix should be. Shadow will go smoothly across the
// entire matrix from black to background color.
// If factor == 1, smoothing will be linear from 0 to the end (depth),
// if 0 < factor < 1, smoothing will drop faster near 0.
// if factor > 1, smoothing will drop faster near the end (depth).
ShadowMatrix(uint32_t depth, double factor, uint32_t background);
~ShadowMatrix();
uint32_t GetValue(int32_t x, int32_t y) const {
return matrix_[y * depth_ + x];
}
uint32_t depth() const { return depth_; }
double factor() const { return factor_; }
uint32_t background() const { return background_; }
private:
uint32_t depth_;
double factor_;
uint32_t background_;
std::vector<uint32_t> matrix_;
};
// Draw shadow on the image using provided ShadowMatrix.
// shadow_rc - rectangle occupied by shadow
// object_rc - rectangle that drops the shadow
// clip_rc - clipping region
void DrawShadow(pp::ImageData* image,
const pp::Rect& shadow_rc,
const pp::Rect& object_rc,
const pp::Rect& clip_rc,
const ShadowMatrix& matrix);
} // namespace chrome_pdf
#endif // PDF_DRAW_UTILS_H_