diff options
| author | Derek Sollenberger <djsollen@google.com> | 2009-08-05 11:53:29 -0400 | 
|---|---|---|
| committer | Derek Sollenberger <djsollen@google.com> | 2009-08-06 08:25:18 -0400 | 
| commit | 243869ecee2d4b5ab0f796fcc6692ece5b03c15e (patch) | |
| tree | 7ed5135cf1a0427c6bfb48957680877233755921 /WebKit | |
| parent | cc42ddfc59bb9fa5aa3b916a27f682fa6fb128a0 (diff) | |
| download | external_webkit-243869ecee2d4b5ab0f796fcc6692ece5b03c15e.zip external_webkit-243869ecee2d4b5ab0f796fcc6692ece5b03c15e.tar.gz external_webkit-243869ecee2d4b5ab0f796fcc6692ece5b03c15e.tar.bz2 | |
first cut at adding zoom support for plugins.
Diffstat (limited to 'WebKit')
| -rw-r--r-- | WebKit/android/plugins/PluginWidgetAndroid.cpp | 13 | ||||
| -rw-r--r-- | WebKit/android/plugins/PluginWidgetAndroid.h | 1 | ||||
| -rw-r--r-- | WebKit/android/plugins/android_npapi.h | 22 | 
3 files changed, 29 insertions, 7 deletions
| diff --git a/WebKit/android/plugins/PluginWidgetAndroid.cpp b/WebKit/android/plugins/PluginWidgetAndroid.cpp index 72714b4..c947b3b 100644 --- a/WebKit/android/plugins/PluginWidgetAndroid.cpp +++ b/WebKit/android/plugins/PluginWidgetAndroid.cpp @@ -48,6 +48,7 @@ PluginWidgetAndroid::PluginWidgetAndroid(WebCore::PluginView* view)      m_requestedFrameRect.setEmpty();      m_visibleDocRect.setEmpty();      m_hasFocus = false; +    m_zoomLevel = 0;  }  PluginWidgetAndroid::~PluginWidgetAndroid() { @@ -222,7 +223,17 @@ ANPSurface* PluginWidgetAndroid::createSurface(ANPSurfaceType ignored) {  void PluginWidgetAndroid::setVisibleScreen(const ANPRectI& visibleDocRect, float zoom) { -    //TODO send an event to the plugin that communicates the zoom +    //send an event to the plugin that communicates the zoom +    if (isAcceptingEvent(kZoom_ANPEventFlag) && m_zoomLevel != zoom) { +        //store the local zoom level +        m_zoomLevel = zoom; + +        //trigger the event +        ANPEvent event; +        SkANP::InitEvent(&event, kZoomLevel_ANPEventType); +        event.data.zoomLevel = zoom; +        sendEvent(event); +    }      int oldScreenW = m_visibleDocRect.width();      int oldScreenH = m_visibleDocRect.height(); diff --git a/WebKit/android/plugins/PluginWidgetAndroid.h b/WebKit/android/plugins/PluginWidgetAndroid.h index c278ffb..151d6ef 100644 --- a/WebKit/android/plugins/PluginWidgetAndroid.h +++ b/WebKit/android/plugins/PluginWidgetAndroid.h @@ -147,6 +147,7 @@ private:      SkIRect                 m_requestedFrameRect;      OwnPtr<android::PluginSurface> m_surface;      bool                    m_hasFocus; +    float                   m_zoomLevel;      /* We limit the number of rectangles to minimize storage and ensure adequate         speed. diff --git a/WebKit/android/plugins/android_npapi.h b/WebKit/android/plugins/android_npapi.h index 47a7494..f67d074 100644 --- a/WebKit/android/plugins/android_npapi.h +++ b/WebKit/android/plugins/android_npapi.h @@ -150,21 +150,22 @@ enum ANPDrawingModels {  };  typedef int32_t ANPDrawingModel; -/** Request to receive/disable events. If the pointer is NULL then all input will -    be disabled. Otherwise, the input type will be enabled iff its corresponding +/** Request to receive/disable events. If the pointer is NULL then all flags will +    be disabled. Otherwise, the event type will be enabled iff its corresponding      bit in the EventFlags bit field is set.      NPN_SetValue(inst, ANPAcceptEvents, (void*)EventFlags)   */  #define kAcceptEvents_ANPSetValue           ((NPPVariable)1001) -/*  The EventFlags are a set of bits used to determine which types of input the +/*  The EventFlags are a set of bits used to determine which types of events the      plugin wishes to receive. For example, if the value is 0x03 then both key      and touch events will be provided to the plugin.   */  enum ANPEventFlag { -    kKey_ANPEventFlag           = 0x01, -    kTouch_ANPEventFlag         = 0x02, +    kKey_ANPEventFlag               = 0x01, +    kTouch_ANPEventFlag             = 0x02, +    kZoom_ANPEventFlag              = 0x04, // triggers zoom & surface changed events  };  typedef uint32_t ANPEventFlags; @@ -755,6 +756,11 @@ enum ANPEventTypes {      kDraw_ANPEventType          = 4,      kLifecycle_ANPEventType     = 5,      kSurface_ANPEventType       = 6, +    /** Reports the current zoom level of the page. The event is only received +        if the plugin has specified that it wants to handle scaling the surface, +        by setting the kDynamicSurface_ANPEventFlag. +     */ +    kZoomLevel_ANPEventType     = 7,  };  typedef int32_t ANPEventType; @@ -794,6 +800,9 @@ enum ANPLifecycleActions {      kGainFocus_ANPLifecycleAction  = 2,      kLoseFocus_ANPLifecycleAction  = 3,      kFreeMemory_ANPLifecycleAction = 4, +    /** The page has finished loading. This happens when the page's top level +        frame reports that it has completed loading. +     */      kOnLoad_ANPLifecycleAction     = 5,  };  typedef uint32_t ANPLifecycleAction; @@ -868,7 +877,8 @@ struct ANPEvent {                  } changed;              } data;          } surface; -        int32_t         other[8]; +        float       zoomLevel; +        int32_t     other[8];      } data;  }; | 
