Coder Social home page Coder Social logo

shaderglass's Introduction

License GitHub Stars Downloads Latest Release

ShaderGlass

Overlay for running GPU shaders on top of Windows desktop.

Features

  • applies shader effects on top of any window on the desktop
  • includes RetroArch shader library covering:
    • CRT monitor simulation
    • image upscaling
    • TV / VHS simulation
    • softening, denoising, blur, sharpen and many more
  • works with most emulators and retro platforms including:
  • excellent companion for pixel art drawing showing shaded and/or aspect-ratio corrected preview
  • you can even use it on top of YouTube, Twitch or modern games
  • saving and loading profiles
  • multiple operating modes, including borderless fullscreen

Download

Latest release (v0.6, 31st Oct 2021):

  • adds ability to fine-tune Parameters for each shader
  • refresh of RetroArch shader library (200+ new shader profiles)

https://github.com/mausimus/ShaderGlass/releases/download/v0.6/ShaderGlass-0.6-win-x64.zip


Follow ShaderGlass on itch.io for latest updates.


Requirements

  • Windows 10, version 2004 (build 19041) or Windows 11
    • will work on version 1903 but in limited capacity (no Desktop Glass mode)
    • Windows 11 allows the removal of yellow border around capture
  • DirectX 11-capable GPU

If the app reports missing libraries please install Visual C++ Redistributable 2019


Screenshots

Desktop Glass mode

In this mode a transparent floating window will apply a shader to anything behind it. This mode is not OBS-friendly, use Window Glass or Clone modes to capture ShaderGlass. Requires Windows 10 2004 - on 1903/1909 you will see only a black window if you switch to this mode.

Wikipedia in Chrome processed by crt-geom shader which applies scanlines and CRT curvature.

screenshot

Window Clone mode

When capture is fixed to a specific window it's easier to tune scaling to match the input and image can also be recaptured (screenshot/OBS etc.)

FS-UAE

Amiga version of The Secret of Monkey Island (1990) running in FS-UAE with crt-interlaced-halation shader applied.

screenshot

Altirra

Ninja (1986) for the Atari XL running in Altirra with a TV-OUT simulation shader.

screenshot

Adventure Game Studio

The Crimson Diamond (2020), a modern AGS game softened using crt-fast-bilateral-super-xbr shader.

screenshot

DOSBox

Police Quest (1987) with its massive half-EGA pixels, aspect-ratio corrected and post-processed using newpixie-crt shader.

screenshot

Rick Dangerous (1989) with C64 monitor shader applied.

screenshot


Options

Currently supported options are:

  • Input -> Desktop - captures the whole desktop or an individual monitor, defaults to Glass mode

  • Input -> Window - captures the selected window, defaults to Clone mode

  • Input -> Capture Cursor - whether to include mouse cursor in capture

  • Input -> Remove Yellow Border - disables yellow frame around captured area (forced security feature); currently only supported on Windows 11

  • Input -> Pixel Size - indicates the size of input pixels (pre-scaling), i.e. if you run a game in x3 scaling mode set this to x3 as well so that ShaderGlass can tell the original resolution

  • Output -> Mode - overrides default mode for the input type:

    • Glass (default for Desktop) - ShaderGlass window appears transparent, you have to position it over the window or area you'd like to capture

    • Clone (default for Window) - ShaderGlass copies the content of capture so you can position it anywhere; this mode is also faster and more compatible

  • Output -> Window - override mouse behavior:

    • Solid (default for Clone) - ShaderGlass window area is solid (traps mouse events), with the only exception of passing focus to captured window when clicked

    • Click-through (default for Glass) - ShaderGlass window area is transparent and clickable/scrollable-through to window(s) underneath

  • Output -> Scale - apply additional scaling to the output if you'd like it to be larger; using no pre-scaling and only output scaling should result in best performance

  • Output -> Aspect Ratio Correction - presets for common aspect ratio correction factors (DOS, etc.), applied horizontally to preserve scanline count

    • If you select Custom you can enter your own correction ratio expressed as pixel height (1.0 being square pixel). For example, in MS-DOS era a picture of 320x200 resolution (16:10) was displayed on a 4:3 screen meaning each pixel was 1.2x tall on screen, 1.2 = (16/10) / (4/3)
  • Output -> Frame Skip - in order to improve performance divide frame rate by n (capture is done at VSync rate)

  • Output -> Fullscreen (Ctrl+Shift+G) - turn ShaderGlass into a topmost fullscreen borderless window, in Glass mode you will still see yellow outline around the screen but if you can use Window Glass (surrounding black bars) or Window Clone (top-left aligned) with your source then you can avoid yellow edges; press Ctrl+Shift+G to revert

  • Shader - choose RetroArch shader to apply, or none shader for testing

    • Parameters - show and modify active shader's parameters

You can save and load profile files which will store all the options. It's also possible to pass profile file path on the command line and ShaderGlass will load it on startup.


Command Line

ShaderGlass.exe [-p|--paused] [-f|--fullscreen] [profile.sgp]

You can pass profile filename as a command-line parameter to ShaderGlass.exe and it will be auto-loaded.

In addition -p will launch in paused mode, and -f will launch in fullscreen mode.


Tuning

In order to achieve the best effect it's necessary to tune parameters to match your input:

  • if you use scaling in your input, use nearest-neighbour (i.e. no smoothing) and set Input -> Pixel Size to match

  • moving/resizing the window slightly might also help find the best fit for downscaling pixels

  • use Window Clone mode if you can, it's fastest and most compatible; if you need mouse click-through use Glass mode

Always check that input is crisply pixelated using the "none" shader as there is often implicit scaling happening (for example even when Chrome displays an image at 100%, Windows DPI scaling is still applied). The none shader should display a pixelated image with no smoothing whatsoever, try to match Input Pixel Size setting with your input's size to achieve that.

Parameters

All shaders start using default Parameters as defined by their authors, but you can also tweak them using Shader -> Parameters menu option.

params

Emulators

Most emulators (DOSBox, FS-UAE, Altirra etc.) will capture mouse by default so you can use them in Window Clone mode. ShaderGlass window will remain topmost so just position it over the game window and Alt-Tab to the game to have mouse and focus captured.

ScummVM

ScummVM doesn't capture mouse cursor by default so for best results follow below steps:

  1. Use Window Clone mode, set Input/Output/Shader options to your liking
  2. Switch Output Window to Click-through
  3. Click or Alt-Tab to ScummVM game window so that it has focus
  4. Press Ctrl-M which will force ScummVM to capture mouse

This way you should have the mouse captured by ScummVM so that it remains within the game window until you press Ctrl-M again. You can apply output scaling and/or aspect ratio correction in ShaderGlass and enjoy the game.


Code

Built using Visual Studio 2019 using ISO C++ 20, Windows SDK 10.0.20348, Windows Capture API and DirectX 11.

ShaderGlass includes a limited implementation of RetroArch shader back-end. ShaderGen is a command-line tool for converting Slang shaders into .h files which can be merged into ShaderGlass. The conversion process requires:

  1. glslang for converting Slang/GLSL shaders to SPIR-V
  2. SPIR-V cross-compiler for converting those to HLSL (DX11 format)
  3. Direct3D Shader Compiler (fxc.exe) for pre-compiling into bytecode

Notices

shaderglass's People

Contributors

mausimus avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.