首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Avalonia 使用 AvaloniaMath 做内联 Latex 公式

Avalonia 使用 AvaloniaMath 做内联 Latex 公式

作者头像
林德熙
发布2026-04-13 09:07:11
发布2026-04-13 09:07:11
690
举报
文章被收录于专栏:林德熙的博客林德熙的博客

本文将告诉大家如何使用 AvaloniaMath 库在 TextBlock 里面,通过 InlineUIContainer 实现内联 Latex 公式效果

按照 .NET 惯例,先通过 NuGet 安装库,安装之后的 csproj 项目文件代码大概如下

代码语言:javascript
复制
<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
    <OutputType>WinExe</OutputType>
    <TargetFramework>net10.0</TargetFramework>
    <Nullable>enable</Nullable>
    <ApplicationManifest>app.manifest</ApplicationManifest>
    <AvaloniaUseCompiledBindingsByDefault>true</AvaloniaUseCompiledBindingsByDefault>
  </PropertyGroup>

  <ItemGroup>
    <PackageReference Include="Avalonia" Version="11.3.12" />
    <PackageReference Include="Avalonia.Desktop" Version="11.3.12" />
    <PackageReference Include="Avalonia.Themes.Fluent" Version="11.3.12" />
    <PackageReference Include="Avalonia.Fonts.Inter" Version="11.3.12" />
    <!--Condition below is needed to remove Avalonia.Diagnostics package from build output in Release configuration.-->
    <PackageReference Include="Avalonia.Diagnostics" Version="11.3.12">
      <IncludeAssets Condition="'$(Configuration)' != 'Debug'">None</IncludeAssets>
      <PrivateAssets Condition="'$(Configuration)' != 'Debug'">All</PrivateAssets>
    </PackageReference>
    <PackageReference Include="AvaloniaMath" Version="2.1.0" />
  </ItemGroup>
</Project>

本文用到的 AvaloniaMath 库是一个开源项目,最初是做 WPF 的 Latex 公式支持,后面为了支持 Avalonia 框架就改名为 xaml-math 项目,项目地址是: https://github.com/ForNeVeR/xaml-math

完成基础库安装之后,即可直接在 XAML 里面使用,其演示代码如下

代码语言:javascript
复制
<Window ... xmlns:controls="clr-namespace:AvaloniaMath.Controls;assembly=AvaloniaMath">
        <TextBlock>
            <Run>123</Run>
            <InlineUIContainer BaselineAlignment="Bottom">
                <controls:FormulaBlock Formula="\frac{1}{2}"/>
            </InlineUIContainer>
        </TextBlock>
</Window>

运行起来的效果如下

本文代码放在 githubgitee 上,可以使用如下命令行拉取代码。我整个代码仓库比较庞大,使用以下命令行可以进行部分拉取,拉取速度比较快

先创建一个空文件夹,接着使用命令行 cd 命令进入此空文件夹,在命令行里面输入以下代码,即可获取到本文的代码

代码语言:javascript
复制
git init
git remote add origin https://gitee.com/lindexi/lindexi_gd.git
git pull origin 55a2a3f647d2cce4e1c5813471f18085dbae42a8

以上使用的是国内的 gitee 的源,如果 gitee 不能访问,请替换为 github 的源。请在命令行继续输入以下代码,将 gitee 源换成 github 源进行拉取代码。如果依然拉取不到代码,可以发邮件向我要代码

代码语言:javascript
复制
git remote remove origin
git remote add origin https://github.com/lindexi/lindexi_gd.git
git pull origin 55a2a3f647d2cce4e1c5813471f18085dbae42a8

获取代码之后,进入 AvaloniaIDemo/QercirawhalroNaicawcalqel 文件夹,即可获取到源代码

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档