| 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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
 | // Copyright 2008, Google Inc.
// All rights reserved.
//
// Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are
// met:
//
//    * Redistributions of source code must retain the above copyright
// notice, this list of conditions and the following disclaimer.
//    * Redistributions in binary form must reproduce the above
// copyright notice, this list of conditions and the following disclaimer
// in the documentation and/or other materials provided with the
// distribution.
//    * Neither the name of Google Inc. nor the names of its
// contributors may be used to endorse or promote products derived from
// this software without specific prior written permission.
//
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
#ifndef CHROME_BROWSER_TABS_TAB_RENDERER_H__
#define CHROME_BROWSER_TABS_TAB_RENDERER_H__
#include "base/gfx/point.h"
#include "chrome/common/animation.h"
#include "chrome/common/slide_animation.h"
#include "chrome/common/notification_service.h"
#include "chrome/views/button.h"
#include "chrome/views/menu.h"
#include "chrome/views/view.h"
class TabContents;
///////////////////////////////////////////////////////////////////////////////
//
// TabRenderer
//
//  A View that renders a Tab, either in a TabStrip or in a DraggedTabView.
//
///////////////////////////////////////////////////////////////////////////////
class TabRenderer : public ChromeViews::View,
                    public AnimationDelegate {
 public:
  // Possible animation states.
  enum AnimationState {
    ANIMATION_NONE,
    ANIMATION_WAITING,
    ANIMATION_LOADING
  };
  TabRenderer();
  virtual ~TabRenderer();
  // Updates the data the Tab uses to render itself from the specified
  // TabContents.
  void UpdateData(TabContents* contents);
  // Updates the display to reflect the contents of this TabRenderer's model.
  void UpdateFromModel();
  // Returns true if the Tab is selected, false otherwise.
  virtual bool IsSelected() const;
  // Advance the Loading Animation to the next frame, or hide the animation if
  // the tab isn't loading.
  void ValidateLoadingAnimation(AnimationState animation_state);
  // AnimationDelegate implementation.
  virtual void AnimationProgressed(const Animation* animation);
  // Returns the minimum possible size of a single unselected Tab.
  static gfx::Size GetMinimumSize();
  // Returns the minimum possible size of a selected Tab. Selected tabs must
  // always show a close button and have a larger minimum size than unselected
  // tabs.
  static gfx::Size GetMinimumSelectedSize();
  // Returns the preferred size of a single Tab, assuming space is
  // available.
  static gfx::Size GetStandardSize();
  // Remove invalid characters from the title (e.g. newlines) that may
  // interfere with rendering.
  static void FormatTitleForDisplay(std::wstring* title);
 protected:
  ChromeViews::Button* close_button() const { return close_button_; }
  const gfx::Rect& title_bounds() const { return title_bounds_; }
  // Returns the title of the Tab.
  std::wstring GetTitle() const;
 private:
  // Overridden from ChromeViews::View:
  virtual void Paint(ChromeCanvas* canvas);
  virtual void Layout();
  virtual void DidChangeBounds(const CRect& previous, const CRect& current);
  virtual void OnMouseEntered(const ChromeViews::MouseEvent& event);
  virtual void OnMouseExited(const ChromeViews::MouseEvent& event);
  // Starts/Stops the crash animation.
  void StartCrashAnimation();
  void StopCrashAnimation();
  // Return true if the crash animation is currently running.
  bool IsPerformingCrashAnimation() const;
  // Set the temporary offset for the favicon. This is used during animation.
  void SetFavIconHidingOffset(int offset);
  void DisplayCrashedFavIcon();
  void ResetCrashedFavIcon();
  // Paint various portions of the Tab
  void PaintInactiveTabBackground(ChromeCanvas* canvas);
  void PaintActiveTabBackground(ChromeCanvas* canvas);
  void PaintHoverTabBackground(ChromeCanvas* canvas, double opacity);
  void PaintLoadingAnimation(ChromeCanvas* canvas);
  // Returns the number of favicon-size elements that can fit in the tab's
  // current size.
  int IconCapacity() const;
  // Returns whether the Tab should display a favicon.
  bool ShouldShowIcon() const;
  // Returns whether the Tab should display a close button.
  bool ShouldShowCloseBox() const;
  // The bounds of various sections of the display.
  gfx::Rect favicon_bounds_;
  gfx::Rect download_icon_bounds_;
  gfx::Rect title_bounds_;
  // Current state of the animation.
  AnimationState animation_state_;
  // The current index into the Animation image strip.
  int animation_frame_;
  // Close Button.
  ChromeViews::Button* close_button_;
  // Hover animation.
  scoped_ptr<SlideAnimation> hover_animation_;
  // Model data. We store this here so that we don't need to ask the underlying
  // model, which is tricky since instances of this object can outlive the
  // corresponding objects in the underlying model.
  struct TabData {
    SkBitmap favicon;
    std::wstring title;
    bool loading;
    bool crashed;
    bool off_the_record;
    bool show_icon;
    bool show_download_icon;
  };
  TabData data_;
  // Whether we're showing the icon. It is cached so that we can detect when it
  // changes and layout appropriately.
  bool showing_icon_;
  // Whether we are showing the download icon. Comes from the model.
  bool showing_download_icon_;
  // Whether we are showing the close button. It is cached so that we can
  // detect when it changes and layout appropriately.
  bool showing_close_button_;
  // The offset used to animate the favicon location.
  int fav_icon_hiding_offset_;
  // The animation object used to swap the favicon with the sad tab icon.
  class FavIconCrashAnimation;
  FavIconCrashAnimation* crash_animation_;
  bool should_display_crashed_favicon_;
  DISALLOW_EVIL_CONSTRUCTORS(TabRenderer);
};
#endif CHROME_BROWSER_TABS_TAB_RENDERER_H__
 |