<table><tr><td style="">subdiff added a comment.
</td><a style="text-decoration: none; padding: 4px 8px; margin: 0 8px 8px; float: right; color: #464C5C; font-weight: bold; border-radius: 3px; background-color: #F7F7F9; background-image: linear-gradient(to bottom,#fff,#f1f0f1); display: inline-block; border: 1px solid rgba(71,87,120,.2);" href="https://phabricator.kde.org/D5928" rel="noreferrer">View Revision</a></tr></table><br /><div><div><blockquote style="border-left: 3px solid #8C98B8;
          color: #6B748C;
          font-style: italic;
          margin: 4px 0 12px 0;
          padding: 8px 12px;
          background-color: #F8F9FC;">
<div style="font-style: normal;
          padding-bottom: 4px;">In <a href="https://phabricator.kde.org/D5928#110990" style="background-color: #e7e7e7;
          border-color: #e7e7e7;
          border-radius: 3px;
          padding: 0 4px;
          font-weight: bold;
          color: black;text-decoration: none;" rel="noreferrer">D5928#110990</a>, <a href="https://phabricator.kde.org/p/davidedmundson/" style="
              border-color: #f1f7ff;
              color: #19558d;
              background-color: #f1f7ff;
                border: 1px solid transparent;
                border-radius: 3px;
                font-weight: bold;
                padding: 0 4px;" rel="noreferrer">@davidedmundson</a> wrote:</div>
<div style="margin: 0;
          padding: 0;
          border: 0;
          color: rgb(107, 116, 140);"><p>In my opinion, and the impression you gave me  when we talked about the design.</p>

<p>We shouldn't have Night mode stuff in kwin.<br />
 We should have generic colour correction in kwin (albeit with fading happening in kwin to reduce traffic)</p></div>
</blockquote>

<p>To make it more clear, I'll describe how I came in the end to the presented solution. In the beginning I wanted the workspace to only submit an updated color temperature values to KWin via DBus, KWin then calculates from this value the new gamma ramps. This has two drawbacks:</p>

<p>The first one is, that the fading phases generate much DBus traffic, as you said. To solve this we would need do the fading in KWin, for that we need timers, at least one. But it would make sense to have already two timers, one for quick adjustments and one for long fades. Because imagine the following:</p>

<p>While being in a fade to the neutral day temperature the user changes the night color temperature. KWin needs to quickly adjust the current color temperature to the new mix of night and day color temperature in the fade and at the same time proceed with the fade to the neutral day temperature.</p>

<p>If we allow only one timer with a target temperature workspace needs to calculate the current mix and then send this data to KWin with the information that it's supposed to be a quick change, after that Workspace again needs to send the neutral temperature and its target time to setup the timer. So we need a second timer in workspace to know when this can be done approximately or a callback from KWin when the quick change is over. In any case less complexity would be to let workspace send the informations <tt style="background: #ebebeb; font-size: 13px;">{current (mixed) temperature, next target temperature, next target time}</tt>. In this case KWin would need two timers. We wouldn't need the <tt style="background: #ebebeb; font-size: 13px;">slowUpdateStartTimer</tt> in KWin, but it would be in workspace and workspace would need to send the next target temperature/time combination at the beginning of every new long fade.</p>

<p>Regarding the second drawback: On bootup and after suspend phases KWin needs to know immediately, i.e. before the first frame is painted, the current color temperature mix, something which can be any value between night and day temperature depending on the time of day. My assumption was, that it would be way slow if we wait on workspace to give KWin this information, to not lead to quick presentations with wrong color temperature values.</p>

<p>In any case we would have lots of traffic going on between workspace and KWin and an higher complexity for little gain in my opinion. Yes, KWin wouldn't have to calculate the sun timings itself, which is somewhat a stretch, but I wrote it as a single function with little to no footprint. On the other side, we have a single DBus interface for configuration, which is only firing on manual configuration changes by the user, and additionally one DBus function to update the automatic location data (but KWin doesn't need that to work in Automatic mode). Other than that KWin can work on its own. All configuration is saved and provided by KWin, which is imo the nicer solution to having it in workspace or worst case having it split up on multiple applet config files, if people decide to write their own control applets for controlling the color temperature.</p>

<blockquote style="border-left: 3px solid #a7b5bf; color: #464c5c; font-style: italic; margin: 4px 0 12px 0; padding: 4px 12px; background-color: #f8f9fc;"><p>I can see your class names start with "color correction" and then you have virtual "supportsNightMode" which is very specific.</p></blockquote>

<p>Certain names start with "ColorCorrect" and I created a new directory "colorcorrection", because the idea is to later extend the classes in this directory with functionality to control the gamma of the connected screens in general. Basically what most people would understand under color correction. But since setting a color temperature value for night time is working in the same way (by adjusting the gamma ramps), it has to be done in tandem, then we have the general gamma control later (it's basically another factor multiplied to the general gamma ramp adjustments). I just started with Night Color, because it was more straight forward without the need to remember different values for different screens. And in my opinion it's more needed. At least I need it to use Wayland at night.</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R108 KWin</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D5928" rel="noreferrer">https://phabricator.kde.org/D5928</a></div></div><br /><div><strong>To: </strong>subdiff, KWin<br /><strong>Cc: </strong>davidedmundson, plasma-devel, kwin, ZrenBot, spstarr, progwolff, lesliezhai, ali-mohamed, hardening, jensreuterberg, abetts, eliasp, sebas, apol, hein, lukas<br /></div>