如何使用 ToolbarItem 的 IconImageSource 的 Xamarin.Forms.Shapes.Path?

发布于 2025-01-11 19:43:58 字数 2596 浏览 0 评论 0原文

我有一个 Settings.xaml 文件:

<Path xmlns="http://xamarin.com/schemas/2014/forms"
  xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
  xmlns:drawables="clr-namespace:App.Resources.Drawables"
  x:DataType="drawables:Settings"
  x:Class="App.Resources.Drawables.Settings"
  Data="M12,15.5A3.5,3.5 0 0,1 8.5,12A3.5,3.5 0 0,1 12,8.5A3.5,3.5 0 0,1 15.5,12A3.5,3.5 0 0,1 12,15.5M19.43,12.97C19.47,12.65 19.5,12.33 19.5,12C19.5,11.67 19.47,11.34 19.43,11L21.54,9.37C21.73,9.22 21.78,8.95 21.66,8.73L19.66,5.27C19.54,5.05 19.27,4.96 19.05,5.05L16.56,6.05C16.04,5.66 15.5,5.32 14.87,5.07L14.5,2.42C14.46,2.18 14.25,2 14,2H10C9.75,2 9.54,2.18 9.5,2.42L9.13,5.07C8.5,5.32 7.96,5.66 7.44,6.05L4.95,5.05C4.73,4.96 4.46,5.05 4.34,5.27L2.34,8.73C2.21,8.95 2.27,9.22 2.46,9.37L4.57,11C4.53,11.34 4.5,11.67 4.5,12C4.5,12.33 4.53,12.65 4.57,12.97L2.46,14.63C2.27,14.78 2.21,15.05 2.34,15.27L4.34,18.73C4.46,18.95 4.73,19.03 4.95,18.95L7.44,17.94C7.96,18.34 8.5,18.68 9.13,18.93L9.5,21.58C9.54,21.82 9.75,22 10,22H14C14.25,22 14.46,21.82 14.5,21.58L14.87,18.93C15.5,18.67 16.04,18.34 16.56,17.94L19.05,18.95C19.27,19.03 19.54,18.95 19.66,18.73L21.66,15.27C21.78,15.05 21.73,14.78 21.54,14.63L19.43,12.97Z"
  Fill="White"
  x:Key="SettingsIcon" />

Settings.xaml.cs 文件很简单:

[XamlCompilation(XamlCompilationOptions.Compile)]
public partial class Settings : Path
{
    public Settings()
    {
        InitializeComponent();
    }
}

我认为我错误地使用了 IconImageSource 作为图标无法显示,而且我似乎找不到任何有关如何将其与 Xamarin.Forms.Shapes.Path 正确使用的文档。 作为测试,我尝试像这样使用它:

<Shell xmlns="http://xamarin.com/schemas/2014/forms"
       xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
       xmlns:App="clr-namespace:App.Views.Shared"
       x:DataType="App:Layout"
       Title="App"
       x:Class="App.Views.Shared.Layout"
       FlyoutBehavior="Disabled">

    <ContentPage Title="App">
        <ContentPage.ToolbarItems>
            <ToolbarItem IconImageSource="Resources\Drawables\Settings.xaml" />
        </ContentPage.ToolbarItems>
        <ContentPage.Content>
            <AbsoluteLayout>
                <Frame HasShadow="True" WidthRequest="64" HeightRequest="64" CornerRadius="4" />
            </AbsoluteLayout>
        </ContentPage.Content>
    </ContentPage>
</Shell>

Is it at all possible to use a Xamarin.Forms.Shapes.Path (实际上是一个 SVG,我相信)作为 ToolbarItem.IconImageSource值?

I have a Settings.xaml file:

<Path xmlns="http://xamarin.com/schemas/2014/forms"
  xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
  xmlns:drawables="clr-namespace:App.Resources.Drawables"
  x:DataType="drawables:Settings"
  x:Class="App.Resources.Drawables.Settings"
  Data="M12,15.5A3.5,3.5 0 0,1 8.5,12A3.5,3.5 0 0,1 12,8.5A3.5,3.5 0 0,1 15.5,12A3.5,3.5 0 0,1 12,15.5M19.43,12.97C19.47,12.65 19.5,12.33 19.5,12C19.5,11.67 19.47,11.34 19.43,11L21.54,9.37C21.73,9.22 21.78,8.95 21.66,8.73L19.66,5.27C19.54,5.05 19.27,4.96 19.05,5.05L16.56,6.05C16.04,5.66 15.5,5.32 14.87,5.07L14.5,2.42C14.46,2.18 14.25,2 14,2H10C9.75,2 9.54,2.18 9.5,2.42L9.13,5.07C8.5,5.32 7.96,5.66 7.44,6.05L4.95,5.05C4.73,4.96 4.46,5.05 4.34,5.27L2.34,8.73C2.21,8.95 2.27,9.22 2.46,9.37L4.57,11C4.53,11.34 4.5,11.67 4.5,12C4.5,12.33 4.53,12.65 4.57,12.97L2.46,14.63C2.27,14.78 2.21,15.05 2.34,15.27L4.34,18.73C4.46,18.95 4.73,19.03 4.95,18.95L7.44,17.94C7.96,18.34 8.5,18.68 9.13,18.93L9.5,21.58C9.54,21.82 9.75,22 10,22H14C14.25,22 14.46,21.82 14.5,21.58L14.87,18.93C15.5,18.67 16.04,18.34 16.56,17.94L19.05,18.95C19.27,19.03 19.54,18.95 19.66,18.73L21.66,15.27C21.78,15.05 21.73,14.78 21.54,14.63L19.43,12.97Z"
  Fill="White"
  x:Key="SettingsIcon" />

And the Settings.xaml.cs file is simply:

[XamlCompilation(XamlCompilationOptions.Compile)]
public partial class Settings : Path
{
    public Settings()
    {
        InitializeComponent();
    }
}

I presume I'm using IconImageSource incorrectly as the icon just fails to show and I can't seem to find any documentation on how to properly use it with a Xamarin.Forms.Shapes.Path.
As a test, I have tried using it like so:

<Shell xmlns="http://xamarin.com/schemas/2014/forms"
       xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
       xmlns:App="clr-namespace:App.Views.Shared"
       x:DataType="App:Layout"
       Title="App"
       x:Class="App.Views.Shared.Layout"
       FlyoutBehavior="Disabled">

    <ContentPage Title="App">
        <ContentPage.ToolbarItems>
            <ToolbarItem IconImageSource="Resources\Drawables\Settings.xaml" />
        </ContentPage.ToolbarItems>
        <ContentPage.Content>
            <AbsoluteLayout>
                <Frame HasShadow="True" WidthRequest="64" HeightRequest="64" CornerRadius="4" />
            </AbsoluteLayout>
        </ContentPage.Content>
    </ContentPage>
</Shell>

Is it at all possible to use a Xamarin.Forms.Shapes.Path (effectively an SVG, I believe) as a ToolbarItem.IconImageSource value?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

最近可好 2025-01-18 19:43:58

另一种选择是使用字体图标,例如 font aweosme。

设置详细信息和步骤:如何在项目中使用 Font Awesome 图标作为 ImageButton 的图标

最后在您的 ToolbarItem 中使用它,例如:

    <ContentPage.ToolbarItems>
        <ToolbarItem>
            <ToolbarItem.IconImageSource>
                <FontImageSource Glyph="{x:Static fonts:IconFont.Cog}"
                                 FontFamily="FontAwesome"/>
            </ToolbarItem.IconImageSource>
        </ToolbarItem>
    </ContentPage.ToolbarItems>

An alternative would be to use font icons like font aweosme.

Details and steps on ow to set it up: How to use Font Awesome icons in project as an icon of ImageButton

At the end use it in your ToolbarItem like:

    <ContentPage.ToolbarItems>
        <ToolbarItem>
            <ToolbarItem.IconImageSource>
                <FontImageSource Glyph="{x:Static fonts:IconFont.Cog}"
                                 FontFamily="FontAwesome"/>
            </ToolbarItem.IconImageSource>
        </ToolbarItem>
    </ContentPage.ToolbarItems>
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文