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

Unified Diff: ui/views/controls/styled_label.h

Issue 12543032: Add views::RichLabel, a class which creates multi-line text with mixed (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: other interface Created 7 years, 9 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | ui/views/controls/styled_label.cc » ('j') | ui/views/controls/styled_label.cc » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/views/controls/styled_label.h
diff --git a/ui/views/controls/styled_label.h b/ui/views/controls/styled_label.h
new file mode 100644
index 0000000000000000000000000000000000000000..4779f75eef980153ed4e68646cbbfb4272b629e3
--- /dev/null
+++ b/ui/views/controls/styled_label.h
@@ -0,0 +1,76 @@
+// Copyright 2013 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_VIEWS_CONTROLS_STYLED_LABEL_H_
+#define UI_VIEWS_CONTROLS_STYLED_LABEL_H_
+
+#include <map>
+#include <queue>
+
+#include "base/string16.h"
+#include "ui/base/range/range.h"
+#include "ui/gfx/size.h"
+#include "ui/views/controls/link_listener.h"
+#include "ui/views/view.h"
+
+namespace views {
+
+class Link;
+class StyledLabelListener;
+
+// A class which can apply mixed styles to a block of text. Currently, text is
+// always multiline, and the only style that may be applied is linkifying ranges
+// of text.
+class VIEWS_EXPORT StyledLabel : public View,
+ public LinkListener {
msw 2013/03/13 03:22:07 nit: fits on the line above.
Evan Stade 2013/03/14 00:30:46 Done.
+ public:
+ explicit StyledLabel(const string16& text, StyledLabelListener* listener);
msw 2013/03/13 03:22:07 Could you take a LinkListener instead and nix Styl
Evan Stade 2013/03/14 00:30:46 no, see below.
+ virtual ~StyledLabel();
+
+ // Marks the given range within |text_| as a link.
+ void SetLink(const ui::Range& range);
msw 2013/03/13 03:22:07 Shouldn't this let users supply the associated Lin
Evan Stade 2013/03/14 00:30:46 No. The fact that this class uses a Link view is a
sky 2013/03/14 14:43:58 That is definitely the case, but making this class
Evan Stade 2013/03/14 19:07:40 there's not always going to be a GURL associated w
msw 2013/03/14 23:24:30 Hmm, I see your point. I guess tracking links by r
+
+ // View implementation:
+ virtual int GetHeightForWidth(int w) OVERRIDE;
+ virtual void Layout() OVERRIDE;
+
+ // LinkListener implementation:
+ virtual void LinkClicked(Link* source, int event_flags) OVERRIDE;
+
+ private:
+ struct LinkRange {
msw 2013/03/13 03:22:07 Try replacing LinkRange, link_ranges_, & link_targ
Evan Stade 2013/03/14 00:30:46 I tried doing this, but it's not pretty because ui
+ LinkRange(const ui::Range& range) : range(range) {}
+ ~LinkRange() {}
+
+ bool operator<(const LinkRange& other) const;
+
+ ui::Range range;
+ };
+
+ // Calculates how to layout child views, creates them and sets their size
+ // and position. |width| is the horizontal space, in pixels, that the view
+ // has to work with. If |dry_run| is true, the view hierarchy is not touched.
+ // The return value is the height in pixels.
+ int CalculateAndDoLayout(int width, bool dry_run);
msw 2013/03/13 03:22:07 nit: Maybe GetHeightForWidthAndLayout with s/dry_r
Evan Stade 2013/03/14 00:30:46 I prefer the current naming but can change it if y
+
+ // The text to display.
+ string16 text_;
+
+ // The listener that will be informed of link clicks.
+ StyledLabelListener* listener_;
+
+ // The ranges that should be linkified, sorted by start position.
+ std::priority_queue<LinkRange> link_ranges_;
+
+ // A mapping from Link* control to the range it corresponds to in |text_|.
+ std::map<Link*, ui::Range> link_targets_;
+
+ // This variable saves the result of the last GetHeightForWidth call in order
+ // to avoid repeated calculation.
+ gfx::Size calculated_size_;
+};
+
+} // namespace views
+
+#endif // UI_VIEWS_CONTROLS_STYLED_LABEL_H_
« no previous file with comments | « no previous file | ui/views/controls/styled_label.cc » ('j') | ui/views/controls/styled_label.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698