blob: 37d8d9998334ed95614ffc0a320609e6aac41b74 (
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
49
50
51
52
53
54
55
56
|
// Copyright (c) 2006-2008 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 CHROME_BROWSER_VIEWS_SAD_TAB_H__
#define CHROME_BROWSER_VIEWS_SAD_TAB_H__
#include "chrome/common/gfx/chrome_font.h"
#include "chrome/views/view.h"
///////////////////////////////////////////////////////////////////////////////
//
// SadTabView
//
// A views::View subclass used to render the presentation of the crashed
// "sad tab" in the browser window when a renderer is destroyed unnaturally.
//
// Note that since this view is not (currently) part of a Container or
// RootView hierarchy, it cannot respond to events or contain controls that
// do, right now it is used simply to render. Adding an extra Container to
// WebContents seemed like a lot of complexity. Ideally, perhaps WebContents'
// view portion would itself become a Container in the future, then event
// processing will work.
//
///////////////////////////////////////////////////////////////////////////////
class SadTabView : public views::View {
public:
SadTabView();
virtual ~SadTabView() {}
// Overridden from views::View:
virtual void Paint(ChromeCanvas* canvas);
virtual void Layout();
private:
static void InitClass();
// Assorted resources for display.
static SkBitmap* sad_tab_bitmap_;
static ChromeFont title_font_;
static ChromeFont message_font_;
static std::wstring title_;
static std::wstring message_;
static int title_width_;
// Regions within the display for different components, populated by
// Layout().
gfx::Rect icon_bounds_;
gfx::Rect title_bounds_;
gfx::Rect message_bounds_;
DISALLOW_EVIL_CONSTRUCTORS(SadTabView);
};
#endif // #ifndef CHROME_BROWSER_VIEWS_SAD_TAB_H__
|