public/images/Get-SpectreSixelImage.ps1
$script:CachedImages = @{} function Get-SpectreSixelImage { <# .SYNOPSIS Displays an image in the console using SixelImage. .DESCRIPTION Displays an image in the console using SixelImage, this requires Windows Terminal Preview or another Sixel compatible terminal. ![Spectre Sixel Example](/sixel.png) This uses a forked copy of Spectre.Console because Sixel is not supported yet https://github.com/spectreconsole/spectre.console/discussions/1671 :::caution This is experimental. Experimental features are unstable and subject to change. ::: .PARAMETER ImagePath The path to the image file to be displayed. This can be a local file path or a URL. .PARAMETER MaxWidth The maximum width of the image in character cells. If not specified, the image will be displayed at its original size or to fit inside the terminal width. #> [Reflection.AssemblyMetadata("title", "Get-SpectreSixelImage")] param ( [Parameter(Mandatory)] [string] $ImagePath, [int] $MaxWidth = (Get-HostWidth) ) if (!(Test-SpectreSixelSupport)) { # check if it's windows terminal or not if ($env:WT_SESSION) { Write-SpectreHost "[yellow]WARNING: Sixel graphics are only supported in Windows Terminal Preview[/]" -PassThru } else { Write-SpectreHost "[yellow]WARNING: Sixel graphics are not supported in this terminal see https://www.arewesixelyet.com/[/]" -PassThru } return } if ($ImagePath.StartsWith("http://") -or $ImagePath.StartsWith("https://")) { if (!$script:CachedImages.ContainsKey($ImagePath) -or -not (Test-Path $script:CachedImages[$ImagePath])) { $tempFile = New-TemporaryFile Invoke-WebRequest -Uri $ImagePath -UseBasicParsing -Outfile $tempFile -ProgressAction SilentlyContinue $script:CachedImages[$ImagePath] = $tempFile.FullName } $ImagePath = $script:CachedImages[$ImagePath] } $imagePathResolved = Resolve-Path $ImagePath if (-not (Test-Path $imagePathResolved)) { throw "The specified image path '$resolvedImagePath' does not exist." } $image = [Spectre.Console.SixelImage]::new($imagePathResolved) if ($MaxWidth) { $image.MaxWidth = $MaxWidth } return $image } |