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

Side by Side Diff: services/keyboard_native/key_layout.cc

Issue 1149293002: Add the ability for keys to be drawn as an image. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Switch back to embedding with files downloading via gclient sync Created 5 years, 7 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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "base/bind.h" 5 #include "base/bind.h"
6 #include "base/bind_helpers.h" 6 #include "base/bind_helpers.h"
7 #include "base/macros.h" 7 #include "base/macros.h"
8 #include "services/keyboard_native/kActionIcon.h"
9 #include "services/keyboard_native/kDeleteIcon.h"
10 #include "services/keyboard_native/kLowerCaseIcon.h"
11 #include "services/keyboard_native/kUpperCaseIcon.h"
8 #include "services/keyboard_native/key_layout.h" 12 #include "services/keyboard_native/key_layout.h"
9 #include "skia/ext/refptr.h" 13 #include "skia/ext/refptr.h"
10 #include "third_party/skia/include/core/SkTypeface.h" 14 #include "third_party/skia/include/core/SkTypeface.h"
15 #include "ui/gfx/codec/png_codec.h"
11 16
12 namespace keyboard { 17 namespace keyboard {
13 18
14 KeyLayout::TextKey::TextKey( 19 KeyLayout::TextKey::TextKey(
15 const char* text, 20 const char* text,
16 base::Callback<void(const TextKey&)> touch_up_callback) 21 base::Callback<void(const TextKey&)> touch_up_callback)
17 : text_(text), touch_up_callback_(touch_up_callback) { 22 : text_(text), touch_up_callback_(touch_up_callback) {
18 } 23 }
19 24
20 KeyLayout::TextKey::~TextKey() { 25 KeyLayout::TextKey::~TextKey() {
21 } 26 }
22 27
23 void KeyLayout::TextKey::Draw(SkCanvas* canvas, 28 void KeyLayout::TextKey::Draw(SkCanvas* canvas,
24 SkPaint paint, 29 SkPaint paint,
25 const gfx::RectF& rect) { 30 const gfx::RectF& rect) {
26 float text_baseline_offset = rect.height() / 5.0f; 31 float text_baseline_offset = rect.height() / 5.0f;
27 canvas->drawText(text_, strlen(text_), rect.x() + (rect.width() / 2.0f), 32 canvas->drawText(text_, strlen(text_), rect.x() + (rect.width() / 2.0f),
28 rect.y() + rect.height() - text_baseline_offset, paint); 33 rect.y() + rect.height() - text_baseline_offset, paint);
29 } 34 }
30 35
31 const char* KeyLayout::TextKey::ToText() const { 36 const char* KeyLayout::TextKey::ToText() const {
32 return text_; 37 return text_;
33 } 38 }
34 39
35 void KeyLayout::TextKey::OnTouchUp() { 40 void KeyLayout::TextKey::OnTouchUp() {
36 touch_up_callback_.Run(*this); 41 touch_up_callback_.Run(*this);
37 } 42 }
38 43
44 KeyLayout::ImageKey::ImageKey(
45 const char* text,
jamesr 2015/05/27 23:30:31 does this use |text| ?
APW 2015/05/28 17:54:25 |text| is used by the TextKey as a fallback in-cas
46 base::Callback<void(const TextKey&)> touch_up_callback,
47 const mojo::embed::Data& data)
48 : TextKey(text, touch_up_callback), bitmap_() {
49 bool result = gfx::PNGCodec::Decode(
50 reinterpret_cast<const unsigned char*>(data.data), data.size, &bitmap_);
51 DCHECK(result);
52 DCHECK(bitmap_.width() > 0);
53 DCHECK(bitmap_.height() > 0);
54 }
55
56 KeyLayout::ImageKey::~ImageKey() {
57 }
58
59 void KeyLayout::ImageKey::Draw(SkCanvas* canvas,
60 SkPaint paint,
61 const gfx::RectF& rect) {
62 float width_scale = rect.width() / bitmap_.width();
63 float height_scale = rect.height() / bitmap_.height();
64 float scale = width_scale > height_scale ? height_scale : width_scale;
65 float target_width = bitmap_.width() * scale;
66 float target_height = bitmap_.height() * scale;
67 float delta_width = rect.width() - target_width;
68 float target_x = rect.x() + (delta_width / 2.0f);
69 float delta_height = rect.height() - target_height;
70 float target_y = rect.y() + (delta_height / 2.0f);
71 canvas->drawBitmapRect(bitmap_, SkRect::MakeXYWH(target_x, target_y,
72 target_width, target_height),
73 &paint);
74 }
75
39 KeyLayout::KeyLayout() 76 KeyLayout::KeyLayout()
40 : on_text_callback_(), 77 : on_text_callback_(),
41 layout_(&letters_layout_), 78 layout_(&letters_layout_),
42 key_map_(&lower_case_key_map_), 79 key_map_(&lower_case_key_map_),
43 weak_factory_(this) { 80 weak_factory_(this) {
44 InitLayouts(); 81 InitLayouts();
45 InitKeyMaps(); 82 InitKeyMaps();
46 } 83 }
47 84
48 KeyLayout::~KeyLayout() { 85 KeyLayout::~KeyLayout() {
(...skipping 165 matching lines...) Expand 10 before | Expand all | Expand 10 after
214 base::Bind(&KeyLayout::OnKeyDelete, weak_factory_.GetWeakPtr()); 251 base::Bind(&KeyLayout::OnKeyDelete, weak_factory_.GetWeakPtr());
215 base::Callback<void(const TextKey&)> switch_to_upper_case_callback = 252 base::Callback<void(const TextKey&)> switch_to_upper_case_callback =
216 base::Bind(&KeyLayout::OnKeySwitchToUpperCase, 253 base::Bind(&KeyLayout::OnKeySwitchToUpperCase,
217 weak_factory_.GetWeakPtr()); 254 weak_factory_.GetWeakPtr());
218 base::Callback<void(const TextKey&)> switch_to_lower_case_callback = 255 base::Callback<void(const TextKey&)> switch_to_lower_case_callback =
219 base::Bind(&KeyLayout::OnKeySwitchToLowerCase, 256 base::Bind(&KeyLayout::OnKeySwitchToLowerCase,
220 weak_factory_.GetWeakPtr()); 257 weak_factory_.GetWeakPtr());
221 base::Callback<void(const TextKey&)> switch_to_symbols_callback = 258 base::Callback<void(const TextKey&)> switch_to_symbols_callback =
222 base::Bind(&KeyLayout::OnKeySwitchToSymbols, weak_factory_.GetWeakPtr()); 259 base::Bind(&KeyLayout::OnKeySwitchToSymbols, weak_factory_.GetWeakPtr());
223 260
261 ImageKey* switch_to_upper_case_image_key = new ImageKey(
262 "/\\", switch_to_upper_case_callback, keyboard_native::kUpperCaseIcon);
263 ImageKey* switch_to_lower_case_image_key = new ImageKey(
264 "\\/", switch_to_lower_case_callback, keyboard_native::kLowerCaseIcon);
265 ImageKey* delete_image_key =
266 new ImageKey("<-", delete_callback, keyboard_native::kDeleteIcon);
267 ImageKey* action_image_key =
268 new ImageKey(":)", do_nothing_callback, keyboard_native::kActionIcon);
269
224 std::vector<Key*> lower_case_key_map_row_one = { 270 std::vector<Key*> lower_case_key_map_row_one = {
225 new TextKey("q", emit_text_callback), 271 new TextKey("q", emit_text_callback),
226 new TextKey("w", emit_text_callback), 272 new TextKey("w", emit_text_callback),
227 new TextKey("e", emit_text_callback), 273 new TextKey("e", emit_text_callback),
228 new TextKey("r", emit_text_callback), 274 new TextKey("r", emit_text_callback),
229 new TextKey("t", emit_text_callback), 275 new TextKey("t", emit_text_callback),
230 new TextKey("y", emit_text_callback), 276 new TextKey("y", emit_text_callback),
231 new TextKey("u", emit_text_callback), 277 new TextKey("u", emit_text_callback),
232 new TextKey("o", emit_text_callback), 278 new TextKey("o", emit_text_callback),
233 new TextKey("i", emit_text_callback), 279 new TextKey("i", emit_text_callback),
234 new TextKey("p", emit_text_callback)}; 280 new TextKey("p", emit_text_callback)};
235 281
236 std::vector<Key*> lower_case_key_map_row_two = { 282 std::vector<Key*> lower_case_key_map_row_two = {
237 new TextKey("a", emit_text_callback), 283 new TextKey("a", emit_text_callback),
238 new TextKey("s", emit_text_callback), 284 new TextKey("s", emit_text_callback),
239 new TextKey("d", emit_text_callback), 285 new TextKey("d", emit_text_callback),
240 new TextKey("f", emit_text_callback), 286 new TextKey("f", emit_text_callback),
241 new TextKey("g", emit_text_callback), 287 new TextKey("g", emit_text_callback),
242 new TextKey("h", emit_text_callback), 288 new TextKey("h", emit_text_callback),
243 new TextKey("j", emit_text_callback), 289 new TextKey("j", emit_text_callback),
244 new TextKey("k", emit_text_callback), 290 new TextKey("k", emit_text_callback),
245 new TextKey("l", emit_text_callback)}; 291 new TextKey("l", emit_text_callback)};
246 292
247 std::vector<Key*> lower_case_key_map_row_three = { 293 std::vector<Key*> lower_case_key_map_row_three = {
248 new TextKey("/\\", switch_to_upper_case_callback), 294 switch_to_upper_case_image_key,
249 new TextKey("z", emit_text_callback), 295 new TextKey("z", emit_text_callback),
250 new TextKey("x", emit_text_callback), 296 new TextKey("x", emit_text_callback),
251 new TextKey("c", emit_text_callback), 297 new TextKey("c", emit_text_callback),
252 new TextKey("v", emit_text_callback), 298 new TextKey("v", emit_text_callback),
253 new TextKey("b", emit_text_callback), 299 new TextKey("b", emit_text_callback),
254 new TextKey("n", emit_text_callback), 300 new TextKey("n", emit_text_callback),
255 new TextKey("m", emit_text_callback), 301 new TextKey("m", emit_text_callback),
256 new TextKey("del", delete_callback)}; 302 delete_image_key};
257 303
258 std::vector<Key*> lower_case_key_map_row_four = { 304 std::vector<Key*> lower_case_key_map_row_four = {
259 new TextKey("sym", switch_to_symbols_callback), 305 new TextKey("sym", switch_to_symbols_callback),
260 new TextKey(",", emit_text_callback), 306 new TextKey(",", emit_text_callback),
261 new TextKey(" ", emit_text_callback), 307 new TextKey(" ", emit_text_callback),
262 new TextKey(".", emit_text_callback), 308 new TextKey(".", emit_text_callback),
263 new TextKey("act", do_nothing_callback)}; 309 action_image_key};
264 310
265 lower_case_key_map_ = {lower_case_key_map_row_one, 311 lower_case_key_map_ = {lower_case_key_map_row_one,
266 lower_case_key_map_row_two, 312 lower_case_key_map_row_two,
267 lower_case_key_map_row_three, 313 lower_case_key_map_row_three,
268 lower_case_key_map_row_four}; 314 lower_case_key_map_row_four};
269 315
270 std::vector<Key*> upper_case_key_map_row_one = { 316 std::vector<Key*> upper_case_key_map_row_one = {
271 new TextKey("Q", emit_text_callback), 317 new TextKey("Q", emit_text_callback),
272 new TextKey("W", emit_text_callback), 318 new TextKey("W", emit_text_callback),
273 new TextKey("E", emit_text_callback), 319 new TextKey("E", emit_text_callback),
(...skipping 10 matching lines...) Expand all
284 new TextKey("S", emit_text_callback), 330 new TextKey("S", emit_text_callback),
285 new TextKey("D", emit_text_callback), 331 new TextKey("D", emit_text_callback),
286 new TextKey("F", emit_text_callback), 332 new TextKey("F", emit_text_callback),
287 new TextKey("G", emit_text_callback), 333 new TextKey("G", emit_text_callback),
288 new TextKey("H", emit_text_callback), 334 new TextKey("H", emit_text_callback),
289 new TextKey("J", emit_text_callback), 335 new TextKey("J", emit_text_callback),
290 new TextKey("K", emit_text_callback), 336 new TextKey("K", emit_text_callback),
291 new TextKey("L", emit_text_callback)}; 337 new TextKey("L", emit_text_callback)};
292 338
293 std::vector<Key*> upper_case_key_map_row_three = { 339 std::vector<Key*> upper_case_key_map_row_three = {
294 new TextKey("\\/", switch_to_lower_case_callback), 340 switch_to_lower_case_image_key,
295 new TextKey("Z", emit_text_callback), 341 new TextKey("Z", emit_text_callback),
296 new TextKey("X", emit_text_callback), 342 new TextKey("X", emit_text_callback),
297 new TextKey("C", emit_text_callback), 343 new TextKey("C", emit_text_callback),
298 new TextKey("V", emit_text_callback), 344 new TextKey("V", emit_text_callback),
299 new TextKey("B", emit_text_callback), 345 new TextKey("B", emit_text_callback),
300 new TextKey("N", emit_text_callback), 346 new TextKey("N", emit_text_callback),
301 new TextKey("M", emit_text_callback), 347 new TextKey("M", emit_text_callback),
302 new TextKey("DEL", delete_callback)}; 348 delete_image_key};
303 349
304 std::vector<Key*> upper_case_key_map_row_four = { 350 std::vector<Key*> upper_case_key_map_row_four = {
305 new TextKey("SYM", switch_to_symbols_callback), 351 new TextKey("SYM", switch_to_symbols_callback),
306 new TextKey(",", emit_text_callback), 352 new TextKey(",", emit_text_callback),
307 new TextKey(" ", emit_text_callback), 353 new TextKey(" ", emit_text_callback),
308 new TextKey(".", emit_text_callback), 354 new TextKey(".", emit_text_callback),
309 new TextKey("ACT", do_nothing_callback)}; 355 action_image_key};
310 356
311 upper_case_key_map_ = {upper_case_key_map_row_one, 357 upper_case_key_map_ = {upper_case_key_map_row_one,
312 upper_case_key_map_row_two, 358 upper_case_key_map_row_two,
313 upper_case_key_map_row_three, 359 upper_case_key_map_row_three,
314 upper_case_key_map_row_four}; 360 upper_case_key_map_row_four};
315 361
316 std::vector<Key*> symbols_key_map_row_one = { 362 std::vector<Key*> symbols_key_map_row_one = {
317 new TextKey("1", emit_text_callback), 363 new TextKey("1", emit_text_callback),
318 new TextKey("2", emit_text_callback), 364 new TextKey("2", emit_text_callback),
319 new TextKey("3", emit_text_callback), 365 new TextKey("3", emit_text_callback),
(...skipping 18 matching lines...) Expand all
338 384
339 std::vector<Key*> symbols_key_map_row_three = { 385 std::vector<Key*> symbols_key_map_row_three = {
340 new TextKey("=\\<", switch_to_symbols_callback), 386 new TextKey("=\\<", switch_to_symbols_callback),
341 new TextKey("*", emit_text_callback), 387 new TextKey("*", emit_text_callback),
342 new TextKey("\"", emit_text_callback), 388 new TextKey("\"", emit_text_callback),
343 new TextKey("'", emit_text_callback), 389 new TextKey("'", emit_text_callback),
344 new TextKey(":", emit_text_callback), 390 new TextKey(":", emit_text_callback),
345 new TextKey(";", emit_text_callback), 391 new TextKey(";", emit_text_callback),
346 new TextKey("!", emit_text_callback), 392 new TextKey("!", emit_text_callback),
347 new TextKey("?", emit_text_callback), 393 new TextKey("?", emit_text_callback),
348 new TextKey("del", delete_callback)}; 394 delete_image_key};
349 395
350 std::vector<Key*> symbols_key_map_row_four = { 396 std::vector<Key*> symbols_key_map_row_four = {
351 new TextKey("ABC", switch_to_lower_case_callback), 397 new TextKey("ABC", switch_to_lower_case_callback),
352 new TextKey(",", emit_text_callback), 398 new TextKey(",", emit_text_callback),
353 new TextKey("_", emit_text_callback), 399 new TextKey("_", emit_text_callback),
354 new TextKey(" ", emit_text_callback), 400 new TextKey(" ", emit_text_callback),
355 new TextKey("/", emit_text_callback), 401 new TextKey("/", emit_text_callback),
356 new TextKey(".", emit_text_callback), 402 new TextKey(".", emit_text_callback),
357 new TextKey("act", do_nothing_callback)}; 403 action_image_key};
358 404
359 symbols_key_map_ = {symbols_key_map_row_one, 405 symbols_key_map_ = {symbols_key_map_row_one,
360 symbols_key_map_row_two, 406 symbols_key_map_row_two,
361 symbols_key_map_row_three, 407 symbols_key_map_row_three,
362 symbols_key_map_row_four}; 408 symbols_key_map_row_four};
363 } 409 }
364 410
365 } // namespace keyboard 411 } // namespace keyboard
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698