// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef UI_AURA_LAYOUT_MANAGER_H_
#define UI_AURA_LAYOUT_MANAGER_H_
#include "base/basictypes.h"
#include "ui/aura/aura_export.h"
namespace gfx {
class Rect;
}
namespace aura {
class Window;
// An interface implemented by an object that places child windows.
class AURA_EXPORT LayoutManager {
public:
LayoutManager();
virtual ~LayoutManager();
// Invoked when the window is resized.
virtual void OnWindowResized() = 0;
// Invoked when the window |child| has been added.
virtual void OnWindowAddedToLayout(Window* child) = 0;
// Invoked prior to removing |window|.
virtual void OnWillRemoveWindowFromLayout(Window* child) = 0;
// Invoked after removing |window|.
virtual void OnWindowRemovedFromLayout(Window* child) = 0;
// Invoked when the |SetVisible()| is invoked on the window |child|.
// |visible| is the value supplied to |SetVisible()|. If |visible| is true,
// window->IsVisible() may still return false. See description in
// Window::IsVisible() for details.
virtual void OnChildWindowVisibilityChanged(Window* child, bool visible) = 0;
// Invoked when |Window::SetBounds| is called on |child|.
// Implementation must call |SetChildBoundsDirect| to change the
// |child|'s bounds. LayoutManager may modify |requested_bounds|
// before applying, or ignore the request.
virtual void SetChildBounds(Window* child,
const gfx::Rect& requested_bounds) = 0;
protected:
// Sets the child's bounds forcibly. LayoutManager is responsible
// for checking the state and make sure the bounds are correctly
// adjusted.
void SetChildBoundsDirect(aura::Window* child, const gfx::Rect& bounds);
};
} // namespace aura
#endif // UI_AURA_LAYOUT_MANAGER_H_