Index: ui/gfx/gdi_util.cc |
diff --git a/ui/gfx/gdi_util.cc b/ui/gfx/gdi_util.cc |
deleted file mode 100644 |
index 996d01ee4a4cbfbf50e1ca29e6ca6d017a4972f0..0000000000000000000000000000000000000000 |
--- a/ui/gfx/gdi_util.cc |
+++ /dev/null |
@@ -1,141 +0,0 @@ |
-// Copyright (c) 2012 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. |
- |
-#include "ui/gfx/gdi_util.h" |
- |
-#include "base/logging.h" |
-#include "base/memory/scoped_ptr.h" |
- |
-namespace { |
- |
-void CreateBitmapHeaderWithColorDepth(LONG width, |
- LONG height, |
- WORD color_depth, |
- BITMAPINFOHEADER* hdr) { |
- // These values are shared with gfx::PlatformDevice |
- hdr->biSize = sizeof(BITMAPINFOHEADER); |
- hdr->biWidth = width; |
- hdr->biHeight = -height; // minus means top-down bitmap |
- hdr->biPlanes = 1; |
- hdr->biBitCount = color_depth; |
- hdr->biCompression = BI_RGB; // no compression |
- hdr->biSizeImage = 0; |
- hdr->biXPelsPerMeter = 1; |
- hdr->biYPelsPerMeter = 1; |
- hdr->biClrUsed = 0; |
- hdr->biClrImportant = 0; |
-} |
- |
-} // namespace |
- |
-namespace gfx { |
- |
-void CreateBitmapHeader(int width, int height, BITMAPINFOHEADER* hdr) { |
- CreateBitmapHeaderWithColorDepth(width, height, 32, hdr); |
-} |
- |
-void CreateBitmapV4Header(int width, int height, BITMAPV4HEADER* hdr) { |
- // Because bmp v4 header is just an extension, we just create a v3 header and |
- // copy the bits over to the v4 header. |
- BITMAPINFOHEADER header_v3; |
- CreateBitmapHeader(width, height, &header_v3); |
- memset(hdr, 0, sizeof(BITMAPV4HEADER)); |
- memcpy(hdr, &header_v3, sizeof(BITMAPINFOHEADER)); |
- |
- // Correct the size of the header and fill in the mask values. |
- hdr->bV4Size = sizeof(BITMAPV4HEADER); |
- hdr->bV4RedMask = 0x00ff0000; |
- hdr->bV4GreenMask = 0x0000ff00; |
- hdr->bV4BlueMask = 0x000000ff; |
- hdr->bV4AlphaMask = 0xff000000; |
-} |
- |
-// Creates a monochrome bitmap header. |
-void CreateMonochromeBitmapHeader(int width, |
- int height, |
- BITMAPINFOHEADER* hdr) { |
- CreateBitmapHeaderWithColorDepth(width, height, 1, hdr); |
-} |
- |
-void SubtractRectanglesFromRegion(HRGN hrgn, |
- const std::vector<gfx::Rect>& cutouts) { |
- if (cutouts.size()) { |
- HRGN cutout = ::CreateRectRgn(0, 0, 0, 0); |
- for (size_t i = 0; i < cutouts.size(); i++) { |
- ::SetRectRgn(cutout, |
- cutouts[i].x(), |
- cutouts[i].y(), |
- cutouts[i].right(), |
- cutouts[i].bottom()); |
- ::CombineRgn(hrgn, hrgn, cutout, RGN_DIFF); |
- } |
- ::DeleteObject(cutout); |
- } |
-} |
- |
-HRGN ConvertPathToHRGN(const gfx::Path& path) { |
-#if defined(USE_AURA) |
- int point_count = path.getPoints(NULL, 0); |
- scoped_ptr<SkPoint[]> points(new SkPoint[point_count]); |
- path.getPoints(points.get(), point_count); |
- scoped_ptr<POINT[]> windows_points(new POINT[point_count]); |
- for (int i = 0; i < point_count; ++i) { |
- windows_points[i].x = SkScalarRoundToInt(points[i].fX); |
- windows_points[i].y = SkScalarRoundToInt(points[i].fY); |
- } |
- |
- return ::CreatePolygonRgn(windows_points.get(), point_count, ALTERNATE); |
-#elif defined(OS_WIN) |
- return path.CreateNativeRegion(); |
-#endif |
-} |
- |
- |
-float CalculatePageScale(HDC dc, int page_width, int page_height) { |
- int dc_width = GetDeviceCaps(dc, HORZRES); |
- int dc_height = GetDeviceCaps(dc, VERTRES); |
- |
- // If page fits DC - no scaling needed. |
- if (dc_width >= page_width && dc_height >= page_height) |
- return 1.0; |
- |
- float x_factor = |
- static_cast<float>(dc_width) / static_cast<float>(page_width); |
- float y_factor = |
- static_cast<float>(dc_height) / static_cast<float>(page_height); |
- return std::min(x_factor, y_factor); |
-} |
- |
-// Apply scaling to the DC. |
-bool ScaleDC(HDC dc, float scale_factor) { |
- SetGraphicsMode(dc, GM_ADVANCED); |
- XFORM xform = {0}; |
- xform.eM11 = xform.eM22 = scale_factor; |
- return !!ModifyWorldTransform(dc, &xform, MWT_LEFTMULTIPLY); |
-} |
- |
-void StretchDIBits(HDC hdc, int dest_x, int dest_y, int dest_w, int dest_h, |
- int src_x, int src_y, int src_w, int src_h, void* pixels, |
- const BITMAPINFO* bitmap_info) { |
- // When blitting a rectangle that touches the bottom, left corner of the |
- // bitmap, StretchDIBits looks at it top-down! For more details, see |
- // http://wiki.allegro.cc/index.php?title=StretchDIBits. |
- int rv; |
- int bitmap_h = -bitmap_info->bmiHeader.biHeight; |
- int bottom_up_src_y = bitmap_h - src_y - src_h; |
- if (bottom_up_src_y == 0 && src_x == 0 && src_h != bitmap_h) { |
- rv = ::StretchDIBits(hdc, |
- dest_x, dest_h + dest_y - 1, dest_w, -dest_h, |
- src_x, bitmap_h - src_y + 1, src_w, -src_h, |
- pixels, bitmap_info, DIB_RGB_COLORS, SRCCOPY); |
- } else { |
- rv = ::StretchDIBits(hdc, |
- dest_x, dest_y, dest_w, dest_h, |
- src_x, bottom_up_src_y, src_w, src_h, |
- pixels, bitmap_info, DIB_RGB_COLORS, SRCCOPY); |
- } |
- DCHECK(rv != GDI_ERROR); |
-} |
- |
-} // namespace gfx |