diff options
-rw-r--r-- | gyp/tools.gyp | 16 | ||||
-rw-r--r-- | tools/get_current_monitor_profile.cpp | 61 |
2 files changed, 77 insertions, 0 deletions
diff --git a/gyp/tools.gyp b/gyp/tools.gyp index 63556da749..fecee044a8 100644 --- a/gyp/tools.gyp +++ b/gyp/tools.gyp @@ -20,6 +20,7 @@ 'chrome_fuzz', 'dump_record', 'get_images_from_skps', + 'get_current_monitor_profile', 'gpuveto', 'imgblur', 'imgslice', @@ -317,6 +318,21 @@ ], }, { + 'target_name': 'get_current_monitor_profile', + 'type': 'executable', + 'sources': [ + '../tools/get_current_monitor_profile.cpp', + ], + 'include_dirs': [ + '../src/core', + '../include/private', + ], + 'dependencies': [ + 'flags.gyp:flags', + 'skia_lib.gyp:skia_lib', + ], + }, + { 'target_name': 'gpuveto', 'type': 'executable', 'sources': [ diff --git a/tools/get_current_monitor_profile.cpp b/tools/get_current_monitor_profile.cpp new file mode 100644 index 0000000000..55a96d56dd --- /dev/null +++ b/tools/get_current_monitor_profile.cpp @@ -0,0 +1,61 @@ +/* + * Copyright 2016 Google Inc. + * + * Use of this source code is governed by a BSD-style license that can be + * found in the LICENSE file. + */ + +#include "SkStream.h" + +#if defined(SK_BUILD_FOR_MAC) +#include <ApplicationServices/ApplicationServices.h> +#elif defined(SK_BUILD_FOR_WIN) +#include <windows.h> +#endif + +int main(int argc, char** argv) { +#if defined(SK_BUILD_FOR_MAC) + CGColorSpaceRef cs = CGDisplayCopyColorSpace(CGMainDisplayID()); + CFDataRef dataRef = CGColorSpaceCopyICCProfile(cs); + const uint8_t* data = CFDataGetBytePtr(dataRef); + size_t size = CFDataGetLength(dataRef); + + SkFILEWStream file("monitor_0.icc"); + file.write(data, size); + + CFRelease(cs); + CFRelease(dataRef); + return 0; +#elif defined(SK_BUILD_FOR_WIN) + DISPLAY_DEVICE dd = { sizeof(DISPLAY_DEVICE) }; + SkString outputFilename; + + // Chrome's code for this currently just gets the primary monitor's profile. This code iterates + // over all attached monitors, so it's "better" in that sense. Making intelligent use of this + // information (via things like MonitorFromWindow or MonitorFromRect to pick the correct + // profile for a particular window or region of a window), is an exercise left to the reader. + for (int i = 0; EnumDisplayDevices(NULL, i, &dd, 0); ++i) { + if (dd.StateFlags & DISPLAY_DEVICE_ATTACHED_TO_DESKTOP) { + // There are other helpful things in dd at this point: + // dd.DeviceString has a longer name for the adapter + // dd.StateFlags indicates primary display, mirroring, etc... + HDC dc = CreateDC(NULL, dd.DeviceName, NULL, NULL); + if (dc) { + char icmPath[MAX_PATH + 1]; + DWORD pathLength = MAX_PATH; + if (GetICMProfile(dc, &pathLength, icmPath)) { + // GetICMProfile just returns the path to the installed profile (not the data) + outputFilename = SkStringPrintf("monitor_%d.icc", i); + CopyFile(icmPath, outputFilename.c_str(), FALSE); + } + DeleteDC(dc); + } + } + } + + return 0; +#else + SkDebugf("ERROR: Unsupported platform\n"); + return 1; +#endif +} |