Bug 45585

Summary: Add zoom support to WebKit2 API
Product: WebKit Reporter: Sam Weinig <sam>
Component: WebKit2Assignee: Nobody <webkit-unassigned>
Status: RESOLVED FIXED    
Severity: Normal CC: mitz, webkit.review.bot
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: PC   
OS: OS X 10.5   
Attachments:
Description Flags
Patch
mitz: review+
Updated patch mitz: review+

Sam Weinig
Reported 2010-09-10 22:44:50 PDT
Add zoom support to WebKit2 API.
Attachments
Patch (98.80 KB, patch)
2010-09-10 22:47 PDT, Sam Weinig
mitz: review+
Updated patch (106.05 KB, patch)
2010-09-10 23:39 PDT, Sam Weinig
mitz: review+
Sam Weinig
Comment 1 2010-09-10 22:45:01 PDT
Sam Weinig
Comment 2 2010-09-10 22:47:26 PDT
WebKit Review Bot
Comment 3 2010-09-10 22:55:53 PDT
Attachment 67290 [details] did not pass style-queue: Failed to run "['WebKitTools/Scripts/check-webkit-style']" exit_code: 1 WebKitTools/MiniBrowser/mac/BrowserWindowController.h:37: _zoomTextOnly is incorrectly named. Don't use underscores in your identifier names. [readability/naming] [4] Total errors found: 1 in 12 files If any of these errors are false positives, please file a bug against check-webkit-style.
mitz
Comment 4 2010-09-10 23:20:26 PDT
Comment on attachment 67290 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=67290&action=prettypatch > WebKit2/Shared/CoreIPCSupport/WebPageMessageKinds.h:57 > + SetPageZoomFactor, > + SetTextZoomFactor, > + SetPageAndTextZoomFactors, Please sort. Better yet, why not eliminate SetPageZoomFactor and SetTextZoomFactor and always send SetPageAndTextZoomFactors? > WebKit2/UIProcess/WebPageProxy.cpp:403 > + m_textZoomFactor = zoomFactor; > + process()->send(WebPageMessage::SetTextZoomFactor, m_pageID, CoreIPC::In(m_textZoomFactor)); Should this return early and save the IPC if m_textZoomFactor is already equal to zoomFactor? > WebKit2/UIProcess/API/C/WKPage.cpp:156 > +float WKPageGetTextZoomFactor(WKPageRef pageRef) Why float and not double? > WebKitTools/MiniBrowser/mac/BrowserWindowController.m:168 > +#define kWKDefaultMinimumZoomFactor (.5f) > +#define kWKDefaultMaximumZoomFactor (3.0f) > +#define kWKDefaultZoomFactorRatio (1.2f) Why do these have a WK prefix if they’re not defined in WebKit?
Sam Weinig
Comment 5 2010-09-10 23:24:30 PDT
(In reply to comment #4) > (From update of attachment 67290 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=67290&action=prettypatch > > > WebKit2/Shared/CoreIPCSupport/WebPageMessageKinds.h:57 > > + SetPageZoomFactor, > > + SetTextZoomFactor, > > + SetPageAndTextZoomFactors, > Please sort. Better yet, why not eliminate SetPageZoomFactor and SetTextZoomFactor and always send SetPageAndTextZoomFactors? Ok. > > > WebKit2/UIProcess/WebPageProxy.cpp:403 > > + m_textZoomFactor = zoomFactor; > > + process()->send(WebPageMessage::SetTextZoomFactor, m_pageID, CoreIPC::In(m_textZoomFactor)); > Should this return early and save the IPC if m_textZoomFactor is already equal to zoomFactor? Yes. Will change. > > > WebKit2/UIProcess/API/C/WKPage.cpp:156 > > +float WKPageGetTextZoomFactor(WKPageRef pageRef) > Why float and not double? At what level do you think I should do the double to float conversion? > > WebKitTools/MiniBrowser/mac/BrowserWindowController.m:168 > > +#define kWKDefaultMinimumZoomFactor (.5f) > > +#define kWKDefaultMaximumZoomFactor (3.0f) > > +#define kWKDefaultZoomFactorRatio (1.2f) > Why do these have a WK prefix if they’re not defined in WebKit? Oh, no good reason. Will change.
mitz
Comment 6 2010-09-10 23:27:20 PDT
(In reply to comment #5) > At what level do you think I should do the double to float conversion? I would use doubles in WebKit and convert to float when calling into WebCore, but I don’t think it’s worth changing now.
mitz
Comment 7 2010-09-10 23:27:58 PDT
Comment on attachment 67290 [details] Patch r=me if you add the equality tests
Sam Weinig
Comment 8 2010-09-10 23:39:51 PDT
Created attachment 67294 [details] Updated patch
Sam Weinig
Comment 9 2010-09-10 23:51:39 PDT
Note You need to log in before you can comment on or make changes to this bug.