Toggle menu
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

Redshift 3DS: Difference between revisions

From GameBrew
(Created page with "{{Infobox-3DS-Homebrews | title = CTR_Redshift | image = https://dlhb.gamebrew.org/3dshomebrew/CTR-Redshift-3DS.jpg|250px | type = Utilities | version = 2018 | lastupdated = 2...")
 
No edit summary
Line 5: Line 5:
| version = 2018
| version = 2018
| lastupdated = 2018/01/09
| lastupdated = 2018/01/09
| licence = Mixed
| licence = GPLv3
| author = Sono
| author = Sono
| website = https://gbatemp.net/threads/ctr_redshift-hardware-based-blue-light-filter-for-old3ds-and-2ds.493736/
| website = https://gbatemp.net/threads/ctr_redshift-hardware-based-blue-light-filter-for-old3ds-and-2ds.493736/
Line 11: Line 11:
| source = https://web.archive.org/web/20180831205721/https://gist.github.com/SonoSooS/d9dfd74a65f5c9ae2c13d76c2c29b5fa
| source = https://web.archive.org/web/20180831205721/https://gist.github.com/SonoSooS/d9dfd74a65f5c9ae2c13d76c2c29b5fa
}}
}}
<youtube></youtube>


Remember the homebrew I did almost a year ago which used the power saving mode on a new3DS to make the screen more red? Yeah, me neither :P It had many problems, almost everything got rid of the effect, and it only worked on new3DS in power saving mode because the old3DS lacks the required hardware. Also, the flicker caused me headaches, so I stopped the project there.
Remember the homebrew I did almost a year ago which used the power saving mode on a new3DS to make the screen more red? Yeah, me neither :P It had many problems, almost everything got rid of the effect, and it only worked on new3DS in power saving mode because the old3DS lacks the required hardware. Also, the flicker caused me headaches, so I stopped the project there.
Line 17: Line 16:
Well, now I fully reverse-engineered a GPU register which controls this, and thus I recreated the old design based on the new color lookup table mechanism, and it works! :D
Well, now I fully reverse-engineered a GPU register which controls this, and thus I recreated the old design based on the new color lookup table mechanism, and it works! :D


Note: due to the characteristics of the ULCD screen, the colors will look absolutely horrible. This is not fault of the code, and thus it's not fixable. The results may differ between different models and screen types.
'''Note:''' due to the characteristics of the ULCD screen, the colors will look absolutely horrible. This is not fault of the code, and thus it's not fixable. The results may differ between different models and screen types.


Note: the example demo application doesn't work in old3DS extended mode because the firmlaunch does a screeninit, resulting in the color lookup table being reset.
'''Note:''' the example demo application doesn't work in old3DS extended mode because the firmlaunch does a screeninit, resulting in the color lookup table being reset.


Note: the code is based on Redshift. The code and the example demo application is just a platform-specific wrapper around it.
'''Note:''' the code is based on [https://github.com/jonls/redshift Redshift]. The code and the example demo application is just a platform-specific wrapper around it.


Note: the example demo application uses the same TitleID as my debugger applications, so installing this will overwrite those. You have been warned!
'''Note:''' the example demo application uses the same TitleID as my debugger applications, so installing this will overwrite those. You have been warned!


Note: the source code isn't meant to be compiled on its own, it's just provided for education purposes. You need to alter it slightly in order to be compiled in an application.
'''Note:''' the source code isn't meant to be compiled on its own, it's just provided for education purposes. You need to alter it slightly in order to be compiled in an application.


Once you downloaded the example application, you can select which section you want to alter with the LEFT and RIGHT buttons, adjust the values using the UP and DOWN buttons (fine adjustments can be made while hoding the R or L buttons), and applying those settings to the screens with the A (bottom screen) and the B (top screen) buttons. Pressing X or Y will reset the config values to their default state, and pressing A and B will also reset the colors on the screens.
Once you downloaded the example application, you can select which section you want to alter with the LEFT and RIGHT buttons, adjust the values using the UP and DOWN buttons (fine adjustments can be made while hoding the R or L buttons), and applying those settings to the screens with the A (bottom screen) and the B (top screen) buttons. Pressing X or Y will reset the config values to their default state, and pressing A and B will also reset the colors on the screens.

Revision as of 11:37, 28 September 2021

Template:Infobox-3DS-Homebrews

Remember the homebrew I did almost a year ago which used the power saving mode on a new3DS to make the screen more red? Yeah, me neither :P It had many problems, almost everything got rid of the effect, and it only worked on new3DS in power saving mode because the old3DS lacks the required hardware. Also, the flicker caused me headaches, so I stopped the project there.

Well, now I fully reverse-engineered a GPU register which controls this, and thus I recreated the old design based on the new color lookup table mechanism, and it works! :D

Note: due to the characteristics of the ULCD screen, the colors will look absolutely horrible. This is not fault of the code, and thus it's not fixable. The results may differ between different models and screen types.

Note: the example demo application doesn't work in old3DS extended mode because the firmlaunch does a screeninit, resulting in the color lookup table being reset.

Note: the code is based on Redshift. The code and the example demo application is just a platform-specific wrapper around it.

Note: the example demo application uses the same TitleID as my debugger applications, so installing this will overwrite those. You have been warned!

Note: the source code isn't meant to be compiled on its own, it's just provided for education purposes. You need to alter it slightly in order to be compiled in an application.

Once you downloaded the example application, you can select which section you want to alter with the LEFT and RIGHT buttons, adjust the values using the UP and DOWN buttons (fine adjustments can be made while hoding the R or L buttons), and applying those settings to the screens with the A (bottom screen) and the B (top screen) buttons. Pressing X or Y will reset the config values to their default state, and pressing A and B will also reset the colors on the screens.

Download has been removed due to violating GPL. Sorry for the inconvenience. You may find community-hosted mirrors on the internet.

Advertising: