C# AvaloniaUI动态显示图片

AvaloniaUI 实现图片读取与显示

在 AvaloniaUI 中,图片的读取与显示可以通过 Image 控件和 Bitmap 类实现。以下是一个完整的示例代码,展示如何从文件路径加载图片并显示在界面上。

创建 AvaloniaUI 项目

确保已安装 AvaloniaUI 模板。如果未安装,可以通过以下命令安装:

bash 复制代码
dotnet new install Avalonia.Templates
dotnet new avalonia.app -n AvaloniaImageDemo
修改主窗口代码

MainWindow.axaml 中定义 Image 控件:

xml 复制代码
<Window xmlns="https://github.com/avaloniaui"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="AvaloniaUI 图片显示示例">
    <StackPanel>
        <Image x:Name="PreviewImage" Width="300" Height="300"/>
        <Button Content="选择图片" Click="OnLoadImageClick"/>
    </StackPanel>
</Window>
实现图片加载逻辑

MainWindow.axaml.cs 中添加以下代码:

csharp 复制代码
using Avalonia;
using Avalonia.Controls;
using Avalonia.Input;
using Avalonia.Media.Imaging;
using Avalonia.Platform;
using System.IO;
using System.Threading.Tasks;

public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();
    }

    private async void OnLoadImageClick(object sender, RoutedEventArgs e)
    {
        // 打开文件选择对话框
        var dialog = new OpenFileDialog();
        dialog.Filters.Add(new FileDialogFilter { Name = "图片文件", Extensions = { "jpg", "png", "bmp" } });
        var result = await dialog.ShowAsync(this);

        if (result != null && result.Length > 0)
        {
            var filePath = result[0];
            await LoadImageAsync(filePath);
        }
    }

    private async Task LoadImageAsync(string filePath)
    {
        // 异步加载图片
        using (var stream = File.OpenRead(filePath))
        {
            var bitmap = new Bitmap(stream);
            PreviewImage.Source = bitmap;
        }
    }
}
从资源加载图片

如果图片嵌入到程序集中(如 Assets 文件夹),可通过以下方式加载:

csharp 复制代码
private void LoadEmbeddedImage()
{
    var assets = AvaloniaLocator.Current.GetService<IAssetLoader>();
    using (var stream = assets.Open(new Uri("avares://AvaloniaImageDemo/Assets/sample.png")))
    {
        var bitmap = new Bitmap(stream);
        PreviewImage.Source = bitmap;
    }
}
注意事项
  • 文件路径需确保应用有访问权限。
  • 图片格式需为 Avalonia 支持的格式(如 PNG、JPEG、BMP)。
  • 异步加载大图片时建议使用 await 避免阻塞 UI 线程。

以上代码实现了从文件系统选择图片并显示的功能,同时提供了从嵌入式资源加载的示例。

相关推荐
日光明媚1 小时前
一步生成视频!One-Forcing:DMD + 零成本 GAN,训练 200 步超越多步 SOTA
android·开发语言·kotlin
2301_803538951 小时前
Java读取Word图片的两种实用方法
java·开发语言·word
bug和崩溃我都要3 小时前
Qt 封装 libmpv 全功能视频播放器开发指南
开发语言·qt·音视频
郝学胜-神的一滴3 小时前
Qt 高级开发 018:复刻经典登录界面布局与窗口美化全解析
开发语言·c++·qt·程序人生·用户界面
郝亚军3 小时前
IEEE 754 单精度浮点的SEM表示
开发语言·c++·算法
zhangjw343 小时前
第15篇:Java多线程零基础入门,进程线程、线程创建方式、线程生命周期、线程安全彻底吃透
java·开发语言·面试
蝈理塘(/_\)大怨种3 小时前
类和对象 (上)
java·开发语言
csdn_aspnet4 小时前
EasyModbus 与 C# 集成
c#·modbus·easymodbus
小新1104 小时前
qt creator 将qInfo的输出日志写入日志文档,方便查看
开发语言·qt