[Help Needed] My work on an Apple Studio Display M7768 (The Transparent ADC CRT)

Tuber Goober

New Tinkerer
Nov 23, 2024
3
1
3
Great news everyone! u/crt09 has managed to wake their Studio Display using WinI2C! Apparently, by pressing the "Standby Test" button, the appropriate wake up signal* is sent and the Studio Display starts displaying a picture. In the same post, @Synceen also found out that the Studio Display supports any resolution as long as it has an 80kHz horizontal frequency. Looks like we've finally cracked the nut and freed these beautiful monitors. Thank you all for your contributions!

*The only caveat of this solution is that it only works on Windows and macOS machines, still, loads better than having to use a G4 era mac! With that said, I'd still like to figure out what the signal actually is. A cursory look at the tools provided in the Hackaday post leads me to believe that the Studio Display manages its power state through appropriate DPMS requests, but I still haven't been able to test that since I can't communicate with my Studio Display. I'm not sure if it's because of an incorrect connection or if it's due to a noisy power supply. Apparently the I2C bus is quite delicate and even very slight voltage fluctuations can disrupt communication. I've noticed that I can "feel" some current whenever i slide my hand on my laptop.

Also, to answer @Titania , I have a feeling that the reason why ddcutil fails to detect the Studio Display is that it simply doesn't reply to DDC requests. If you think about it, the DDC lines in the Studio Display see very little use. They're only used to transmit the EDID information and the wake up signal. That would explain why Apple didn't bother fully implementing the standard. I believe you can force ddcutil into sending a command by specifying the bus that the Studio Display is connected to. I'll be trying that as soon as I can get mine working.
Hello I'm kinda new to this, I ordered and made the adapter for me and my friend who happen to own an m7768. I tried looking up winI2C but I only found a device, there where some downloads but every download I tried would just contain a text file saying winI2C was retired from this website. Granted I've searched on the first page of Google soo far. But could you point me in the right direction? Do I need the device (which isn't cheap) or do I need to keep looking for the software?
 

panettondoro

New Tinkerer
Sep 7, 2024
7
9
3
Hello I'm kinda new to this, I ordered and made the adapter for me and my friend who happen to own an m7768. I tried looking up winI2C but I only found a device, there where some downloads but every download I tried would just contain a text file saying winI2C was retired from this website. Granted I've searched on the first page of Google soo far. But could you point me in the right direction? Do I need the device (which isn't cheap) or do I need to keep looking for the software?
Hey there! You can still get WinI2C by downloading the files for this Hackaday project. It should be in DDC Tools/Windows. However, if possible, I would recommend using Twinkle Tray instead since it's still maintained. It *should* work but I'm not sure since no one has tested with the Studio Display yet.
 

Tuber Goober

New Tinkerer
Nov 23, 2024
3
1
3
Hey there! You can still get WinI2C by downloading the files for this Hackaday project. It should be in DDC Tools/Windows. However, if possible, I would recommend using Twinkle Tray instead since it's still maintained. It *should* work but I'm not sure since no one has tested with the Studio Display yet.
Thanks for the help. So I tried twinkle tray fist and it says it can't communicate with the monitor. So I tried WinI2C but every time I try to open it, it says it's blocked by the administrator while I am the administrator. I even try to run it as an administrator to no avail. I need to figure out a way to get this running, I don't want this monitor to become an oversized paperweight. :(
 

Attachments

  • 20241124_084400.jpg
    20241124_084400.jpg
    1.3 MB · Views: 31
  • 20241124_083311.jpg
    20241124_083311.jpg
    320.2 KB · Views: 34

panettondoro

New Tinkerer
Sep 7, 2024
7
9
3
Thanks for the help. So I tried twinkle tray fist and it says it can't communicate with the monitor. So I tried WinI2C but every time I try to open it, it says it's blocked by the administrator while I am the administrator. I even try to run it as an administrator to no avail. I need to figure out a way to get this running, I don't want this monitor to become an oversized paperweight. :(
That's weird. The identifier in the first screenshot does not match that of the Studio Display. Are you using an HDMI to VGA adapter by any chance? Unfortunately, they've been found to be quite fickle when it comes to DDC communication :(. If you have access to one, try using an old laptop or computer with a native VGA output instead as they don't usually perform any kind of "post-processing" to the DDC signals. As for the windows issue, try following this guide, it may be related to SmartScreen settings.
 
  • Like
Reactions: Tuber Goober

Tuber Goober

New Tinkerer
Nov 23, 2024
3
1
3
That's weird. The identifier in the first screenshot does not match that of the Studio Display. Are you using an HDMI to VGA adapter by any chance? Unfortunately, they've been found to be quite fickle when it comes to DDC communication :(. If you have access to one, try using an old laptop or computer with a native VGA output instead as they don't usually perform any kind of "post-processing" to the DDC signals. As for the windows issue, try following this guide, it may be related to SmartScreen settings.
Probably that converter, I'll try my Display port or Dvi-D converter, if not I'll use my xp laptop
 
  • Like
Reactions: panettondoro

getwellkel

New Tinkerer
Dec 13, 2024
1
1
1
I have been using WinI2C to successfully boot my monitor for the past month, however I have run into the limitations of the trial period. I have attempted to use the registry keys provided in the hackaday project, but once I merge those keys, I still get the expiry notice and cannot use the program any more. It could be because I'm not using the exact same installer as the one packaged in that project zip. The reason why I am not using that one is because it doesn't appear to install correctly, and I get an error message saying there was a "Driver Error" or something. So I have been using the WinI2C 4.05 trial as mirrored from Soft32, because the Nicomsoft download isn't very helpful.

So far, to attempt to salvage WinI2C:
  • I have tried a full uninstall via Revo, which is a program that scans for all associated registry keys and file locations and gives you the option to shred them. After a full uninstall and removal and restart, I try a fresh install but that doesn't seem to have cleared whatever saves the trial start date.
  • I tried to merge the registry keys included in the aforementioned hackaday project, but they don't seem to have changed anything.
  • I sent a hail marry message to Chris Tully on hackaday, who is the OP of that project, to ask for advice on the registry keys. We'll see if they are still active there since their last activity AFAIK was January of 2023.
I have also looked into Twinkle Tray, and have been getting the same (but slightly different) results. It looks like Twinkle Tray also cannot communicate with my Studio Display, however I do have the friendly name present. Another one of the programs provided by Chris Tully was ClickMonitor DDC, I did a bit of experimenting with this program as well but no luck either as it seems like it can't communicate either.

1734297146576.png


For context, my converter pipeline looks like this.
PC's GPU DisplayPort output -> Active DP to VGA converter -> VGA cable -> ADC converter on the Jasondoesitall PCB -> Studio Display

It would be great to have Twinkle Tray work since its such a clean looking program that's not a legacy EOL program. But it seems like WinI2C is the only program that works with my configuration. Does anyone have any additional insights into bypassing the expired trial?

1734297688587.png


I have a crummy powerbook that I can use to jumpstart the monitor but its really a piece of junk. I really would prefer the convenience of activating the monitor from my PC as that means I can power off the monitor when I'm not using it. I'm concerned about putting too much strain on the old thing leaving it powered on all the time, but that might just be what I have to do.
 
  • Like
Reactions: panettondoro

Synceen

New Tinkerer
Aug 1, 2024
2
1
1
i recently got my hands on the 2000 mercury TiBook and found that using "detect display" in macOS turns the monitor on; so ive just been using that to turn on mine. i know its not convenient but i dont really use the monitor much anyway so it just sits on standby. also ive found my crt runs better on windows at 1500x1150 at 65hz and that helps the screen being cut off.
 
  • Like
Reactions: panettondoro

renskegsm

New Tinkerer
Jan 7, 2025
3
2
3
Hello everyone! I just got one for free, same crt monitor. I was reading and I'm impressed by all the people passion, really nice!

I have a question: ddc wires, where do they go on the VGA pinout? As when I look for vga pinout, I don't see ddc.

Thanks in advance!

I might do the same with cutting the wires and manually do the connections. Power, vga or dvi, usb if needed. As I live in Ireland and it's hard to order the pcb and the components
 

renskegsm

New Tinkerer
Jan 7, 2025
3
2
3
The other option, what if we use a GPU with the ADC connector, e.g. nvidia fx 5200 and somehow power the GPU, enough to send the power ON signal? Just thinking outloud.
 

François

Tinkerer
Aug 9, 2022
94
43
18
France
Just a though: they were linux distros for PowerPC Macs back in the day when this monitor was current. So, if this monitor was (still is?) supported by linux distros, all the information on how to initialize it and how to set it up (geometry settings are done in software), all is in the linux source code!
 

renskegsm

New Tinkerer
Jan 7, 2025
3
2
3
1000100811.jpg



I got it working using the same method with the WIN2C app on windows XP 😜

I have a raspberry pi connected on the SDL and SCL pins as I can try reading what signal in being sent when using the Test Standby Mode in WINI2C.

To note: no board, just wire to wire on a VGA cable.

The problem I have on my crt is that the tube is always electrostaticly charged, everytime I touch the screen I get shocks. Is not the grouding or anything as it was doing the same when connected to a mac g4 ( previous owner)


Limitation: just 1600x1200 supported, other resolutions are blank.

If I can't fix the static discharge, I won't use it as I'm scared😄
 

panettondoro

New Tinkerer
Sep 7, 2024
7
9
3
View attachment 19401


I got it working using the same method with the WIN2C app on windows XP 😜

I have a raspberry pi connected on the SDL and SCL pins as I can try reading what signal in being sent when using the Test Standby Mode in WINI2C.

To note: no board, just wire to wire on a VGA cable.

The problem I have on my crt is that the tube is always electrostaticly charged, everytime I touch the screen I get shocks. Is not the grouding or anything as it was doing the same when connected to a mac g4 ( previous owner)


Limitation: just 1600x1200 supported, other resolutions are blank.

If I can't fix the static discharge, I won't use it as I'm scared😄
Congrats on getting it working! I apologize for my lack of activity, I just haven't had the energy to reply to messages these days.

To answer your previous post, that shouldn't be necessary! I haven't been able to confirm it "officially" yet (possibly dead monitor :(, do you happen to know another source for them?), but the power on signal is just a standard DDC message can be replicated by basically anything with an I2C interface. What I believe WinI2C does is just "cycling" the 0xd6 attribute (power mode). First, it sets it to 0 in order to power off the monitor and then, it sets it again to 1 in order to turn it back on.

Theoretically, you could just install ddcutil on your raspi and write a short python script that upon some kind of event, say a button press, sends the power on signal. u/crt09 on reddit has already written a script that does something similar, although not with ddcutil, but with the monitorcontrol python library.

If I'm not wrong, even a simple arduino can be programmed to send the power on signal by installing a DDC library.

Also re: the shocking, you likely no longer have the anti-reflective coating on your Studio Display. AFAIK, it also has anti-static properties, mine started doing that too when I removed it (accidentally used glass wipes to clean it!).
 
Last edited:

panettondoro

New Tinkerer
Sep 7, 2024
7
9
3
I have been using WinI2C to successfully boot my monitor for the past month, however I have run into the limitations of the trial period. I have attempted to use the registry keys provided in the hackaday project, but once I merge those keys, I still get the expiry notice and cannot use the program any more. It could be because I'm not using the exact same installer as the one packaged in that project zip. The reason why I am not using that one is because it doesn't appear to install correctly, and I get an error message saying there was a "Driver Error" or something. So I have been using the WinI2C 4.05 trial as mirrored from Soft32, because the Nicomsoft download isn't very helpful.

So far, to attempt to salvage WinI2C:
  • I have tried a full uninstall via Revo, which is a program that scans for all associated registry keys and file locations and gives you the option to shred them. After a full uninstall and removal and restart, I try a fresh install but that doesn't seem to have cleared whatever saves the trial start date.
  • I tried to merge the registry keys included in the aforementioned hackaday project, but they don't seem to have changed anything.
  • I sent a hail marry message to Chris Tully on hackaday, who is the OP of that project, to ask for advice on the registry keys. We'll see if they are still active there since their last activity AFAIK was January of 2023.
I have also looked into Twinkle Tray, and have been getting the same (but slightly different) results. It looks like Twinkle Tray also cannot communicate with my Studio Display, however I do have the friendly name present. Another one of the programs provided by Chris Tully was ClickMonitor DDC, I did a bit of experimenting with this program as well but no luck either as it seems like it can't communicate either.

View attachment 18938

For context, my converter pipeline looks like this.
PC's GPU DisplayPort output -> Active DP to VGA converter -> VGA cable -> ADC converter on the Jasondoesitall PCB -> Studio Display

It would be great to have Twinkle Tray work since its such a clean looking program that's not a legacy EOL program. But it seems like WinI2C is the only program that works with my configuration. Does anyone have any additional insights into bypassing the expired trial?

View attachment 18939

I have a crummy powerbook that I can use to jumpstart the monitor but its really a piece of junk. I really would prefer the convenience of activating the monitor from my PC as that means I can power off the monitor when I'm not using it. I'm concerned about putting too much strain on the old thing leaving it powered on all the time, but that might just be what I have to do.
I apologize for the late response, I just haven't had much energy to reply these days. I unfortunately can't completely solve your issue as I no longer own a Windows computer nor a functioning Studio Display, but I believe the issue lies in the Studio Display's somewhat non-standard DDC implementation. Most DDC compliant monitors "broadcast" their compliance by replying with a short message whenever a request to the x37 I2C address is made, however the Studio Display doesn't seem to do that. So whenever Twinkle Tray tries checking for its compliance, it sees that it doesn't reply to its request and marks it as an incompatible monitor. I'm not sure if you can "force" Twinkle Tray into sending the power on sequence (maybe try opening an issue on its github?), but, in the mean time, you can try experimenting with the script that u/crt09 wrote.