@page "/"
@using System.Drawing
@using System.Drawing.Imaging
@using System.IO
@using System.Threading.Tasks
@using Microsoft.AspNetCore.Components.Forms
@using System.Text
@using Microsoft.AspNetCore.Mvc
@using Microsoft.AspNetCore.Http
@inject IHttpContextAccessor HttpContextAccessor
@inject NavigationManager NavigationManager
@using System
@using System.Net
@* @using Microsoft.AspNetCore.Mvc
@using Claue3_Haiko *@
<h3>Bitmap to SVG Converter</h3>
<InputFile OnChange="@HandleFileUploadAsync" />
@* progress-bar *@
@if (isConverting)
{
<div class="progress mt-3">
<div class="progress-bar progress-bar-striped progress-bar-animated" role="progressbar" style="width: 100%"></div>
</div>
}
@if (svgContent != null)
{
<div>
<h4>Generated SVG:</h4>
<div>@((MarkupString)svgContent)</div>
</div>
<div>
<button class="btn btn-primary mt-3" @onclick="DownloadSvg">Download SVG</button>
</div>
}
@code {
private string svgContent = null!;
private bool isConverting = false;
// uploading the image
private async Task HandleFileUploadAsync(InputFileChangeEventArgs e)
{
var file = e.GetMultipleFiles(1).FirstOrDefault();
if (file != null)
{
isConverting = true;
StateHasChanged();
using var stream = new MemoryStream();
await file.OpenReadStream().CopyToAsync(stream);
stream.Seek(0, SeekOrigin.Begin);
var bitmap = new Bitmap(stream);
svgContent = ConvertBitmapToSvg(bitmap);
isConverting = false;
StateHasChanged();
}
}
//converting bitmap to svg
private string ConvertBitmapToSvg(Bitmap bitmap)
{
var width = bitmap.Width;
var height = bitmap.Height;
var svg = new StringBuilder();
svg.AppendLine($"<svg width='{width}' height='{height}' xmlns='http://www.w3.org/2000/svg'>");
for (int y = 0; y < height; y++)
{
for (int x = 0; x < width; x++)
{
var color = bitmap.GetPixel(x, y);
var hexColor = $"#{color.R:X2}{color.G:X2}{color.B:X2}";
svg.AppendLine($"<rect x='{x}' y='{y}' width='1' height='1' fill='{hexColor}' />");
}
}
svg.AppendLine("</svg>");
return svg.ToString();
}
// Downloading the svg image
private void DownloadSvg()
{
byte[] svgBytes = Encoding.UTF8.GetBytes(svgContent);
var fileName = "convertedImage.svg";
var base64 = Convert.ToBase64String(svgBytes);
var dataUrl = $"data:image/svg+xml;base64,{base64}";
NavigationManager.NavigateTo(dataUrl, true);
}
}