OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2011 Google Inc. | 2 * Copyright 2011 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #include "SampleApp.h" | 8 #include "SampleApp.h" |
9 | 9 |
10 #include "OverView.h" | 10 #include "OverView.h" |
(...skipping 30 matching lines...) Expand all Loading... | |
41 # include "SkGr.h" | 41 # include "SkGr.h" |
42 # if SK_ANGLE | 42 # if SK_ANGLE |
43 # include "gl/angle/GLTestContext_angle.h" | 43 # include "gl/angle/GLTestContext_angle.h" |
44 # endif | 44 # endif |
45 #else | 45 #else |
46 class GrContext; | 46 class GrContext; |
47 #endif | 47 #endif |
48 | 48 |
49 const struct { | 49 const struct { |
50 SkColorType fColorType; | 50 SkColorType fColorType; |
51 SkColorProfileType fProfileType; | 51 bool fSRGB; |
Brian Osman
2016/06/16 15:15:06
Not using sk_sp<SkColorSpace> here to avoid static
msarett
2016/06/16 15:56:04
Acknowledged.
| |
52 const char* fName; | 52 const char* fName; |
53 } gConfig[] = { | 53 } gConfig[] = { |
54 { kN32_SkColorType, kLinear_SkColorProfileType, "L32" }, | 54 { kN32_SkColorType, false, "L32" }, |
55 { kN32_SkColorType, kSRGB_SkColorProfileType, "S32" }, | 55 { kN32_SkColorType, true, "S32" }, |
56 { kRGBA_F16_SkColorType, kLinear_SkColorProfileType, "F16" }, | 56 { kRGBA_F16_SkColorType, false, "F16" }, |
57 }; | 57 }; |
58 | 58 |
59 static const char* find_config_name(const SkImageInfo& info) { | 59 static const char* find_config_name(const SkImageInfo& info) { |
60 for (const auto& config : gConfig) { | 60 for (const auto& config : gConfig) { |
61 if (config.fColorType == info.colorType() && config.fProfileType == info .profileType()) { | 61 if (config.fColorType == info.colorType() && |
62 config.fSRGB == (info.colorSpace() != nullptr)) { | |
62 return config.fName; | 63 return config.fName; |
63 } | 64 } |
64 } | 65 } |
65 return "???"; | 66 return "???"; |
66 } | 67 } |
67 | 68 |
68 // Should be 3x + 1 | 69 // Should be 3x + 1 |
69 #define kMaxFatBitsScale 28 | 70 #define kMaxFatBitsScale 28 |
70 | 71 |
71 extern SampleView* CreateSamplePictFileView(const char filename[]); | 72 extern SampleView* CreateSamplePictFileView(const char filename[]); |
(...skipping 1556 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1628 if (isInvalEvent(evt)) { | 1629 if (isInvalEvent(evt)) { |
1629 this->inval(nullptr); | 1630 this->inval(nullptr); |
1630 return true; | 1631 return true; |
1631 } | 1632 } |
1632 int selected = -1; | 1633 int selected = -1; |
1633 if (SkOSMenu::FindListIndex(evt, "Device Type", &selected)) { | 1634 if (SkOSMenu::FindListIndex(evt, "Device Type", &selected)) { |
1634 this->setDeviceType((DeviceType)selected); | 1635 this->setDeviceType((DeviceType)selected); |
1635 return true; | 1636 return true; |
1636 } | 1637 } |
1637 if (SkOSMenu::FindListIndex(evt, "ColorType", &selected)) { | 1638 if (SkOSMenu::FindListIndex(evt, "ColorType", &selected)) { |
1638 this->setDeviceColorType(gConfig[selected].fColorType, gConfig[selected] .fProfileType); | 1639 auto srgbColorSpace = SkColorSpace::NewNamed(SkColorSpace::kSRGB_Named); |
1640 this->setDeviceColorType(gConfig[selected].fColorType, | |
1641 gConfig[selected].fSRGB ? srgbColorSpace : null ptr); | |
1639 return true; | 1642 return true; |
1640 } | 1643 } |
1641 if (SkOSMenu::FindSwitchState(evt, "Slide Show", nullptr)) { | 1644 if (SkOSMenu::FindSwitchState(evt, "Slide Show", nullptr)) { |
1642 this->toggleSlideshow(); | 1645 this->toggleSlideshow(); |
1643 return true; | 1646 return true; |
1644 } | 1647 } |
1645 if (SkOSMenu::FindTriState(evt, "AA", &fAAState) || | 1648 if (SkOSMenu::FindTriState(evt, "AA", &fAAState) || |
1646 SkOSMenu::FindTriState(evt, "LCD", &fLCDState) || | 1649 SkOSMenu::FindTriState(evt, "LCD", &fLCDState) || |
1647 SkOSMenu::FindListIndex(evt, "FilterQuality", &fFilterQualityIndex) || | 1650 SkOSMenu::FindListIndex(evt, "FilterQuality", &fFilterQualityIndex) || |
1648 SkOSMenu::FindTriState(evt, "Subpixel", &fSubpixelState) || | 1651 SkOSMenu::FindTriState(evt, "Subpixel", &fSubpixelState) || |
(...skipping 194 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1843 return; | 1846 return; |
1844 | 1847 |
1845 fDevManager->tearDownBackend(this); | 1848 fDevManager->tearDownBackend(this); |
1846 fDeviceType = type; | 1849 fDeviceType = type; |
1847 fDevManager->setUpBackend(this, fMSAASampleCount, fDeepColor); | 1850 fDevManager->setUpBackend(this, fMSAASampleCount, fDeepColor); |
1848 | 1851 |
1849 this->updateTitle(); | 1852 this->updateTitle(); |
1850 this->inval(nullptr); | 1853 this->inval(nullptr); |
1851 } | 1854 } |
1852 | 1855 |
1853 void SampleWindow::setDeviceColorType(SkColorType ct, SkColorProfileType pt) { | 1856 void SampleWindow::setDeviceColorType(SkColorType ct, sk_sp<SkColorSpace> cs) { |
1854 this->setColorType(ct, pt); | 1857 this->setColorType(ct, std::move(cs)); |
1855 | 1858 |
1856 fDevManager->tearDownBackend(this); | 1859 fDevManager->tearDownBackend(this); |
1857 fDevManager->setUpBackend(this, fMSAASampleCount, fDeepColor); | 1860 fDevManager->setUpBackend(this, fMSAASampleCount, fDeepColor); |
1858 | 1861 |
1859 this->updateTitle(); | 1862 this->updateTitle(); |
1860 this->inval(nullptr); | 1863 this->inval(nullptr); |
1861 } | 1864 } |
1862 | 1865 |
1863 void SampleWindow::toggleSlideshow() { | 1866 void SampleWindow::toggleSlideshow() { |
1864 fAnimating = !fAnimating; | 1867 fAnimating = !fAnimating; |
(...skipping 534 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
2399 #ifdef SK_BUILD_FOR_MAC | 2402 #ifdef SK_BUILD_FOR_MAC |
2400 setenv("ANDROID_ROOT", "/android/device/data", 0); | 2403 setenv("ANDROID_ROOT", "/android/device/data", 0); |
2401 #endif | 2404 #endif |
2402 SkGraphics::Init(); | 2405 SkGraphics::Init(); |
2403 SkEvent::Init(); | 2406 SkEvent::Init(); |
2404 } | 2407 } |
2405 | 2408 |
2406 void application_term() { | 2409 void application_term() { |
2407 SkEvent::Term(); | 2410 SkEvent::Term(); |
2408 } | 2411 } |
OLD | NEW |