summaryrefslogtreecommitdiffstats
path: root/views/controls/native_control_gtk.h
blob: ce2f187c519e3c569d88b6c6c36cddc278d7fd4f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
// Copyright (c) 2009 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 VIEWS_CONTROLS_NATIVE_CONTROL_GTK_H_
#define VIEWS_CONTROLS_NATIVE_CONTROL_GTK_H_

#include <gtk/gtk.h>

#include "views/controls/native/native_view_host.h"

namespace views {

// A View that hosts a native control.
class NativeControlGtk : public NativeViewHost {
 public:
  NativeControlGtk();
  virtual ~NativeControlGtk();

  // Overridden from View:
  virtual void SetEnabled(bool enabled);

 protected:
  virtual void ViewHierarchyChanged(bool is_add, View *parent, View *child);
  virtual void VisibilityChanged(View* starting_from, bool is_visible);
  virtual void Focus();

  // Called when the NativeControlGtk is attached to a View hierarchy with a
  // valid Widget. The NativeControlGtk should use this opportunity to create
  // its associated GtkWidget.
  virtual void CreateNativeControl() = 0;

  // MUST be called by the subclass implementation of |CreateNativeControl|
  // immediately after creating the control GtkWidget, otherwise it won't be
  // attached to the GtkView and will be effectively orphaned.
  virtual void NativeControlCreated(GtkWidget* widget);

 private:
  static void CallFocusIn(GtkWidget* widget,
                          GdkEventFocus* event,
                          NativeControlGtk* button);

  DISALLOW_COPY_AND_ASSIGN(NativeControlGtk);
};

}  // namespace views

#endif  // #ifndef VIEWS_CONTROLS_NATIVE_CONTROL_GTK_H_