| ▲ | Show HN: The text disappears when you screenshot it(unscreenshottable.vercel.app) |
| 560 points by zikero 5 days ago | 191 comments |
| |
|
| ▲ | axiolite 5 days ago | parent | next [-] |
| You can take TWO screenshots, moments apart, open in GIMP, paste one over the other and choose any one of these laying modes: Lighten, Screen, Addition, Darken, Multiply, Linear burn, Hard Mix, Difference, Exclusion, Subtract, Grain Extract, Grain Merge, or Luminance. https://ibb.co/DDQBJDKR |
| |
| ▲ | cloudbonsai 5 days ago | parent | next [-] | | > You can take TWO screenshots, moments apart, open in GIMP, paste one over the other and choose any one of these laying modes: You actually don't need any image editing skill. Here is a browser-only solution: 1. Take two screenshots. 2. Open these screenshots in two separate tabs on your browser. 3. Switch between tabs very, very quickly (use CTRL-Tab) Source: tested on Firefox | | |
| ▲ | milkshakes 5 days ago | parent | next [-] | | reminds me of this: https://www.reddit.com/r/LifeProTips/comments/5jdzsx/lpt_use... | | |
| ▲ | JadeNB 4 days ago | parent | next [-] | | This was used in some early-20th-century astronomical setting, I think to detect supernovae. I can't find any documentation now, but my memory is that it was called "blink testing" or something similar, where one switched rapidly between two images of a star field so that changes due to a supernova would stand out. | | | |
| ▲ | CGMthrowaway 4 days ago | parent | prev [-] | | I went cross-eyed on my screenshot, and I couldnt read the word, but I did notice some artifacts |
| |
| ▲ | axiolite 4 days ago | parent | prev | next [-] | | What does that accomplish? You can just read the web page as-is... Are you going to share your two screenshots, and provide those instructions, with others? That seems impractical. Video recording is a bit less impractical, but there you really need a short looping animation to avoid ballooning the file size. An actual readable screenshot has its advantages... | |
| ▲ | chinathrow 4 days ago | parent | prev | next [-] | | > use CTRL-Tab Thank you forever for this, I ever used Ctrl-Page up/down for that. | |
| ▲ | azinman2 4 days ago | parent | prev [-] | | You could also just record a video. | | |
| ▲ | jama211 4 days ago | parent [-] | | Hah, indeed, that was my first thought. This is clearly for fun though, it’s a cool project idea |
|
| |
| ▲ | gus_massa 5 days ago | parent | prev | next [-] | | Is it possible to modify the webpage to make the pattern of the text go down and the pattern of the background do up? | | | |
| ▲ | sunrunner 5 days ago | parent | prev | next [-] | | Neat idea. A friend of mine made a similar animated GIF type captcha a few years ago but based on multiple scrolling horizontal bars that would each reveal their portion of the underlying image including letters, and made a (friendly) bet that it should be pretty hard to solve. Grabbing the entire set of frames and greyscaling them, doing an average over all of them and then applying a few minor fixups like thresholding and contrast adjustment worked easily enough as the letters were reveleaed in more frames than not (I don't think that would affect the difficulty much though if it were any diffierent). After that the rest of the image was pretty amenable to character recognition. | | |
| ▲ | aw1621107 4 days ago | parent [-] | | That's reminiscent of a (possibly apocryphal?) method I once read about to get "clean" images of normally crowded public places - take multiple photos over time, then median each pixel. Never had the opportunity to try it myself, but I thought it sounded plausible as a way to get rid of transient "noise" from an otherwise static image. | | |
| |
| ▲ | postalcoder 5 days ago | parent | prev | next [-] | | Out of sheer curiosity, I put three screenshots of the noise into Claude Opus 4.1, Gemini 2.5 Pro, and GPT 5, all with thinking enabled with the prompt “what does the screen say?”. Opus 4.1 flagged the message due to prompt injection risk, Gemini made a bad guess, and GPT 5 got it by using the code interpreter. I thought it was amusing. Claude’s (non) response got me thinking - first, it was very on brand, second, that the content filter was right - pasting images of seemingly random noise into a sensitive environment is a terrible idea. | | | |
| ▲ | bonyt 4 days ago | parent | prev | next [-] | | I've found taking two screenshots and adding them as separate layers works well, and then setting one as Difference, and then tweaking the opacity. Here it is in Pixelmator Pro: https://i.moveything.com/299930fb6174.mp4 | |
| ▲ | loopduplicate 4 days ago | parent | prev | next [-] | | Bottom layer normal, second layer grain extract, top layer vivid light. This completely blacks out the whole area outside of the text. | |
| ▲ | LadyCailin 5 days ago | parent | prev | next [-] | | Or just copy the text from the url. Not very secure, really. :D | | | |
| ▲ | bobmcnamara 5 days ago | parent | prev | next [-] | | Computer vision mode: and each screenshot together. | |
| ▲ | flux3125 4 days ago | parent | prev | next [-] | | But then that would be a video, not a screenshot | | |
| ▲ | jdiff 4 days ago | parent [-] | | Layered images do not a video make. Sequential images distributed over time do. |
| |
| ▲ | amelius 5 days ago | parent | prev [-] | | Yeah if this became popular, we'd have another Show HN for a tool that automated that. |
|
|
| ▲ | xnx 5 days ago | parent | prev | next [-] |
| This game disappears if you pause it: https://youtube.com/watch?v=Bg3RAI8uyVw |
| |
| ▲ | vunderba 5 days ago | parent | next [-] | | This is great - seems to be the same effect of hiding a shape using an animated noise pattern on a background of static noise. They even provide the source code for the effect: https://github.com/brantagames/noise-shader | |
| ▲ | krzat 4 days ago | parent | prev | next [-] | | Interesting that the perception of objects/text does not disappear immediately, there is smooth fade out. | |
| ▲ | nomilk 5 days ago | parent | prev | next [-] | | First time seeing this, makes me smile involuntarily. | |
| ▲ | robertlagrant 5 days ago | parent | prev | next [-] | | Yes - I was thinking of this. It solves various complicated problems such as rendering distance information in this format. | |
| ▲ | sunrunner 5 days ago | parent | prev | next [-] | | This is great. The sphere example looks especially pleasing. It also reminds me of the game The Voidness. | |
| ▲ | lproven 4 days ago | parent | prev | next [-] | | Not really a game, but neat all the same. It reminds me of the mid-1990s video game Magic Carpet. https://en.wikipedia.org/wiki/Magic_Carpet_(video_game) This was a pseudo-3D game and on an ordinary display it used perspective to simulate 3D like most games. If you had 3D goggles it could use them, but I didn't. However, it could do a true 3D display on a 2D monitor using a random-dot stereogram. https://en.wikipedia.org/wiki/Random_dot_stereogram If you have depth perception and are able to see RDS autostereograms, then Magic Carpet did an animated one. It was a wholly remarkable affect, but for me anyway, it was really hard to watch. It felt like it was trying to rotate my eyeballs in their sockets. Very impressive, but essentially unplayable and I could only watch for a minute or two before I couldn't stand the discomfort any more. | | | |
| ▲ | Jordan-117 4 days ago | parent | prev [-] | | See also: Lost in the Static https://silverspaceship.com/static/ | | |
|
|
| ▲ | Syntonicles 5 days ago | parent | prev | next [-] |
| I first saw this effect in a video from Branta Games. https://www.youtube.com/watch?v=Bg3RAI8uyVw The effect is disrupted by introducing rendering artifacts, by watching the video in 144p or in this case by zooming out. I'd love to know the name of this effect, so I can read more about the fMRI studies that make use of it. What I've found so far: Random Dot Kinematogram Perceptual Organization from Motion (video of Flounder camouflage) https://www.youtube.com/watch?v=2VO10eDIyiE |
|
| ▲ | shannifin 5 days ago | parent | prev | next [-] |
| Others have mentioned Branta Games, but I first saw the effect here: https://youtu.be/TdTMeNXCnTs |
| |
| ▲ | cubefox 4 days ago | parent | next [-] | | This one is actually more sophisticated because it doesn't rely on scrolling pixels like the OP. So the object doesn't just disappear in screenshots, but also when the animation stops moving! So you can't actually display text that stands still, like the "hello" in the OP. | | |
| ▲ | shannifin 4 days ago | parent | next [-] | | Yep. He tries text in another video by flipping pixels for one or more frames, so the words disappear very quickly. Definitely harder to read, especially longer words: https://youtu.be/EDQeArrqRZ4 | |
| ▲ | optionalsquid 4 days ago | parent | prev [-] | | I'm not sure I follow. Couldn't you display text that stands still by (re)drawing the outline of the text repeatedly? It would essentially be a two frame animation | | |
| ▲ | derefr 4 days ago | parent | next [-] | | I think the algorithm in the video is doing a very specific thing where there's a zero-width pixel-grid-clamped stroke (picture an etch-a-sketch-like seam carving "between" the bounds of pixels on the grid) moving about the grid, altering (with XOR?) anything it advances across. So, sure, you could try to implement this by having a seam that is made to "reverberate" back and forth "across" the outlining pixels of a static shape on each frame. But that's not exactly the same thing as selecting the outline of the shape itself and having those pixels update each frame. Given the way this algorithm looks to work, pushing the seam "inwards" vs "outwards" across the same set of pixels forming the outline might gather an entirely different subset of pixels, creating a lot of holes or perhaps double-counting pixels. And if you fix those problems, then you're not really using this algorithm any more; you're just doing the much-more-boring thing of taking a list of pixel positions forming the outline and updating them each frame. :) | |
| ▲ | cubefox 4 days ago | parent | prev [-] | | I believe the algorithm in the video works by flipping the pixel color when the pixel changes from foreground (some shape) to background, or from background to foreground. If the shape doesn't move, there is no such change, so it disappears. In the OP the foreground pixels continuously change (scrolling in this case) while the background doesn't change. That's a different method of separating background and foreground. |
|
| |
| ▲ | zem 5 days ago | parent | prev [-] | | thanks, that's also the best explained one! |
|
|
| ▲ | geordieboozer 4 days ago | parent | prev | next [-] |
| Reminds me a bit of the album cover of _Any Minute Now_ by Soulwax https://upload.wikimedia.org/wikipedia/en/a/ab/AnyMinuteNow.... |
| |
|
| ▲ | pmontra 5 days ago | parent | prev | next [-] |
| If anybody implements that to antiscrenshot some sensitive data, somebody else will use another phone, a tablet or a camera to record a video of it. Nice idea though. |
| |
| ▲ | gwbas1c 4 days ago | parent | next [-] | | It's just adding friction: Someone determined will figure out a way to get the text. Sometimes friction is enough. | |
| ▲ | jonathaneunice 4 days ago | parent | prev [-] | | Or the same one. While a screencap image hides the message, a screencap video shows it perfectly well. |
|
|
| ▲ | catlifeonmars 5 days ago | parent | prev | next [-] |
| https://gist.github.com/jncornett/d7cb397ce3ceff268a0ee1b86f... On iPhone: screenrecord. Take screenshots every couple seconds. Overlay images with 50% transparency (I use Procreate Pocket for this part) |
| |
| ▲ | CaptainOfCoit 5 days ago | parent | next [-] | | On Android: Take a look at the URL, see the text in plain-text :) | | | |
| ▲ | HarHarVeryFunny 4 days ago | parent | prev [-] | | A single photo is good enough as long as the exposure time is long enough to capture the motion blur. | | |
| ▲ | catlifeonmars 4 days ago | parent [-] | | If I had another camera then yes, that would have been easier. In my case I only had the one mobile device and I don’t think screenshots support long exposure. |
|
|
|
| ▲ | Anonyneko 5 days ago | parent | prev | next [-] |
| As soon as I read the title I knew it would be akin to "Bad Apple that disappears when you pause it" https://www.youtube.com/watch?v=bVLwYa46Cf0 And another version of this, using apples instead of white noise https://www.youtube.com/watch?v=r40AvHs3uJE |
|
| ▲ | kemayo 5 days ago | parent | prev | next [-] |
| This makes me feel motion-sick, which is kind of impressive because I'm normally not easily susceptible to that. |
| |
| ▲ | dylan604 5 days ago | parent [-] | | My eyes went straight into seeing 3D image mode. It's the easiest one I've seen yet! /s | | |
|
|
| ▲ | landgenoot 4 days ago | parent | prev | next [-] |
| I'm wondering. Can we also come up with something the other way around? Text you cannot read, unless you take a screenshot? |
| |
| ▲ | gnramires 4 days ago | parent | next [-] | | If you have a very high enough refresh rate display, then yes: just flash alternatingly black-over-white and white-over-black text (i.e. invert it). We perceive essentially a low-pass filtered visual input (with limitations like neural firing rate), eventually it should appear as just uniform gray. Maybe adding some confusing elements might make it feasible at lower refresh rates. | |
| ▲ | rompic 4 days ago | parent | prev | next [-] | | Maybe not exactly what you meant but it reminded me about the following: When one of our apple servers failed a decade ago and just vomitted out walls of error logs too fast to read anything,the apple support guy we called took his smartphone and made some photos to read and fix the error. | |
| ▲ | adrianmonk 4 days ago | parent | prev [-] | | You could probably do it with timing tricks related to video refresh. Wait until the monitor has finished refreshing, then draw the text into the framebuffer. Leave the text there a short while, but erase it before the monitor starts refreshing again. Repeat. The screenshot would have a chance of capturing the text, depending on exactly when the screenshot pulls pixel data out of the framebuffer. This might not work on certain devices. You need access to the refreshing timing information. The capture mechanism used for screenshots might also vary. |
|
|
| ▲ | Aeolun 5 days ago | parent | prev | next [-] |
| This should have an epilepsy warning. Or something of that kind. It certainly made me feel sick. |
| |
| ▲ | injidup 5 days ago | parent | next [-] | | This is more a curious question for those affected by epilepsy. If you know you are triggered by such things how long an exposure is required to trigger an effect. Are you able notice that media may be triggering and simply close it or is exposure and triggering almost instantaneous? | |
| ▲ | a3w 5 days ago | parent | prev | next [-] | | I saw the game using this rendering weeks ago, looked okay. Now I saw a font and tried to hold on to the edges while reading it, and yes, somehow this made me more (sea) sick. Strange. Perhaps faces would be strongest in terms of reaction. | |
| ▲ | dorianmonnier 5 days ago | parent | prev | next [-] | | Oh yes please add a warning. My brain is burning right now! | |
| ▲ | popopo73 4 days ago | parent | prev [-] | | This feels like when I had the spins in my college years. |
|
|
| ▲ | dylan604 5 days ago | parent | prev | next [-] |
| Has anyone tried a long exposure to see if the motion smears into something discernible? Obviously harder to expose a bright screen without some ND since the shutter speed is the phone's main exposure control |
| |
| ▲ | sprobertson 5 days ago | parent | next [-] | | Here's the screen recording version of a long exposure (thanks for the nerd snipe) - https://gist.github.com/spro/7599415b0e47de65311557b3454771a... | | |
| ▲ | shawnz 5 days ago | parent | next [-] | | Perhaps this technique could be defeated by scrolling the background in the opposite direction as the text | |
| ▲ | dylan604 4 days ago | parent | prev [-] | | That's what I was expecting to see. I didn't have a mount for my phone handy, to try it. The exporting of frames from a video is a good compromise though. nice one |
| |
| ▲ | lodovic 5 days ago | parent | prev | next [-] | | If you zoom out to 25 % the text is clearly visible and screenshottable. | | |
| ▲ | EvgeniyZh 5 days ago | parent [-] | | Probably the lower frequencies of noise are not matched? Not sure if the frequencies of the order of movement frequency can actually be matched |
| |
| ▲ | dasil003 5 days ago | parent | prev [-] | | How do you take a “long exposure” screenshot? Isn’t every screenshot a perfect digital copy of a single frame or a full on video? | | |
| ▲ | dylan604 5 days ago | parent [-] | | Clearly, I meant using a camera, and I'm guessing you knew that too | | |
| ▲ | dice 5 days ago | parent [-] | | Not the parent but that was not at all clear to me. I immediately thought of taking multiple successive instantaneous screenshots and then stacking them. I'm not sure I would have thought of using a camera within a few minutes to an hour, it's not a tool I would ever reach for normally. | | |
| ▲ | DonHopkins 4 days ago | parent | next [-] | | Oh, so your screenshot utility has "long exposure" and an "ND" filter and "shutter speed" controls, just like a phone's camera? What kind of screenshot utility simulates optical camera effects? What purpose does that serve? Care to share a link to it? >Obviously harder to expose a bright screen without some ND since the shutter speed is the phone's main exposure control https://en.wikipedia.org/wiki/Neutral-density_filter https://en.wikipedia.org/wiki/Shutter_speed | |
| ▲ | catlifeonmars 5 days ago | parent | prev | next [-] | | I just did this with 50% transparency. It works | |
| ▲ | viccis 5 days ago | parent | prev [-] | | Also not the parent but how the hell did you not understand what "long exposure" means ffs | | |
| ▲ | rkomorn 5 days ago | parent [-] | | Because the context is about screenshots and context matters "ffs". | | |
| ▲ | dylan604 4 days ago | parent | next [-] | | You mean like all of the context I used describing something not a screenshot. Being able to pick up on context clues from the reading is a crucial skill one should have in life. It also makes one look less clueless in conversation when the topics shift quickly and one can keep up. | | |
| ▲ | rkomorn 4 days ago | parent [-] | | None of this warrants the type of response they got, nor your attitude. |
| |
| ▲ | viccis 4 days ago | parent | prev [-] | | Periods go inside of quotes, even mealy mouthed shock quotes because an internet abbreviation made you upset. | | |
|
|
|
|
|
|
|
| ▲ | NKosmatos 4 days ago | parent | prev | next [-] |
| Nice one, the good (great?) thing is that you can save this as a plain old html and you've got the whole code :-)
It hasn't got any type of license included or any other info as comments, so perhaps the creator or the OP can let us know. |
|
| ▲ | oniony 5 days ago | parent | prev | next [-] |
| I don't see any text: just a scrolling down screen of random black/white pixels. |
| |
| ▲ | rnhmjoj 5 days ago | parent [-] | | It seems to depend on reading pixels from a canvas. This is commonly used for fingerprinting users on the web, so you have to disable some privacy plugins. |
|
|
| ▲ | temperceve 12 hours ago | parent | prev | next [-] |
| A problem I never knew I had until now. |
|
| ▲ | Theodores 4 days ago | parent | prev | next [-] |
| > let textString = `hello` I think further obfuscation could be possible by uglifying the script and providing a SVG path that stores the text as some vector image. Self modifying code could be useful too, to delete the SVG data once it is in the canvas. I fully expect this to still be defeated by AI though, such is my presumption that AI is smarter than me, always. It won't care about uglification and it would just laugh to itself at my humble efforts to defeat Skynet. Regarding practical applications, nowadays kids sell weed online quite brazenly on platforms such as Instagram. Prostitutes also sell their services on Telegram. It is only a matter of time before this type of usage gets clamped down on, so there may come a time when this approach will be needed to thwart the authorities. |
|
| ▲ | landgenoot 4 days ago | parent | prev | next [-] |
| I think there are usecases for this. Some countries switched to identity apps instead of plastic identity cards. You could make sensitive data non-screenshottable and non-photographable. A modern variant to the passport anti identity fraud cover: https://merk.anwb.nl/transform/a9b4e52a-9ba1-414b-b199-29085... The hotel you are checking in doesn't need to know your DOB, length, SSN, birth place, validity and document number. But they will demand a photo of the ID anyway. |
| |
| ▲ | jlokier 4 days ago | parent [-] | | > You could make sensitive data non-screenshottable and non-photographable. That made me curious, so I took a photo of my laptop screen running this page. With default camera settingse, the text wasn't visible to me in the photo on my phone screen. However, setting the exposure time manually to 0.5s, the text came out white on a noisy background and I could easily read it on the phone screen. I would not be surprised if the default camera settings photo could be processed ("enhance!") to make the text visible, but I didn't try. | | |
| ▲ | landgenoot 4 days ago | parent [-] | | I think it also depends on the response time of the display and even the temperature. |
|
|
|
| ▲ | zikero 5 days ago | parent | prev | next [-] |
| Another idea I had with this concept is to make an LLM-proof captcha. Maybe humans can detect the characters in the 'motion' itself, which could be unique to us? - The captcha would be generated like this on a headless browser, and recorded as a video, which is then served to the user. - We can make the background also move in random directions, to prevent just detecting which pixels are changing and drawing an outline. - I tried also having the text itself move (bounce like the DVD logo). Somehow makes it even more readable. I definitely know nothing about how LLMs interpret video, or optics, so please let me know if this is dumb. |
| |
| ▲ | squigz 5 days ago | parent | next [-] | | As if captchas aren't painful enough for visually impaired users... | |
| ▲ | xandrius 5 days ago | parent | prev | next [-] | | I don't think we need more capable people thinking of silly captchas. | | |
| ▲ | ATechGuy 4 days ago | parent [-] | | Why? stopping LLM crawlers is a need now. We've seen more capable people working for undergrad dropouts. |
| |
| ▲ | pwdisswordfishz 5 days ago | parent | prev [-] | | Take N screenshots, XOR them pairwise, OR the results, then perform normal OCR. | | |
| ▲ | ranger_danger 4 days ago | parent [-] | | Yes but this is prohibitively expensive for a large bot network to employ. Wasn't that the whole point of Anubis? |
|
|
|
| ▲ | captain123456 3 days ago | parent | prev | next [-] |
| I have no idea about anyprogramming at all, but i tried to make chatgpt make a wolfenstein-like game using this concept. It doesnt work but perhaps someone will be interested in the concept: https://pastebin.com/SKAnBPMg |
|
| ▲ | andai 5 days ago | parent | prev | next [-] |
| Neat! I've seen stuff like this that works as a magic eye thing. So you cross your eyes (or make them parallel, depending on the type of image) and it makes a 3d animation appear in front of the page. |
| |
|
| ▲ | Izkata 5 days ago | parent | prev | next [-] |
| Firefox on Android seems to just be a static image, I can't see any text. |
| |
| ▲ | creatonez 5 days ago | parent | next [-] | | Probably the result of canvas fingerprinting protection configured in your `about:config`? With a default profile it seems to work fine on Firefox for Android. | | |
| ▲ | Izkata 4 days ago | parent [-] | | I haven't changed any of that on here. Looks like I consistently get just the static image when I open in a new tab then switch to it, but then if I refresh the page without switching tabs it'll show the animation. |
| |
| ▲ | stevage 5 days ago | parent | prev [-] | | Wfm |
|
|
| ▲ | ape4 4 days ago | parent | prev | next [-] |
| You can pass in different text. eg: https://unscreenshottable.vercel.app/?text=Bonjour |
|
| ▲ | jerf 4 days ago | parent | prev | next [-] |
| On my Chrome-descended browser, the initial screen is populated by something that appears to be some sort of downsampled grid image, resulting in black and white, but also various shades of grey. However the scrolling text is pure black and white. It also seems the canvas is persistent, so the result is that text on the canvas is leaving a shadow for me, where I can still read the shadow. Somehow the initial noise is not coming out as just black and white pixels. |
|
| ▲ | wink 5 days ago | parent | prev | next [-] |
| Doesn't even show anything on LibreWolf, probably disabled WebGL as usual. I thought it was a nice error screen, but apparently it was intended, just without the text :P |
| |
|
| ▲ | vivegi 5 days ago | parent | prev | next [-] |
| Cool. I used the Windows snipping tool and just screen-recorded it. |
|
| ▲ | marcodiego 4 days ago | parent | prev | next [-] |
| Instead of having the pixels on the letters scrolling down, wouldn't it also work if the pixels were simply re-randomized every frame? |
| |
|
| ▲ | alanfalcon 5 days ago | parent | prev | next [-] |
| Not technically a screenshot, I guess, but trivially easy to do with software I had lying around all the same. https://media4.giphy.com/media/v1.Y2lkPTc5MGI3NjExYXloZ3Z0NT... |
|
| ▲ | throwaway81523 4 days ago | parent | prev | next [-] |
| I don't see any text, just something like scrolling white noise. I'm able to screenshot it. Am I missing something? |
| |
| ▲ | andersco 4 days ago | parent [-] | | Yes, there is a “Hello” in the noise, made visible through contrast and animation. |
|
|
| ▲ | cryptoz 5 days ago | parent | prev | next [-] |
| Had a lot of fun trying to break this. Turns out you can screenshot real easily by zooming out. Maybe there are other ways but I stopped trying :) |
| |
| ▲ | vunderba 5 days ago | parent | next [-] | | yeah - I actually was initially confused since I wasn't having any issues screenshotting it but had forgotten that I have the default site zoom set to ~65%. | |
| ▲ | sans_souse 5 days ago | parent | prev [-] | | Not sure what you mean - I can screenshot it freely that's not the point the point is if you look then at the screenshot you cant discern the text because its a single frame now | | |
| ▲ | esafak 5 days ago | parent | next [-] | | He's right. This is zoomed out: https://imgur.com/a/G7CKZ94 This is on MacOS 15.6, Chromium (BrowserOS), captured with the OS' native screenshot utility. Since I was asked about the zoom factor, I now tried simply capturing it at 100% and it was still perfectly readable... I guess the trick doesn't work on this browser. | | |
| ▲ | dylan604 5 days ago | parent | next [-] | | I zoomed out to 90% and could make out something was there but wasn't easy to read. Zooming out further went back to just being noise. I also tried zooming in but with no success. What zoom level did you use and I guess we have to ask the standard what browser/version/OS/etc?? My FFv142 on macOS never took a screen grab like you did | |
| ▲ | chii 5 days ago | parent | prev [-] | | This is really interesting - because it means the "randomness" is different between the text and the background, and when you zoom out enough, the eye can distinguish it? | | |
| ▲ | vunderba 5 days ago | parent [-] | | hmmm I think it's probably just an aliasing / canvas drawing issue. When I bring a screenshot in heavily zoomed out 33% - the pixels comprising the "HELLO" shape have a significantly higher luminance than the rest of the background. |
|
| |
| ▲ | dwg 5 days ago | parent | prev [-] | | Zooming out before taking screenshot and the text is no longer obfuscated. I tried and confirmed it works. In fact, the text is perhaps even more readable than the original. | | |
| ▲ | anigbrowl 5 days ago | parent [-] | | It depends how fast or slow your GPU is. I tried it and saw the effect you described, but within a second or two it started moving and was obscured again. Obviously you could automate the problem away. | | |
| ▲ | dylan604 5 days ago | parent [-] | | Mine freezes the animation on zoom change. Not sure you could automate against that | | |
| ▲ | anigbrowl 5 days ago | parent [-] | | What I meant was that even if it only freezes for a second, you could automate the screenshots to be captured during that time instead of trying to beat the clock manually |
|
|
|
|
|
|
| ▲ | bix6 5 days ago | parent | prev | next [-] |
| Ha cool! How’s it work? |
| |
| ▲ | Lalabadie 5 days ago | parent | next [-] | | The only way to see the text is in the movement. The pattern across any single frame is entirely random noise. | | |
| ▲ | thaumasiotes 5 days ago | parent [-] | | > The pattern across any single frame is entirely random noise. This is untrue in at least one sense. The patterning within the animated letters cycles. It is generated either by evaluating a periodic function or by reading from a file using a periodic offset. | | |
| ▲ | giveita 5 days ago | parent | next [-] | | Can't it be continuous random noise added at the top and then moved down each frame. Roughly you create another full size rect. On each frame add a random pixel on row 1 and shift everything down. Make that rest a layer below the top one which has Hello cut out as transparent. In any single frame the result is random noise. | | |
| ▲ | thaumasiotes 5 days ago | parent [-] | | You could do that, but that's not what the page is doing. You don't even need to maintain the approach of having the pattern within the text move downwards over time. You could redraw it every frame with random data, as if it was television static. It would still be easy to read, as long as the background stayed fixed. |
| |
| ▲ | ranger_danger 4 days ago | parent | prev [-] | | They didn't mean random noise as in certifiably truly random in a cryptographic sense... nobody cares about that for a silly demo. Random noise as in a normal non-tech human cannot see anything discernable to them at all, without the motion component. | | |
| ▲ | Lalabadie 10 hours ago | parent [-] | | Hah, late reply, but as a generative artist, the True Randomness in Computing rabbit hole has no perceivable bottom. As you said, I was _not_ alluding to more than being perceivably random/noisy. |
|
|
| |
| ▲ | tgv 5 days ago | parent | prev [-] | | It's not a great visual, but like this: https://michaelbach.de/ot/cog-Dalmatian/ |
|
|
| ▲ | creata 5 days ago | parent | prev | next [-] |
| Fun! I always wanted to make text that couldn't be recorded with a video recorder, but that doesn't seem possible. Maybe if you knew the exact framerate that the camera was recording at, you could do the same trick, but I don't think cameras are that consistent. |
|
| ▲ | jiehong 5 days ago | parent | prev | next [-] |
| I have to admit it's a pretty cool idea. At first I was worried that there was a (stupid) API in web browsers just like on mobiles to prevent users from screenshotting something by blanking the screen in the screenshot. |
|
| ▲ | p0w3n3d 5 days ago | parent | prev | next [-] |
| This idea has made me think of another subject - would it be possible to overload a face / car plate scanning camera by using a pattern, like qr code for exampl? Or a jacket made of qr codes? |
| |
|
| ▲ | birdman3131 4 days ago | parent | prev | next [-] |
| So windows 11 easily bypasses this when taking a screenshot. Just switch to video mode. (Yeah yeah. Not technically a screenshot but same default software built in to windows.) |
|
| ▲ | giamma 5 days ago | parent | prev | next [-] |
| It's a nice effect, but I don't think it's usable in practice, because it's not accessible for visually impaired users: not enough contrast between foreground text and background |
|
| ▲ | dgan 5 days ago | parent | prev | next [-] |
| What i am supposed to see here? Its just static noisy background |
| |
| ▲ | j1436go 5 days ago | parent | next [-] | | Had the same in LibreWolf under Manjaro Linux. Worked in Chrome. | |
| ▲ | giveita 5 days ago | parent | prev [-] | | Animation, but only inside a border that is the letters of Hello. |
|
|
| ▲ | trod1234 4 days ago | parent | prev | next [-] |
| Is this supposed to show something? All I am seeing is a static noise generated on a moving background towards the bottom. No text. |
|
| ▲ | shrikant 5 days ago | parent | prev | next [-] |
| Could someone please post what this disappeared bit is supposed to look like? Looks legible to me when I screenshot and open in Preview on MacOS 15.6.1 (Firefox). |
| |
| ▲ | grumbel 5 days ago | parent [-] | | You are probably browsing with zoom, that seems to screw up the up rendering and makes the background and text look different. It should be just black&white random pixel noise for both background and foreground, without motion the text becomes invisible, as it blends with the background. |
|
|
| ▲ | EGreg 4 days ago | parent | prev | next [-] |
| This is good but I feel it can somehow be made better! I like the idea of motion revealing things out of randomness and screenshots are random. You can just take a screencast though hehe |
|
| ▲ | tamimio 5 days ago | parent | prev | next [-] |
| In your phone, just record the screen, then drag the player to see how every still pic blend in within the surroundings, but as soon as it moves it shows up. |
|
| ▲ | QuiCasseRien 5 days ago | parent | prev | next [-] |
| Even is some have found a workaround, this is a cool feature |
|
| ▲ | alliancedamages 5 days ago | parent | prev | next [-] |
| You can also break it by recording the screen, of course. |
|
| ▲ | markasoftware 5 days ago | parent | prev | next [-] |
| same thing, but a game: https://brantagames.itch.io/motus |
|
| ▲ | amelius 5 days ago | parent | prev | next [-] |
| Yeah but the randomness may produce all kinds of NSFW stuff ... Also, it's even harder to read than most captchas. But fun idea, it was nice to see. |
|
| ▲ | UltraSane 5 days ago | parent | prev | next [-] |
| Seems trivial to diff multiple screenshots to identify what parts move. Or just use a compression algorithm to do the same. |
| |
|
| ▲ | jszymborski 4 days ago | parent | prev | next [-] |
| This would make for a great effect for a technothriller. Like a cyber ransom or something like that. |
|
| ▲ | johnjreiser 5 days ago | parent | prev | next [-] |
| Appreciate that it handles emoji as well.
Can't distinguish between smileys though. |
| |
|
| ▲ | tedggh 5 days ago | parent | prev | next [-] |
| I uploaded two images to ChatGPT and asked it to XOR them and give me the result in text. |
|
| ▲ | leogout 4 days ago | parent | prev | next [-] |
| It also dissapear if you shake your phone (or computer screen but it's harder) |
|
| ▲ | buibuibui 5 days ago | parent | prev | next [-] |
| This could be used for Captcha systems. Would current bots be able to decipher these? |
| |
| ▲ | ranger_danger 4 days ago | parent [-] | | Yes, you can make ChatGPT decipher this already. But doing this on a massive scale would warm the planet. And it's not friendly accessibility-wise. |
|
|
| ▲ | altcognito 5 days ago | parent | prev | next [-] |
| Fun side effect: staring at the letters for a bit makes the rest of the image move. |
|
| ▲ | viccis 5 days ago | parent | prev | next [-] |
| For what it's worth, there are some websites that embed some crazy shit when you screenshot. On reddit, r/CenturyClub will fill your background with a slightly off-white version of your username so that they can identify leakers, and I'm not certain how exactly they do it. |
|
| ▲ | db48x 5 days ago | parent | prev | next [-] |
| Sure, but I can just record a video instead. It doesn’t disappear then! |
|
| ▲ | alimbada 4 days ago | parent | prev | next [-] |
| I managed to screenshot it just fine. |
|
| ▲ | elAhmo 5 days ago | parent | prev | next [-] |
| If you blink really fast, the text almost disappears. |
|
| ▲ | benob 4 days ago | parent | prev | next [-] |
| a good benchmark for video understanding in IA |
|
| ▲ | magios 5 days ago | parent | prev | next [-] |
| firefox on linux with a bunch of css stuff set to defaults or none !important shows a static image |
|
| ▲ | davidgerard 5 days ago | parent | prev | next [-] |
| Screnshotted fine in Xfce. |
|
| ▲ | itomato 4 days ago | parent | prev | next [-] |
| Was this made with v0? |
|
| ▲ | Kuinox 4 days ago | parent | prev | next [-] |
| you can unzoom and then it's screenshotable. |
|
| ▲ | bilsbie 4 days ago | parent | prev | next [-] |
| Ultimately people will just take photos of the screen. Seems like you’re just annoying people. I feel like there’s an ethical issue. If something is on my screen I own it. I know the law doesn’t agree but it feels right to me. |
| |
| ▲ | sarreph 4 days ago | parent [-] | | The point is that it's noise and you can't "capture" a still image of the text / information (relies on motion to be viewable). | | |
| ▲ | ranger_danger 4 days ago | parent [-] | | We figured out how to capture video though. And ChatGPT can already decipher this. |
|
|
|
| ▲ | kps 5 days ago | parent | prev | next [-] |
| The text reappears when I screenshot it twice. |
|
| ▲ | domatic1 5 days ago | parent | prev | next [-] |
| but screen recording works :) |
|
| ▲ | captain123456 3 days ago | parent | prev | next [-] |
| asdf |
|
| ▲ | 1oooqooq 5 days ago | parent | prev | next [-] |
| "you cannot screenshot this already illegible mess of white noise" |
|
| ▲ | hbbio 5 days ago | parent | prev [-] |
| Coinbase was hacked for $400M when literally someone from outsourced support services was taking screenshots on their phone! The culprit had more than 10k photos of all security details for thousands of wealthy customers. |
| |
| ▲ | gloosx 5 days ago | parent [-] | | If it's even true someone from outsourced support has access to some sensitive security details then using this dumpster is almost like throwing your money out of the window. |
|