我认为有两种方法可以实现。
1, WebBrowser 是基于IE 9的,所以WebBrowser 也是支持最新的HTML5标准。然而在HTML中有许多控件是通过Browser的 pan 和zoom等手持行为起作 用的,您可以设置HTML中的 viewport metadata 元素来实现。如:将下面的HTML代码加入到您的HTML文件头上。
<meta name="viewport" content="user-scalable=no" />
2, WebBroswer控件的组成是一棵树型结构如下图:
\-WebBrowser
\-Border
\-Border
\-PanZoomContainer
\-Grid
\-Border (*)
\-ContentPresenter
\-TileHost
其中 TileHost 就是原始的IE9组件,TileHost 不处理所有的manipulation相关的事件,而是由PanZoomContainer来处理,将这些事件转换成手持,然后将结果传输到TileHost。
换句话说我们可以中断相关的manipulationg事件传输到PanZoomContainer。当这些事件还未bubble up到PanZoomContainer时,当这些事件设置为已经处理过。
这个方法的关键步骤有2步:
1, 需要从WebBroswer组件树中找到Border控件。请参考:http://www.scottlogic.co.uk/blog/colin/2010/03/linq-to-visual-tree/
2, 处理manipulation相关的事件,并设置该事件已经处理过 e.Handled = true;。
例如:
001 | using LinqToVisualTree; |
003 | public class WebBrowserHelper |
007 | public WebBrowser _browser; |
013 | /// Gets or sets whether to suppress the scrolling of |
015 | /// the WebBrowser control; |
019 | public bool ScrollDisabled { get ; set ; } |
023 | public WebBrowserHelper(WebBrowser browser) |
029 | browser.Loaded += new RoutedEventHandler(browser_Loaded); |
035 | private void browser_Loaded( object sender, RoutedEventArgs e) |
039 | var border = _browser.Descendants<Border>().Last() as Border; |
043 | border.ManipulationDelta += Border_ManipulationDelta; |
045 | border.ManipulationCompleted += Border_ManipulationCompleted; |
051 | private void Border_ManipulationCompleted( object sender, |
053 | ManipulationCompletedEventArgs e) |
059 | if (e.FinalVelocities.ExpansionVelocity.X != 0.0 || |
061 | e.FinalVelocities.ExpansionVelocity.Y != 0.0) |
069 | private void Border_ManipulationDelta( object sender, |
071 | ManipulationDeltaEventArgs e) |
077 | if (e.DeltaManipulation.Scale.X != 0.0 || |
079 | e.DeltaManipulation.Scale.Y != 0.0) |
091 | if (e.DeltaManipulation.Translation.X != 0.0 || |
093 | e.DeltaManipulation.Translation.Y != 0.0) |