summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorvandebo@chromium.org <vandebo@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-05-30 20:58:09 +0000
committervandebo@chromium.org <vandebo@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-05-30 20:58:09 +0000
commit67e16b3941e532e5e20a7c9367c32e845911ce24 (patch)
tree6f641162d27ad3fd3a5624adf4a21a03b7307139
parent62294a083fcafabd5b88417a60555ab298af79e4 (diff)
downloadchromium_src-67e16b3941e532e5e20a7c9367c32e845911ce24.zip
chromium_src-67e16b3941e532e5e20a7c9367c32e845911ce24.tar.gz
chromium_src-67e16b3941e532e5e20a7c9367c32e845911ce24.tar.bz2
Add metrics to determine what font types are being used with print preview.
This depends on Skia r1444. BUG=80918 TEST=NONE Committed: http://src.chromium.org/viewvc/chrome?view=rev&revision=87242 Reverted: http://src.chromium.org/viewvc/chrome?view=rev&revision=87248 Review URL: http://codereview.chromium.org/7084021 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@87257 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--printing/pdf_metafile_skia.cc27
1 files changed, 27 insertions, 0 deletions
diff --git a/printing/pdf_metafile_skia.cc b/printing/pdf_metafile_skia.cc
index f76eb70..2558a84 100644
--- a/printing/pdf_metafile_skia.cc
+++ b/printing/pdf_metafile_skia.cc
@@ -7,23 +7,33 @@
#include "base/eintr_wrapper.h"
#include "base/file_descriptor_posix.h"
#include "base/file_util.h"
+#include "base/hash_tables.h"
+#include "base/metrics/histogram.h"
#include "skia/ext/vector_platform_device_skia.h"
#include "third_party/skia/include/core/SkRefCnt.h"
#include "third_party/skia/include/core/SkScalar.h"
#include "third_party/skia/include/core/SkStream.h"
+#include "third_party/skia/include/core/SkTypeface.h"
#include "third_party/skia/include/pdf/SkPDFDevice.h"
#include "third_party/skia/include/pdf/SkPDFDocument.h"
+#include "third_party/skia/include/pdf/SkPDFFont.h"
#include "third_party/skia/include/pdf/SkPDFPage.h"
#include "ui/gfx/point.h"
#include "ui/gfx/rect.h"
#include "ui/gfx/size.h"
+namespace {
+ typedef base::hash_map<SkFontID, SkAdvancedTypefaceMetrics::FontType>
+ FontTypeMap;
+};
+
namespace printing {
struct PdfMetafileSkiaData {
SkRefPtr<SkPDFDevice> current_page_;
SkPDFDocument pdf_doc_;
SkDynamicMemoryWStream pdf_stream_;
+ FontTypeMap font_type_stats_;
};
PdfMetafileSkia::~PdfMetafileSkia() {}
@@ -71,6 +81,13 @@ bool PdfMetafileSkia::StartPage(const gfx::Size& page_size,
bool PdfMetafileSkia::FinishPage() {
DCHECK(data_->current_page_.get());
+ const SkTDArray<SkPDFFont*>& font_resources =
+ data_->current_page_->getFontResources();
+ for (int i = 0; i < font_resources.count(); i++) {
+ SkFontID key = font_resources[i]->typeface()->uniqueID();
+ data_->font_type_stats_[key] = font_resources[i]->getType();
+ }
+
data_->pdf_doc_.appendPage(data_->current_page_);
data_->current_page_ = NULL;
return true;
@@ -83,6 +100,16 @@ bool PdfMetafileSkia::FinishDocument() {
if (data_->current_page_.get())
FinishPage();
+
+ for (FontTypeMap::const_iterator it = data_->font_type_stats_.begin();
+ it != data_->font_type_stats_.end();
+ it++) {
+ UMA_HISTOGRAM_ENUMERATION(
+ "PrintPreview.FontType",
+ it->second,
+ SkAdvancedTypefaceMetrics::kNotEmbeddable_Font + 1);
+ }
+
return data_->pdf_doc_.emitPDF(&data_->pdf_stream_);
}