[chromium] Add WebLayerTreeViewClient API to request font atlas
authorcommit-queue@webkit.org <commit-queue@webkit.org@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Tue, 27 Nov 2012 23:17:02 +0000 (23:17 +0000)
committercommit-queue@webkit.org <commit-queue@webkit.org@268f45cc-cd09-0410-ab3c-d52691b4dbfc>
Tue, 27 Nov 2012 23:17:02 +0000 (23:17 +0000)
https://bugs.webkit.org/show_bug.cgi?id=102958

Patch by Eberhard Graether <egraether@google.com> on 2012-11-27
Reviewed by James Robinson.

This change makes the font atlas creation accessible to the WebLayerTreeView.

Source/Platform:

* chromium/public/WebLayerTreeViewClient.h:
(WebKit):
(WebLayerTreeViewClient):
(WebKit::WebLayerTreeViewClient::createFontAtlas):

Source/WebKit/chromium:

* src/WebViewImpl.cpp:
(WebKit::WebViewImpl::createFontAtlas):
(WebKit):
* src/WebViewImpl.h:
(WebViewImpl):

git-svn-id: https://svn.webkit.org/repository/webkit/trunk@135929 268f45cc-cd09-0410-ab3c-d52691b4dbfc

Source/Platform/ChangeLog
Source/Platform/chromium/public/WebLayerTreeViewClient.h
Source/WebKit/chromium/ChangeLog
Source/WebKit/chromium/src/WebViewImpl.cpp
Source/WebKit/chromium/src/WebViewImpl.h

index c4e3c3d..8a242c8 100644 (file)
@@ -1,5 +1,19 @@
 2012-11-27  Eberhard Graether  <egraether@google.com>
 
+        [chromium] Add WebLayerTreeViewClient API to request font atlas
+        https://bugs.webkit.org/show_bug.cgi?id=102958
+
+        Reviewed by James Robinson.
+
+        This change makes the font atlas creation accessible to the WebLayerTreeView.
+
+        * chromium/public/WebLayerTreeViewClient.h:
+        (WebKit):
+        (WebLayerTreeViewClient):
+        (WebKit::WebLayerTreeViewClient::createFontAtlas):
+
+2012-11-27  Eberhard Graether  <egraether@google.com>
+
         Plumbing showPaintRects out of InspectorPageAgent to use a different drawing implementation if available.
         https://bugs.webkit.org/show_bug.cgi?id=102452
 
index 3375913..2ca6b0a 100644 (file)
 #ifndef WebLayerTreeViewClient_h
 #define WebLayerTreeViewClient_h
 
+class SkBitmap;
+
 namespace WebKit {
 class WebCompositorOutputSurface;
 class WebInputHandler;
 class WebThread;
+struct WebRect;
 struct WebSize;
 
 class WebLayerTreeViewClient {
@@ -90,6 +93,11 @@ public:
     // internally schedule a compositing pass when needed.
     virtual void scheduleComposite() = 0;
 
+    // Creates a font atlas to use for debug visualizations. The atlas is a bitmap
+    // containing glyph data, a table of ASCII character values to a subrectangle
+    // of the atlas representing the corresponding glyph, and the glyph height.
+    virtual void createFontAtlas(SkBitmap&, WebRect asciiToRectTable[128], int& fontHeight) { }
+
 protected:
     virtual ~WebLayerTreeViewClient() { }
 };
index 811bd22..762ae19 100644 (file)
@@ -1,3 +1,18 @@
+2012-11-27  Eberhard Graether  <egraether@google.com>
+
+        [chromium] Add WebLayerTreeViewClient API to request font atlas
+        https://bugs.webkit.org/show_bug.cgi?id=102958
+
+        Reviewed by James Robinson.
+
+        This change makes the font atlas creation accessible to the WebLayerTreeView.
+
+        * src/WebViewImpl.cpp:
+        (WebKit::WebViewImpl::createFontAtlas):
+        (WebKit):
+        * src/WebViewImpl.h:
+        (WebViewImpl):
+
 2012-11-27  Joshua Bell  <jsbell@chromium.org>
 
         IndexedDB: Simplify transaction timers and event tracking
index fb4221c..f66ae48 100644 (file)
@@ -4212,6 +4212,12 @@ void WebViewImpl::scheduleComposite()
     m_client->scheduleComposite();
 }
 
+void WebViewImpl::createFontAtlas(SkBitmap& bitmap, WebRect asciiToRectTable[128], int& fontHeight)
+{
+    TRACE_EVENT0("webkit", "WebViewImpl::loadFontAtlas");
+    bitmap = WebCore::CompositorHUDFontAtlas::generateFontAtlas(asciiToRectTable, fontHeight);
+}
+
 void WebViewImpl::updateLayerTreeViewport()
 {
     if (!page() || !m_nonCompositedContentHost || !m_layerTreeView)
index bfcfd58..bbdbda7 100644 (file)
@@ -325,6 +325,7 @@ public:
     virtual void didCommitAndDrawFrame();
     virtual void didCompleteSwapBuffers();
     virtual void scheduleComposite();
+    virtual void createFontAtlas(SkBitmap&, WebRect[128], int&);
 
     // WebViewImpl