Jump to content
You must now use your email address to sign in [click for more info] ×

YourMJK

Members
  • Posts

    5
  • Joined

  • Last visited

  1. @debraspicher What @NotMyFault said. I also want to add that macOS doesn't convert the actual 8bit RGB values by converting from e.g. Display P3 to sRGB. It just embeds the correct ICC profile of the display and keeps the native values. I'm using sRGB as the default profile for both 32bit and 16bit/8bit. The rest is the same as in your screenshot, except for that HDR checkbox.
  2. @NotMyFault macOS automatically created them over the years whenever I attached a display. They are also copied over when you migrate machines through TimeMachine or Migration Assistent. They do of course contain timestamp, manufacturer and all sorts of other metadata but they all have the same "ASCII Name" in "Localised description strings". Their actual name (shown in Finder, ColorSync Utility, Preferences etc.) is different. See the attached profiles. "Color LCD" is the MacBook's internal one, the other three are older external displays. All four have ASCII name "Display". Color LCD-37D8832A-2D66-02CA-B9F7-8F30A301B230.icc Thunderbolt Display-8D473DEC-366A-4232-AC22-0027A548D55D.icc LED Cinema Display-82B0B317-2947-5615-1D46-AEB4167B03CA.icc DELL U2212HM-C74F0953-E6A6-A1A5-A17E-2186A9E122C7.icc
  3. I just discovered this and I'm a bit shocked. This bug means that all screenshots I've edited with Affinity Photo have slightly wrong colors due to a wrong ICC profile embedded in the exports. When you open an image file with an embedded ICC profile, Affinity will first check if there is a profile with the same ASCII name ('desc' tag aka. Localized description strings) installed on the system. If yes, it will use this one as the workspace/document profile over the original embedded one (this causes colors to be inaccurately displayed!). This is also the profile embedded in the export, unless explicitly specified otherwise. You can see this in Finder on the exported file which shows the "real" name. Only if the embedded profile's ASCII name is unique, it will use the embedded profile. You would expect that Affinity always uses the embedded profile or at least matches them based on the XYZ tristimulus values and response curves of the profiles. Not based on some non-unique description string. Reproduce: Have multiple profiles with ASCII name "Display" installed under /Library/ColorSync/Profiles/Displays/. This is tricky, I don't know how many or how the files should be named to guarantee that Affinity always chooses the "wrong one" (not the actual internal display's profile) to deduplicate all. Knowing the source code would be helpful here. Take a screenshot. Finder should say something like "Color LCD" in the color profile metadata. Open screenshot with Affinity Photo V1 (1.10.6) or V2 (2.0.3) and export as PNG with "ICC profile: Use document profile", "Embed ICC profile: yes", "Embed metadata: yes". Look at exported file with Finder. It should/could say something different now in the color profile metadata. macOS Monterey 12.6.2, MacBookPro M1 16". Background: When you take a screenshot using macOS's built-in tool, it embeds the ICC profile of the monitor into the PNG file (which is good, since this will help with accurately showing the correct colors on different displays) as opposed to something like sRGB. This profile is usually under /Library/ColorSync/Profiles/Displays/Color LCD-*.icc (depends on your internal display, you can find it through the ColorSync Utility) and it has the ASCII name "Display" as metadata. That's also the name shown in Affinity. Now you might have lots of ICC profiles in /Library/ColorSync/Profiles/Displays/ of other displays you had previously connected (years/decades ago perhaps) and most of these will also have an ASCII name of "Display". Note that this is not the name shown in Finder etc.! That shows the multi-localized description `dscm`, e.g. "Color LCD", "Thunderbolt Display", "DELL <model>" etc. In my case, every screenshot I took on my wide gamut Display P3 display got converted/interpreted with the RGB primaries of some 20 year old Dell display after I opened it in Affinity because apparently that's the first *.icc file with the ASCII name "Display" that it matched. Document > Assign ICC profile… doesn't work since it deduplicated all profiles with this name to that Dell one, so it only lists this one under "Display". Workaround: Either delete/move all profiles in /Library/ColorSync/Profiles/ with "Display" as the ASCII name if you don't need them anymore or rename them so they are all unique. You can lookup and change that name by opening the .icc file with the ColorSync Utility and going to 'desc'/Localized description strings > ASCII Name. If you move them to a different location, make sure it's not still inside /Library/ColorSync/Profiles/ or ~/Library/ColorSync/Profiles/. Now of course this only helps with screenshots you create on your computer but the issue still persists when you open other people's file! It's embarrassing for Affinity to handle color profiles so carelessly and intransparent for the user. You should fix this ASAP.
×
×
  • Create New...

Important Information

Terms of Use | Privacy Policy | Guidelines | We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.