Index: ui/gfx/canvas_unittest_mac.mm |
diff --git a/ui/gfx/canvas_unittest_mac.mm b/ui/gfx/canvas_unittest_mac.mm |
index d607218c64fe432969faf70f02858dc14f4c3115..66e4d303a07342d951a9a22545fb9176cbb9679b 100644 |
--- a/ui/gfx/canvas_unittest_mac.mm |
+++ b/ui/gfx/canvas_unittest_mac.mm |
@@ -4,8 +4,6 @@ |
#include "ui/gfx/canvas.h" |
-#include <cmath> |
- |
#import <Cocoa/Cocoa.h> |
#include "base/strings/utf_string_conversions.h" |
@@ -18,67 +16,72 @@ namespace gfx { |
namespace { |
-// Mac-specific code for string size computations. This is a verbatim copy |
-// of the old implementation that used to be in canvas_mac.mm. |
-void CanvasMac_SizeStringInt(const base::string16& text, |
- const FontList& font_list, |
- int* width, |
- int* height, |
- int line_height, |
- int flags) { |
- DLOG_IF(WARNING, line_height != 0) << "Line heights not implemented."; |
- DLOG_IF(WARNING, flags & Canvas::MULTI_LINE) << "Multi-line not implemented."; |
+// Returns the pixel width of the string via calling the native method |
+// sizeWithAttributes. |
+float GetStringNativeWidth(const base::string16& text, |
+ const FontList& font_list) { |
msw
2013/10/01 21:46:45
nit: remove blank line
|
NSFont* native_font = font_list.GetPrimaryFont().GetNativeFont(); |
NSString* ns_string = base::SysUTF16ToNSString(text); |
NSDictionary* attributes = |
[NSDictionary dictionaryWithObject:native_font |
forKey:NSFontAttributeName]; |
- NSSize string_size = [ns_string sizeWithAttributes:attributes]; |
- *width = std::ceil(string_size.width); |
- *height = font_list.GetHeight(); |
+ return [ns_string sizeWithAttributes:attributes].width; |
} |
} // namespace |
class CanvasTestMac : public testing::Test { |
protected: |
- // Compare the size returned by Canvas::SizeStringInt to the size generated |
- // by the platform-specific version in CanvasMac_SizeStringInt. Will generate |
- // expectation failure on any mismatch. Only works for single-line text |
- // without specified line height, since that is all the platform |
+ // Compare the size returned by Canvas::SizeStringToFit to the size generated |
+ // by the platform-specific version in CanvasMac_SizeStringToFit. Will |
+ // generate expectation failure on any mismatch. Only works for single-line |
+ // text without specified line height, since that is all the platform |
// implementation supports. |
void CompareSizes(const char* text) { |
- const int kReallyLargeNumber = 12345678; |
+ const float kReallyLargeNumber = 12345678; |
FontList font_list(font_); |
base::string16 text16 = base::UTF8ToUTF16(text); |
- int mac_width = kReallyLargeNumber; |
- int mac_height = kReallyLargeNumber; |
- CanvasMac_SizeStringInt(text16, font_list, &mac_width, &mac_height, 0, 0); |
+ float mac_width = GetStringNativeWidth(text16, font_list); |
+ int mac_height = font_list.GetHeight(); |
- int canvas_width = kReallyLargeNumber; |
- int canvas_height = kReallyLargeNumber; |
- Canvas::SizeStringInt( |
+ float canvas_width = kReallyLargeNumber; |
+ float canvas_height = kReallyLargeNumber; |
+ Canvas::SizeStringToFit( |
text16, font_list, &canvas_width, &canvas_height, 0, 0); |
EXPECT_NE(kReallyLargeNumber, mac_width) << "no width for " << text; |
EXPECT_NE(kReallyLargeNumber, mac_height) << "no height for " << text; |
EXPECT_EQ(mac_width, canvas_width) << " width for " << text; |
- EXPECT_EQ(mac_height, canvas_height) << " height for " << text; |
+ // FontList::GetHeight returns a truncated height. |
+ EXPECT_EQ(mac_height, |
+ static_cast<int>(canvas_height)) << " height for " << text; |
} |
private: |
Font font_; |
}; |
- // Tests that Canvas' SizeStringInt yields result consistent with a native |
- // implementation. |
- TEST_F(CanvasTestMac, StringSizeIdenticalForSkia) { |
+// Tests that Canvas' SizeStringToFit yields result consistent with a native |
+// implementation. |
+TEST_F(CanvasTestMac, StringSizeIdenticalForSkia) { |
CompareSizes(""); |
CompareSizes("Foo"); |
CompareSizes("Longword"); |
CompareSizes("This is a complete sentence."); |
} |
+TEST_F(CanvasTestMac, FractionalWidth) { |
+ const float kReallyLargeNumber = 12345678; |
+ float width = kReallyLargeNumber; |
+ float height = kReallyLargeNumber; |
+ |
+ FontList font_list; |
+ Canvas::SizeStringToFit( |
+ base::UTF8ToUTF16("Test"), font_list, &width, &height, 0, 0); |
+ |
+ EXPECT_GT(width - static_cast<int>(width), 0); |
+} |
+ |
} // namespace gfx |