Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(409)

Side by Side Diff: ui/views/examples/multiline_example.cc

Issue 16867016: Windows implementation of multiline RenderText (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Alexei's comments 2 Created 7 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "ui/views/examples/multiline_example.h" 5 #include "ui/views/examples/multiline_example.h"
6 6
7 #include "base/strings/utf_string_conversions.h" 7 #include "base/strings/utf_string_conversions.h"
8 #include "ui/base/events/event.h" 8 #include "ui/base/events/event.h"
9 #include "ui/gfx/render_text.h" 9 #include "ui/gfx/render_text.h"
10 #include "ui/views/controls/button/checkbox.h"
msw 2013/08/15 02:44:17 nit: remove this (included by header)
ckocagil 2013/08/20 21:25:07 Done.
10 #include "ui/views/controls/label.h" 11 #include "ui/views/controls/label.h"
11 #include "ui/views/controls/textfield/textfield.h" 12 #include "ui/views/controls/textfield/textfield.h"
13 #include "ui/views/layout/fill_layout.h"
msw 2013/08/15 02:44:17 nit: remove this (unused)
ckocagil 2013/08/20 21:25:07 Done.
12 #include "ui/views/layout/grid_layout.h" 14 #include "ui/views/layout/grid_layout.h"
13 #include "ui/views/view.h" 15 #include "ui/views/view.h"
14 16
15 namespace views { 17 namespace views {
16 namespace examples { 18 namespace examples {
17 19
18 // A simple View that hosts a RenderText object. 20 // A simple View that hosts a RenderText object.
19 class MultilineExample::RenderTextView : public View { 21 class MultilineExample::RenderTextView : public View {
20 public: 22 public:
21 explicit RenderTextView(gfx::RenderText* render_text) 23 explicit RenderTextView(gfx::RenderText* render_text)
22 : render_text_(render_text) { 24 : render_text_(render_text) {
25 render_text_->SetHorizontalAlignment(gfx::ALIGN_CENTER);
23 render_text_->SetColor(SK_ColorBLACK); 26 render_text_->SetColor(SK_ColorBLACK);
27 render_text_->SetMultiline(true);
28 render_text_->set_clip_to_display_rect(false);
msw 2013/08/15 02:44:17 Hmm, this is no longer used and it's underlying co
ckocagil 2013/08/20 21:25:07 Done, removed.
24 set_border(Border::CreateSolidBorder(2, SK_ColorGRAY)); 29 set_border(Border::CreateSolidBorder(2, SK_ColorGRAY));
25 } 30 }
26 31
27 virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE { 32 virtual void OnPaint(gfx::Canvas* canvas) OVERRIDE {
28 View::OnPaint(canvas); 33 View::OnPaint(canvas);
29 render_text_->Draw(canvas); 34 render_text_->Draw(canvas);
30 } 35 }
31 36
32 virtual gfx::Size GetPreferredSize() OVERRIDE { 37 virtual gfx::Size GetPreferredSize() OVERRIDE {
33 return gfx::Size(0, 38 return gfx::Size(0,
34 render_text_->font_list().GetHeight() + GetInsets().height()); 39 render_text_->font_list().GetHeight() + GetInsets().height());
35 } 40 }
36 41
42 virtual int GetHeightForWidth(int w) OVERRIDE {
43 if (w == 0) // TODO(ckocagil): Why does this happen?
msw 2013/08/15 02:44:17 nit: resolve this (you can just remove the TODO if
ckocagil 2013/08/20 21:25:07 Leaving the TODO here as we decided on IM.
44 return View::GetHeightForWidth(w);
45 gfx::Rect rect = render_text_->display_rect();
46 rect.set_width(w - GetInsets().width());
47 render_text_->SetDisplayRect(rect);
48 return render_text_->GetMultilineTextSize().height() + GetInsets().height();
49 }
50
37 void SetText(const string16& new_contents) { 51 void SetText(const string16& new_contents) {
52 ui::Range test_range(1, 21);
msw 2013/08/15 02:44:17 nit: move declaration below the SetText call.
ckocagil 2013/08/20 21:25:07 Done.
38 render_text_->SetText(new_contents); 53 render_text_->SetText(new_contents);
54 render_text_->MoveCursorTo(gfx::SelectionModel(test_range,
55 gfx::CURSOR_FORWARD));
56 render_text_->set_selection_background_focused_color(0xFFFF0000);
57 render_text_->set_focused(true);
58 render_text_->ApplyStyle(gfx::DIAGONAL_STRIKE, true, test_range);
59 render_text_->ApplyStyle(gfx::UNDERLINE, true, test_range);
60 InvalidateLayout();
39 SchedulePaint(); 61 SchedulePaint();
40 } 62 }
41 63
42 private: 64 private:
43 virtual void OnBoundsChanged(const gfx::Rect& previous_bounds) OVERRIDE { 65 virtual void OnBoundsChanged(const gfx::Rect& previous_bounds) OVERRIDE {
44 gfx::Rect bounds = GetLocalBounds(); 66 gfx::Rect bounds = GetLocalBounds();
45 bounds.Inset(GetInsets()); 67 bounds.Inset(GetInsets());
46 render_text_->SetDisplayRect(bounds); 68 render_text_->SetDisplayRect(bounds);
47 } 69 }
48 70
49 scoped_ptr<gfx::RenderText> render_text_; 71 scoped_ptr<gfx::RenderText> render_text_;
50 72
51 DISALLOW_COPY_AND_ASSIGN(RenderTextView); 73 DISALLOW_COPY_AND_ASSIGN(RenderTextView);
52 }; 74 };
53 75
54 MultilineExample::MultilineExample() 76 MultilineExample::MultilineExample()
55 : ExampleBase("Multiline RenderText"), 77 : ExampleBase("Multiline RenderText"),
78 top_container_(NULL),
56 render_text_view_(NULL), 79 render_text_view_(NULL),
57 label_(NULL), 80 label_(NULL),
81 label_checkbox_(NULL),
58 textfield_(NULL) { 82 textfield_(NULL) {
59 } 83 }
60 84
61 MultilineExample::~MultilineExample() { 85 MultilineExample::~MultilineExample() {
62 } 86 }
63 87
64 void MultilineExample::CreateExampleView(View* container) { 88 void MultilineExample::CreateExampleView(View* container) {
65 const char kTestString[] = "test string asdf 1234 test string asdf 1234 " 89 const char kTestString[] = "test string asdf 1234 test string asdf 1234 "
66 "test string asdf 1234 test string asdf 1234"; 90 "test string asdf 1234 test string asdf 1234";
67 91
92 top_container_ = container;
msw 2013/08/15 02:44:17 nit: |example_container_| seems clearer.
ckocagil 2013/08/20 21:25:07 Done.
93
68 gfx::RenderText* render_text = gfx::RenderText::CreateInstance(); 94 gfx::RenderText* render_text = gfx::RenderText::CreateInstance();
msw 2013/08/15 02:44:17 Move this to the RenderTextView ctor initializatio
ckocagil 2013/08/20 21:25:07 Done.
69 render_text->SetText(ASCIIToUTF16(kTestString));
70 render_text->SetHorizontalAlignment(gfx::ALIGN_CENTER);
71 95
72 render_text_view_ = new RenderTextView(render_text); 96 render_text_view_ = new RenderTextView(render_text);
97 render_text_view_->SetText(ASCIIToUTF16(kTestString));
73 98
74 label_ = new Label(); 99 label_ = new Label();
75 label_->SetText(ASCIIToUTF16(kTestString)); 100 label_->SetText(ASCIIToUTF16(kTestString));
76 label_->SetMultiLine(true); 101 label_->SetMultiLine(true);
77 label_->set_border(Border::CreateSolidBorder(2, SK_ColorCYAN)); 102 label_->set_border(Border::CreateSolidBorder(2, SK_ColorCYAN));
78 103
104 label_checkbox_ = new Checkbox(string16());
105 label_checkbox_->SetChecked(true);
106 label_checkbox_->set_listener(this);
107 label_checkbox_->set_request_focus_on_press(false);
108
79 textfield_ = new Textfield(); 109 textfield_ = new Textfield();
80 textfield_->SetController(this); 110 textfield_->SetController(this);
81 textfield_->SetText(ASCIIToUTF16(kTestString)); 111 textfield_->SetText(ASCIIToUTF16(kTestString));
82 112
83 GridLayout* layout = new GridLayout(container); 113 GridLayout* layout = new GridLayout(container);
84 container->SetLayoutManager(layout); 114 container->SetLayoutManager(layout);
85 115
86 ColumnSet* column_set = layout->AddColumnSet(0); 116 ColumnSet* column_set = layout->AddColumnSet(0);
87 column_set->AddColumn(GridLayout::LEADING, GridLayout::FILL, 117 column_set->AddColumn(GridLayout::LEADING, GridLayout::CENTER,
118 0.0f, GridLayout::USE_PREF, 0, 0);
119 column_set->AddColumn(GridLayout::LEADING, GridLayout::CENTER,
88 0.0f, GridLayout::USE_PREF, 0, 0); 120 0.0f, GridLayout::USE_PREF, 0, 0);
89 column_set->AddColumn(GridLayout::FILL, GridLayout::FILL, 121 column_set->AddColumn(GridLayout::FILL, GridLayout::FILL,
90 1.0f, GridLayout::FIXED, 0, 0); 122 1.0f, GridLayout::FIXED, 0, 0);
91 123
92 layout->StartRow(0, 0); 124 layout->StartRow(0, 0);
125 layout->SkipColumns(1);
93 layout->AddView(new Label(ASCIIToUTF16("gfx::RenderText:"))); 126 layout->AddView(new Label(ASCIIToUTF16("gfx::RenderText:")));
94 layout->AddView(render_text_view_); 127 layout->AddView(render_text_view_);
95 128
96 layout->StartRow(0, 0); 129 layout->StartRow(0, 0);
130 layout->AddView(label_checkbox_);
97 layout->AddView(new Label(ASCIIToUTF16("views::Label:"))); 131 layout->AddView(new Label(ASCIIToUTF16("views::Label:")));
98 layout->AddView(label_); 132 layout->AddView(label_);
99 133
100 layout->StartRow(0, 0); 134 layout->StartRow(0, 0);
135 layout->SkipColumns(1);
101 layout->AddView(new Label(ASCIIToUTF16("Sample Text:"))); 136 layout->AddView(new Label(ASCIIToUTF16("Sample Text:")));
102 layout->AddView(textfield_); 137 layout->AddView(textfield_);
103 } 138 }
104 139
105 void MultilineExample::ContentsChanged(Textfield* sender, 140 void MultilineExample::ContentsChanged(Textfield* sender,
106 const string16& new_contents) { 141 const string16& new_contents) {
107 render_text_view_->SetText(new_contents); 142 render_text_view_->SetText(new_contents);
108 label_->SetText(new_contents); 143 if (label_checkbox_->checked())
144 label_->SetText(new_contents);
145 top_container_->Layout();
msw 2013/08/15 02:44:17 Can you just InvalidateLayout instead of Layout+Sc
ckocagil 2013/08/20 21:25:07 It seems to need to be both laid out and painted.
146 top_container_->SchedulePaint();
109 } 147 }
110 148
111 bool MultilineExample::HandleKeyEvent(Textfield* sender, 149 bool MultilineExample::HandleKeyEvent(Textfield* sender,
112 const ui::KeyEvent& key_event) { 150 const ui::KeyEvent& key_event) {
113 return false; 151 return false;
114 } 152 }
115 153
154 void MultilineExample::ButtonPressed(Button* sender, const ui::Event& event) {
155 if (sender != label_checkbox_)
msw 2013/08/15 02:44:17 nit: just DCHECK this
ckocagil 2013/08/20 21:25:07 Done.
156 return;
157 if (label_checkbox_->checked())
158 label_->SetText(textfield_->text());
159 else
160 label_->SetText(string16());
161 top_container_->Layout();
162 top_container_->SchedulePaint();
163 }
164
116 } // namespace examples 165 } // namespace examples
117 } // namespace views 166 } // namespace views
OLDNEW
« ui/gfx/render_text_win.cc ('K') | « ui/views/examples/multiline_example.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698