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

Unified Diff: chrome/browser/ui/views/color_chooser_dialog.cc

Issue 9203001: Implement input type=color UI (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: rebased Created 8 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 | « chrome/browser/ui/views/color_chooser_dialog.h ('k') | chrome/browser/ui/views/color_chooser_win.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/ui/views/color_chooser_dialog.cc
diff --git a/chrome/browser/ui/views/color_chooser_dialog.cc b/chrome/browser/ui/views/color_chooser_dialog.cc
new file mode 100644
index 0000000000000000000000000000000000000000..1a3c129aab4490a8ffdd88125a9b653a071bcb44
--- /dev/null
+++ b/chrome/browser/ui/views/color_chooser_dialog.cc
@@ -0,0 +1,81 @@
+// Copyright (c) 2012 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.
+
+#include "chrome/browser/ui/views/color_chooser_dialog.h"
+
+#include <commdlg.h>
+
+#include "base/bind.h"
+#include "base/message_loop.h"
+#include "base/threading/thread.h"
+#include "content/public/browser/browser_thread.h"
+#include "skia/ext/skia_utils_win.h"
+
+using content::BrowserThread;
+
+// static
+COLORREF ColorChooserDialog::g_custom_colors[16];
+
+ColorChooserDialog::ExecuteOpenParams::ExecuteOpenParams(SkColor color,
+ RunState run_state,
+ HWND owner)
+ : color(color),
+ run_state(run_state),
+ owner(owner) {
+}
+
+ColorChooserDialog::ColorChooserDialog(Listener* listener,
+ SkColor initial_color,
+ gfx::NativeWindow owning_window)
+ : listener_(listener) {
+ DCHECK(listener_);
+ CopyCustomColors(g_custom_colors, custom_colors_);
+ ExecuteOpenParams execute_params(initial_color, BeginRun(owning_window),
+ owning_window);
+ execute_params.run_state.dialog_thread->message_loop()->PostTask(FROM_HERE,
+ base::Bind(&ColorChooserDialog::ExecuteOpen, this, execute_params));
+}
+
+ColorChooserDialog::~ColorChooserDialog() {
+}
+
+bool ColorChooserDialog::IsRunning(HWND owning_hwnd) const {
+ return listener_ && IsRunningDialogForOwner(owning_hwnd);
+}
+
+void ColorChooserDialog::ListenerDestroyed() {
+ // Our associated listener has gone away, so we shouldn't call back to it if
+ // our worker thread returns after the listener is dead.
+ listener_ = NULL;
+}
+
+void ColorChooserDialog::ExecuteOpen(const ExecuteOpenParams& params) {
+ CHOOSECOLOR cc;
+ cc.lStructSize = sizeof(CHOOSECOLOR);
+ cc.hwndOwner = params.owner;
+ cc.rgbResult = skia::SkColorToCOLORREF(params.color);
+ cc.lpCustColors = custom_colors_;
+ cc.Flags = CC_ANYCOLOR | CC_FULLOPEN | CC_RGBINIT;
+ bool success = !!ChooseColor(&cc);
+ DisableOwner(cc.hwndOwner);
+ BrowserThread::PostTask(BrowserThread::UI, FROM_HERE,
+ base::Bind(&ColorChooserDialog::DidCloseDialog, this, success,
+ skia::COLORREFToSkColor(cc.rgbResult), params.run_state));
+}
+
+void ColorChooserDialog::DidCloseDialog(bool chose_color,
+ SkColor color,
+ RunState run_state) {
+ if (!listener_)
+ return;
+ EndRun(run_state);
+ CopyCustomColors(custom_colors_, g_custom_colors);
+ if (chose_color)
+ listener_->DidChooseColor(color);
+ listener_->DidEnd();
+}
+
+void ColorChooserDialog::CopyCustomColors(COLORREF* src, COLORREF* dst) {
+ memcpy(dst, src, sizeof(COLORREF) * arraysize(g_custom_colors));
+}
« no previous file with comments | « chrome/browser/ui/views/color_chooser_dialog.h ('k') | chrome/browser/ui/views/color_chooser_win.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698