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 线程。

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

相关推荐
Artech2 小时前
[MAF预定义的AIContextProvider-03]ChatHistoryMemoryProvider——赋予Agent从经验中学习的能力
ai·c#·agent·memory·maf
Scout-leaf2 天前
C#摸鱼实录——IoC与DI案例详解
c#
咕白m6252 天前
使用 C# 在 Excel 中应用多种字体样式
后端·c#
Artech2 天前
[MAF预定义的AIContextProvider-02]AgentSkillsProvider——将Agent Skills引入MAF
ai·c#·agent·agent skills·maf
LDR0063 天前
Type-C 快充全面升级!LDR6601 赋能个人护理便携电机,重塑剃须刀 / 理发器新体验
c语言·开发语言
雪碧聊技术3 天前
Tree.js是什么?一文讲透
开发语言·javascript·ecmascript
码云数智-园园3 天前
C++20 Modules 模块详解
java·开发语言·spring
swordbob3 天前
NIO的channel中什么是 fd(File Descriptor,文件描述符)
java·开发语言·nio
源分享3 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
Luminous.3 天前
C语言--day30
c语言·开发语言