Index: chrome/browser/ui/views/extensions/shell_window_frame_view.cc |
diff --git a/chrome/browser/ui/views/extensions/native_app_window_views.cc b/chrome/browser/ui/views/extensions/shell_window_frame_view.cc |
similarity index 50% |
copy from chrome/browser/ui/views/extensions/native_app_window_views.cc |
copy to chrome/browser/ui/views/extensions/shell_window_frame_view.cc |
index df16fd4fcd9a13b85cfbe1126addd378dc9f4a84..3d8b761bcf68bedc5b56651435260cd2d8988033 100644 |
--- a/chrome/browser/ui/views/extensions/native_app_window_views.cc |
+++ b/chrome/browser/ui/views/extensions/shell_window_frame_view.cc |
@@ -2,18 +2,11 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#include "chrome/browser/ui/views/extensions/native_app_window_views.h" |
+#include "chrome/browser/ui/views/extensions/shell_window_frame_view.h" |
#include "base/utf_string_conversions.h" |
-#include "chrome/browser/extensions/extension_host.h" |
-#include "chrome/browser/favicon/favicon_tab_helper.h" |
-#include "chrome/browser/ui/views/extensions/extension_keybinding_registry_views.h" |
+#include "chrome/browser/ui/views/extensions/native_app_window_views.h" |
#include "chrome/common/extensions/draggable_region.h" |
-#include "chrome/common/extensions/extension.h" |
-#include "content/public/browser/render_view_host.h" |
-#include "content/public/browser/render_widget_host_view.h" |
-#include "content/public/browser/web_contents.h" |
-#include "content/public/browser/web_contents_view.h" |
#include "grit/theme_resources.h" |
#include "grit/ui_strings.h" // Accessibility names |
#include "third_party/skia/include/core/SkPaint.h" |
@@ -23,13 +16,10 @@ |
#include "ui/gfx/canvas.h" |
#include "ui/gfx/image/image.h" |
#include "ui/gfx/path.h" |
-#include "ui/views/controls/button/button.h" |
#include "ui/views/controls/button/image_button.h" |
-#include "ui/views/controls/webview/webview.h" |
#include "ui/views/layout/grid_layout.h" |
#include "ui/views/views_delegate.h" |
#include "ui/views/widget/widget.h" |
-#include "ui/views/window/non_client_view.h" |
#if defined(OS_WIN) && !defined(USE_AURA) |
#include "chrome/browser/shell_integration.h" |
@@ -39,7 +29,6 @@ |
#if defined(USE_ASH) |
#include "ash/ash_constants.h" |
-#include "ash/wm/custom_frame_view_ash.h" |
#include "chrome/browser/ui/ash/ash_util.h" |
#include "ui/aura/env.h" |
#include "ui/aura/window.h" |
@@ -53,49 +42,6 @@ const int kResizeAreaCornerSize = 16; |
const int kCaptionHeight = 25; |
} // namespace |
-class ShellWindowFrameView : public views::NonClientFrameView, |
- public views::ButtonListener { |
- public: |
- static const char kViewClassName[]; |
- |
- explicit ShellWindowFrameView(NativeAppWindowViews* window); |
- virtual ~ShellWindowFrameView(); |
- |
- void Init(views::Widget* frame); |
- |
- // views::NonClientFrameView implementation. |
- virtual gfx::Rect GetBoundsForClientView() const OVERRIDE; |
- virtual gfx::Rect GetWindowBoundsForClientBounds( |
- const gfx::Rect& client_bounds) const OVERRIDE; |
- virtual int NonClientHitTest(const gfx::Point& point) OVERRIDE; |
- virtual void GetWindowMask(const gfx::Size& size, |
- gfx::Path* window_mask) OVERRIDE; |
- virtual void ResetWindowControls() OVERRIDE {} |
- virtual void UpdateWindowIcon() OVERRIDE {} |
- virtual void UpdateWindowTitle() OVERRIDE {} |
- |
- // views::View implementation. |
- virtual gfx::Size GetPreferredSize() OVERRIDE; |
- virtual void Layout() OVERRIDE; |
- virtual std::string GetClassName() const OVERRIDE; |
- virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE; |
- virtual gfx::Size GetMinimumSize() OVERRIDE; |
- virtual gfx::Size GetMaximumSize() OVERRIDE; |
- |
- private: |
- // views::ButtonListener implementation. |
- virtual void ButtonPressed(views::Button* sender, const ui::Event& event) |
- OVERRIDE; |
- |
- NativeAppWindowViews* window_; |
- views::Widget* frame_; |
- views::ImageButton* close_button_; |
- views::ImageButton* maximize_button_; |
- views::ImageButton* restore_button_; |
- views::ImageButton* minimize_button_; |
- |
- DISALLOW_COPY_AND_ASSIGN(ShellWindowFrameView); |
-}; |
const char ShellWindowFrameView::kViewClassName[] = |
"browser/ui/views/extensions/ShellWindowFrameView"; |
@@ -178,6 +124,8 @@ void ShellWindowFrameView::Init(views::Widget* frame) { |
#endif |
} |
+// views::NonClientFrameView implementation. |
+ |
gfx::Rect ShellWindowFrameView::GetBoundsForClientView() const { |
if (window_->frameless() || frame_->IsFullscreen()) |
return bounds(); |
@@ -274,6 +222,8 @@ void ShellWindowFrameView::GetWindowMask(const gfx::Size& size, |
// We got nothing to say about no window mask. |
} |
+// views::View implementation. |
+ |
gfx::Size ShellWindowFrameView::GetPreferredSize() { |
gfx::Size pref = frame_->client_view()->GetPreferredSize(); |
gfx::Rect bounds(0, 0, pref.width(), pref.height()); |
@@ -382,6 +332,8 @@ gfx::Size ShellWindowFrameView::GetMaximumSize() { |
return max_size; |
} |
+// views::ButtonListener implementation. |
+ |
void ShellWindowFrameView::ButtonPressed(views::Button* sender, |
const ui::Event& event) { |
DCHECK(!window_->frameless()); |
@@ -394,363 +346,3 @@ void ShellWindowFrameView::ButtonPressed(views::Button* sender, |
else if (sender == minimize_button_) |
frame_->Minimize(); |
} |
- |
-NativeAppWindowViews::NativeAppWindowViews( |
- ShellWindow* shell_window, |
- const ShellWindow::CreateParams& win_params) |
- : shell_window_(shell_window), |
- web_view_(NULL), |
- is_fullscreen_(false), |
- frameless_(win_params.frame == ShellWindow::CreateParams::FRAME_NONE) { |
- window_ = new views::Widget; |
- views::Widget::InitParams params(views::Widget::InitParams::TYPE_WINDOW); |
- params.delegate = this; |
- params.remove_standard_frame = true; |
- params.use_system_default_icon = true; |
- minimum_size_ = win_params.minimum_size; |
- maximum_size_ = win_params.maximum_size; |
- window_->Init(params); |
- gfx::Rect window_bounds = |
- window_->non_client_view()->GetWindowBoundsForClientBounds( |
- win_params.bounds); |
- // Center window if no position was specified. |
- if (win_params.bounds.x() == INT_MIN || win_params.bounds.y() == INT_MIN) { |
- window_->CenterWindow(window_bounds.size()); |
- } else { |
- window_->SetBounds(window_bounds); |
- } |
-#if defined(OS_WIN) && !defined(USE_AURA) |
- std::string app_name = web_app::GenerateApplicationNameFromExtensionId( |
- extension()->id()); |
- ui::win::SetAppIdForWindow( |
- ShellIntegration::GetAppModelIdForProfile( |
- UTF8ToWide(app_name), shell_window_->profile()->GetPath()), |
- GetWidget()->GetTopLevelWidget()->GetNativeWindow()); |
-#endif |
- |
- extension_keybinding_registry_.reset( |
- new ExtensionKeybindingRegistryViews(shell_window_->profile(), |
- window_->GetFocusManager(), |
- extensions::ExtensionKeybindingRegistry::PLATFORM_APPS_ONLY, |
- shell_window_)); |
- |
- OnViewWasResized(); |
- window_->AddObserver(this); |
-} |
- |
-views::View* NativeAppWindowViews::GetInitiallyFocusedView() { |
- return web_view_; |
-} |
- |
-bool NativeAppWindowViews::ShouldDescendIntoChildForEventHandling( |
- gfx::NativeView child, |
- const gfx::Point& location) { |
-#if defined(USE_AURA) |
- DCHECK_EQ(child, web_view_->web_contents()->GetView()->GetNativeView()); |
- // Shell window should claim mouse events that fall within the draggable |
- // region. |
- return !draggable_region_.get() || |
- !draggable_region_->contains(location.x(), location.y()); |
-#else |
- return true; |
-#endif |
-} |
- |
-void NativeAppWindowViews::OnFocus() { |
- web_view_->RequestFocus(); |
-} |
- |
-void NativeAppWindowViews::ViewHierarchyChanged( |
- bool is_add, views::View *parent, views::View *child) { |
- if (is_add && child == this) { |
- web_view_ = new views::WebView(NULL); |
- AddChildView(web_view_); |
- web_view_->SetWebContents(web_contents()); |
- } |
-} |
- |
-gfx::Size NativeAppWindowViews::GetMinimumSize() { |
- return minimum_size_; |
-} |
- |
-gfx::Size NativeAppWindowViews::GetMaximumSize() { |
- return maximum_size_; |
-} |
- |
-void NativeAppWindowViews::SetFullscreen(bool fullscreen) { |
- is_fullscreen_ = fullscreen; |
- window_->SetFullscreen(fullscreen); |
- // TODO(jeremya) we need to call RenderViewHost::ExitFullscreen() if we |
- // ever drop the window out of fullscreen in response to something that |
- // wasn't the app calling webkitCancelFullScreen(). |
-} |
- |
-bool NativeAppWindowViews::IsFullscreenOrPending() const { |
- return is_fullscreen_; |
-} |
- |
-NativeAppWindowViews::~NativeAppWindowViews() { |
- web_view_->SetWebContents(NULL); |
-} |
- |
-bool NativeAppWindowViews::IsActive() const { |
- return window_->IsActive(); |
-} |
- |
-bool NativeAppWindowViews::IsMaximized() const { |
- return window_->IsMaximized(); |
-} |
- |
-bool NativeAppWindowViews::IsMinimized() const { |
- return window_->IsMinimized(); |
-} |
- |
-bool NativeAppWindowViews::IsFullscreen() const { |
- return window_->IsFullscreen(); |
-} |
- |
-gfx::NativeWindow NativeAppWindowViews::GetNativeWindow() { |
- return window_->GetNativeWindow(); |
-} |
- |
-gfx::Rect NativeAppWindowViews::GetRestoredBounds() const { |
- return window_->GetRestoredBounds(); |
-} |
- |
-gfx::Rect NativeAppWindowViews::GetBounds() const { |
- return window_->GetWindowBoundsInScreen(); |
-} |
- |
-void NativeAppWindowViews::Show() { |
- if (window_->IsVisible()) { |
- window_->Activate(); |
- return; |
- } |
- |
- window_->Show(); |
-} |
- |
-void NativeAppWindowViews::ShowInactive() { |
- if (window_->IsVisible()) |
- return; |
- window_->ShowInactive(); |
-} |
- |
-void NativeAppWindowViews::Hide() { |
- window_->Hide(); |
-} |
- |
-void NativeAppWindowViews::Close() { |
- window_->Close(); |
-} |
- |
-void NativeAppWindowViews::Activate() { |
- window_->Activate(); |
-} |
- |
-void NativeAppWindowViews::Deactivate() { |
- window_->Deactivate(); |
-} |
- |
-void NativeAppWindowViews::Maximize() { |
- window_->Maximize(); |
-} |
- |
-void NativeAppWindowViews::Minimize() { |
- window_->Minimize(); |
-} |
- |
-void NativeAppWindowViews::Restore() { |
- window_->Restore(); |
-} |
- |
-void NativeAppWindowViews::SetBounds(const gfx::Rect& bounds) { |
- GetWidget()->SetBounds(bounds); |
-} |
- |
-void NativeAppWindowViews::FlashFrame(bool flash) { |
- window_->FlashFrame(flash); |
-} |
- |
-bool NativeAppWindowViews::IsAlwaysOnTop() const { |
- return false; |
-} |
- |
-void NativeAppWindowViews::DeleteDelegate() { |
- window_->RemoveObserver(this); |
- shell_window_->OnNativeClose(); |
-} |
- |
-bool NativeAppWindowViews::CanResize() const { |
- return maximum_size_.IsEmpty() || minimum_size_ != maximum_size_; |
-} |
- |
-bool NativeAppWindowViews::CanMaximize() const { |
- return maximum_size_.IsEmpty(); |
-} |
- |
-views::View* NativeAppWindowViews::GetContentsView() { |
- return this; |
-} |
- |
-views::NonClientFrameView* NativeAppWindowViews::CreateNonClientFrameView( |
- views::Widget* widget) { |
-#if defined(USE_ASH) |
- if (chrome::IsNativeViewInAsh(widget->GetNativeView()) && !frameless_) { |
- ash::CustomFrameViewAsh* frame = new ash::CustomFrameViewAsh(); |
- frame->Init(widget); |
- return frame; |
- } |
-#endif |
- ShellWindowFrameView* frame_view = new ShellWindowFrameView(this); |
- frame_view->Init(window_); |
- return frame_view; |
-} |
- |
-string16 NativeAppWindowViews::GetWindowTitle() const { |
- return shell_window_->GetTitle(); |
-} |
- |
-views::Widget* NativeAppWindowViews::GetWidget() { |
- return window_; |
-} |
- |
-const views::Widget* NativeAppWindowViews::GetWidget() const { |
- return window_; |
-} |
- |
-void NativeAppWindowViews::OnViewWasResized() { |
- // TODO(jeremya): this doesn't seem like a terribly elegant way to keep the |
- // window shape in sync. |
-#if defined(OS_WIN) && !defined(USE_AURA) |
- // Set the window shape of the RWHV. |
- DCHECK(window_); |
- DCHECK(web_view_); |
- gfx::Size sz = web_view_->size(); |
- int height = sz.height(), width = sz.width(); |
- int radius = 1; |
- gfx::Path path; |
- if (window_->IsMaximized() || window_->IsFullscreen()) { |
- // Don't round the corners when the window is maximized or fullscreen. |
- path.addRect(0, 0, width, height); |
- } else { |
- if (frameless_) { |
- path.moveTo(0, radius); |
- path.lineTo(radius, 0); |
- path.lineTo(width - radius, 0); |
- path.lineTo(width, radius); |
- } else { |
- // Don't round the top corners in chrome-style frame mode. |
- path.moveTo(0, 0); |
- path.lineTo(width, 0); |
- } |
- path.lineTo(width, height - radius - 1); |
- path.lineTo(width - radius - 1, height); |
- path.lineTo(radius + 1, height); |
- path.lineTo(0, height - radius - 1); |
- path.close(); |
- } |
- SetWindowRgn(web_contents()->GetNativeView(), path.CreateNativeRegion(), 1); |
- |
- SkRegion* rgn = new SkRegion; |
- if (!window_->IsFullscreen()) { |
- if (draggable_region()) |
- rgn->op(*draggable_region(), SkRegion::kUnion_Op); |
- if (!window_->IsMaximized()) { |
- if (frameless_) |
- rgn->op(0, 0, width, kResizeInsideBoundsSize, SkRegion::kUnion_Op); |
- rgn->op(0, 0, kResizeInsideBoundsSize, height, SkRegion::kUnion_Op); |
- rgn->op(width - kResizeInsideBoundsSize, 0, width, height, |
- SkRegion::kUnion_Op); |
- rgn->op(0, height - kResizeInsideBoundsSize, width, height, |
- SkRegion::kUnion_Op); |
- } |
- } |
- if (web_contents()->GetRenderViewHost()->GetView()) |
- web_contents()->GetRenderViewHost()->GetView()->SetClickthroughRegion(rgn); |
-#endif |
-} |
- |
-gfx::ImageSkia NativeAppWindowViews::GetWindowAppIcon() { |
- gfx::Image app_icon = shell_window_->app_icon(); |
- if (app_icon.IsEmpty()) |
- return GetWindowIcon(); |
- else |
- return *app_icon.ToImageSkia(); |
-} |
- |
-gfx::ImageSkia NativeAppWindowViews::GetWindowIcon() { |
- content::WebContents* web_contents = shell_window_->web_contents(); |
- if (web_contents) { |
- FaviconTabHelper* favicon_tab_helper = |
- FaviconTabHelper::FromWebContents(web_contents); |
- gfx::Image app_icon = favicon_tab_helper->GetFavicon(); |
- if (!app_icon.IsEmpty()) |
- return *app_icon.ToImageSkia(); |
- } |
- return gfx::ImageSkia(); |
-} |
- |
-bool NativeAppWindowViews::ShouldShowWindowTitle() const { |
- return false; |
-} |
- |
-void NativeAppWindowViews::OnWidgetMove() { |
- shell_window_->OnNativeWindowChanged(); |
-} |
- |
-void NativeAppWindowViews::OnWidgetVisibilityChanged(views::Widget* widget, |
- bool visible) { |
- shell_window_->OnNativeWindowChanged(); |
-} |
- |
-void NativeAppWindowViews::OnWidgetActivationChanged(views::Widget* widget, |
- bool active) { |
- shell_window_->OnNativeWindowChanged(); |
-} |
- |
-void NativeAppWindowViews::Layout() { |
- DCHECK(web_view_); |
- web_view_->SetBounds(0, 0, width(), height()); |
- OnViewWasResized(); |
-} |
- |
-void NativeAppWindowViews::UpdateWindowIcon() { |
- window_->UpdateWindowIcon(); |
-} |
- |
-void NativeAppWindowViews::UpdateWindowTitle() { |
- window_->UpdateWindowTitle(); |
-} |
- |
-void NativeAppWindowViews::UpdateDraggableRegions( |
- const std::vector<extensions::DraggableRegion>& regions) { |
- // Draggable region is not supported for non-frameless window. |
- if (!frameless_) |
- return; |
- |
- draggable_region_.reset(ShellWindow::RawDraggableRegionsToSkRegion(regions)); |
- OnViewWasResized(); |
-} |
- |
-void NativeAppWindowViews::HandleKeyboardEvent( |
- const content::NativeWebKeyboardEvent& event) { |
- unhandled_keyboard_event_handler_.HandleKeyboardEvent(event, |
- GetFocusManager()); |
-} |
- |
-void NativeAppWindowViews::RenderViewHostChanged() { |
- OnViewWasResized(); |
-} |
- |
-void NativeAppWindowViews::SaveWindowPlacement(const gfx::Rect& bounds, |
- ui::WindowShowState show_state) { |
- views::WidgetDelegate::SaveWindowPlacement(bounds, show_state); |
- shell_window_->OnNativeWindowChanged(); |
-} |
- |
-// static |
-NativeAppWindow* NativeAppWindow::Create( |
- ShellWindow* shell_window, const ShellWindow::CreateParams& params) { |
- return new NativeAppWindowViews(shell_window, params); |
-} |