| OLD | NEW | 
|---|
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be | 
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. | 
| 4 | 4 | 
| 5 #include "app/gfx/chrome_canvas.h" | 5 #include "app/gfx/chrome_canvas.h" | 
| 6 | 6 | 
| 7 #include <pango/pango.h> | 7 #include <pango/pango.h> | 
| 8 | 8 | 
| 9 #include "app/gfx/chrome_font.h" | 9 #include "app/gfx/chrome_font.h" | 
| 10 #include "base/gfx/rect.h" | 10 #include "base/gfx/rect.h" | 
| 11 #include "base/logging.h" | 11 #include "base/logging.h" | 
| 12 #include "base/string_util.h" | 12 #include "base/string_util.h" | 
| 13 | 13 | 
| 14 namespace { | 14 namespace { | 
| 15 | 15 | 
| 16 // Returns a new pango font, free with pango_font_description_free(). | 16 // Returns a new pango font, free with pango_font_description_free(). | 
| 17 PangoFontDescription* PangoFontFromChromeFont(const ChromeFont& chrome_font) { | 17 PangoFontDescription* PangoFontFromGfxFont(const gfx::Font& gfx_font) { | 
| 18   ChromeFont font = chrome_font;  // Copy so we can call non-const methods. | 18   gfx::Font font = gfx_font;  // Copy so we can call non-const methods. | 
| 19   PangoFontDescription* pfd = pango_font_description_new(); | 19   PangoFontDescription* pfd = pango_font_description_new(); | 
| 20   pango_font_description_set_family(pfd, WideToUTF8(font.FontName()).c_str()); | 20   pango_font_description_set_family(pfd, WideToUTF8(font.FontName()).c_str()); | 
| 21   pango_font_description_set_size(pfd, font.FontSize() * PANGO_SCALE); | 21   pango_font_description_set_size(pfd, font.FontSize() * PANGO_SCALE); | 
| 22 | 22 | 
| 23   switch (font.style()) { | 23   switch (font.style()) { | 
| 24     case ChromeFont::NORMAL: | 24     case gfx::Font::NORMAL: | 
| 25       // Nothing to do, should already be PANGO_STYLE_NORMAL. | 25       // Nothing to do, should already be PANGO_STYLE_NORMAL. | 
| 26       break; | 26       break; | 
| 27     case ChromeFont::BOLD: | 27     case gfx::Font::BOLD: | 
| 28       pango_font_description_set_weight(pfd, PANGO_WEIGHT_BOLD); | 28       pango_font_description_set_weight(pfd, PANGO_WEIGHT_BOLD); | 
| 29       break; | 29       break; | 
| 30     case ChromeFont::ITALIC: | 30     case gfx::Font::ITALIC: | 
| 31       pango_font_description_set_style(pfd, PANGO_STYLE_ITALIC); | 31       pango_font_description_set_style(pfd, PANGO_STYLE_ITALIC); | 
| 32       break; | 32       break; | 
| 33     case ChromeFont::UNDERLINED: | 33     case gfx::Font::UNDERLINED: | 
| 34       // TODO(deanm): How to do underlined?  Where do we use it?  Probably have | 34       // TODO(deanm): How to do underlined?  Where do we use it?  Probably have | 
| 35       // to paint it ourselves, see pango_font_metrics_get_underline_position. | 35       // to paint it ourselves, see pango_font_metrics_get_underline_position. | 
| 36       break; | 36       break; | 
| 37   } | 37   } | 
| 38 | 38 | 
| 39   return pfd; | 39   return pfd; | 
| 40 } | 40 } | 
| 41 | 41 | 
| 42 }  // namespace | 42 }  // namespace | 
| 43 | 43 | 
| 44 ChromeCanvas::ChromeCanvas(int width, int height, bool is_opaque) | 44 ChromeCanvas::ChromeCanvas(int width, int height, bool is_opaque) | 
| 45     : skia::PlatformCanvasLinux(width, height, is_opaque) { | 45     : skia::PlatformCanvasLinux(width, height, is_opaque) { | 
| 46 } | 46 } | 
| 47 | 47 | 
| 48 ChromeCanvas::ChromeCanvas() : skia::PlatformCanvasLinux() { | 48 ChromeCanvas::ChromeCanvas() : skia::PlatformCanvasLinux() { | 
| 49 } | 49 } | 
| 50 | 50 | 
| 51 ChromeCanvas::~ChromeCanvas() { | 51 ChromeCanvas::~ChromeCanvas() { | 
| 52 } | 52 } | 
| 53 | 53 | 
| 54 // static | 54 // static | 
| 55 void ChromeCanvas::SizeStringInt(const std::wstring& text, | 55 void ChromeCanvas::SizeStringInt(const std::wstring& text, | 
| 56                                  const ChromeFont& font, | 56                                  const gfx::Font& font, | 
| 57                                  int* width, int* height, int flags) { | 57                                  int* width, int* height, int flags) { | 
| 58   NOTIMPLEMENTED(); | 58   NOTIMPLEMENTED(); | 
| 59 } | 59 } | 
| 60 | 60 | 
| 61 void ChromeCanvas::ApplySkiaMatrixToCairoContext(cairo_t* cr) { | 61 void ChromeCanvas::ApplySkiaMatrixToCairoContext(cairo_t* cr) { | 
| 62   const SkMatrix& skia_matrix = getTotalMatrix(); | 62   const SkMatrix& skia_matrix = getTotalMatrix(); | 
| 63   cairo_matrix_t cairo_matrix; | 63   cairo_matrix_t cairo_matrix; | 
| 64   cairo_matrix_init(&cairo_matrix, | 64   cairo_matrix_init(&cairo_matrix, | 
| 65                     SkScalarToFloat(skia_matrix.getScaleX()), | 65                     SkScalarToFloat(skia_matrix.getScaleX()), | 
| 66                     SkScalarToFloat(skia_matrix.getSkewY()), | 66                     SkScalarToFloat(skia_matrix.getSkewY()), | 
| 67                     SkScalarToFloat(skia_matrix.getSkewX()), | 67                     SkScalarToFloat(skia_matrix.getSkewX()), | 
| 68                     SkScalarToFloat(skia_matrix.getScaleY()), | 68                     SkScalarToFloat(skia_matrix.getScaleY()), | 
| 69                     SkScalarToFloat(skia_matrix.getTranslateX()), | 69                     SkScalarToFloat(skia_matrix.getTranslateX()), | 
| 70                     SkScalarToFloat(skia_matrix.getTranslateY())); | 70                     SkScalarToFloat(skia_matrix.getTranslateY())); | 
| 71   cairo_set_matrix(cr, &cairo_matrix); | 71   cairo_set_matrix(cr, &cairo_matrix); | 
| 72 } | 72 } | 
| 73 | 73 | 
| 74 void ChromeCanvas::DrawStringInt(const std::wstring& text, | 74 void ChromeCanvas::DrawStringInt(const std::wstring& text, | 
| 75                                  const ChromeFont& font, | 75                                  const gfx::Font& font, | 
| 76                                  const SkColor& color, int x, int y, int w, | 76                                  const SkColor& color, int x, int y, int w, | 
| 77                                  int h, int flags) { | 77                                  int h, int flags) { | 
| 78   cairo_surface_t* surface = beginPlatformPaint(); | 78   cairo_surface_t* surface = beginPlatformPaint(); | 
| 79   cairo_t* cr = cairo_create(surface); | 79   cairo_t* cr = cairo_create(surface); | 
| 80   // We're going to draw onto the surface directly. This circumvents the matrix | 80   // We're going to draw onto the surface directly. This circumvents the matrix | 
| 81   // installed by Skia. Apply the matrix from skia to cairo so they align and | 81   // installed by Skia. Apply the matrix from skia to cairo so they align and | 
| 82   // we draw at the right place. | 82   // we draw at the right place. | 
| 83   ApplySkiaMatrixToCairoContext(cr); | 83   ApplySkiaMatrixToCairoContext(cr); | 
| 84   PangoLayout* layout = pango_cairo_create_layout(cr); | 84   PangoLayout* layout = pango_cairo_create_layout(cr); | 
| 85 | 85 | 
| (...skipping 19 matching lines...) Expand all  Loading... | 
| 105     pango_layout_set_wrap(layout, | 105     pango_layout_set_wrap(layout, | 
| 106         (flags & CHARACTER_BREAK) ? PANGO_WRAP_WORD_CHAR : PANGO_WRAP_WORD); | 106         (flags & CHARACTER_BREAK) ? PANGO_WRAP_WORD_CHAR : PANGO_WRAP_WORD); | 
| 107   } | 107   } | 
| 108 | 108 | 
| 109   if (flags & NO_ELLIPSIS) | 109   if (flags & NO_ELLIPSIS) | 
| 110     pango_layout_set_ellipsize(layout, PANGO_ELLIPSIZE_NONE); | 110     pango_layout_set_ellipsize(layout, PANGO_ELLIPSIZE_NONE); | 
| 111 | 111 | 
| 112   std::string utf8 = WideToUTF8(text); | 112   std::string utf8 = WideToUTF8(text); | 
| 113   pango_layout_set_text(layout, utf8.data(), utf8.size()); | 113   pango_layout_set_text(layout, utf8.data(), utf8.size()); | 
| 114 | 114 | 
| 115   PangoFontDescription* desc = PangoFontFromChromeFont(font); | 115   PangoFontDescription* desc = PangoFontFromGfxFont(font); | 
| 116   pango_layout_set_font_description(layout, desc); | 116   pango_layout_set_font_description(layout, desc); | 
| 117   pango_font_description_free(desc); | 117   pango_font_description_free(desc); | 
| 118 | 118 | 
| 119   int width, height; | 119   int width, height; | 
| 120   pango_layout_get_size(layout, &width, &height); | 120   pango_layout_get_size(layout, &width, &height); | 
| 121 | 121 | 
| 122   if (flags & ChromeCanvas::TEXT_VALIGN_TOP) { | 122   if (flags & ChromeCanvas::TEXT_VALIGN_TOP) { | 
| 123     // Cairo should draw from the top left corner already. | 123     // Cairo should draw from the top left corner already. | 
| 124   } else if (flags & ChromeCanvas::TEXT_VALIGN_BOTTOM) { | 124   } else if (flags & ChromeCanvas::TEXT_VALIGN_BOTTOM) { | 
| 125     y = y + (h - (height / PANGO_SCALE)); | 125     y = y + (h - (height / PANGO_SCALE)); | 
| 126   } else { | 126   } else { | 
| 127     // Vertically centered. | 127     // Vertically centered. | 
| 128     y = y + ((h - (height / PANGO_SCALE)) / 2); | 128     y = y + ((h - (height / PANGO_SCALE)) / 2); | 
| 129   } | 129   } | 
| 130 | 130 | 
| 131   cairo_move_to(cr, x, y); | 131   cairo_move_to(cr, x, y); | 
| 132   pango_cairo_show_layout(cr, layout); | 132   pango_cairo_show_layout(cr, layout); | 
| 133 | 133 | 
| 134   g_object_unref(layout); | 134   g_object_unref(layout); | 
| 135   cairo_destroy(cr); | 135   cairo_destroy(cr); | 
| 136   // NOTE: beginPlatformPaint returned its surface, we shouldn't destroy it. | 136   // NOTE: beginPlatformPaint returned its surface, we shouldn't destroy it. | 
| 137 } | 137 } | 
| OLD | NEW | 
|---|