如何在c ++ / winrt UWP应用程序中使用SVG图像?

时间:2018-01-17 13:48:45

标签: c++ svg uwp c++-winrt

我已经能够在我的UWP应用程序中使用C ++ / WinRT以编程方式显示位图图像,但是我无法使SVG图像生效。

以下是我能想到的最简单的例子。我创建了一个应用程序,我加载了一个SVG图像,我将它添加到应用程序窗口并激活窗口。我在下面提供了源代码和SVG文件。

一些注意事项:

  • 应用程序运行,只是没有显示图像
  • 我确保SVG文件符合supported features in Windows
  • 该文件位于我的项目根文件夹
  • 以类似方式加载位图可以正常工作
  • 我尝试使用OpenFailed方法进行故障排除,但它提供的信息无用

#include "pch.h"


using namespace winrt;
using namespace winrt::Windows::ApplicationModel::Activation;
using namespace winrt::Windows::Foundation;
using namespace winrt::Windows::UI::Xaml;
using namespace winrt::Windows::UI::Xaml::Controls;
using namespace winrt::Windows::UI::Xaml::Media::Imaging;


struct App : ApplicationT<App>
{
    Image mImage;

    void OnLaunched(LaunchActivatedEventArgs const &)
    {
        //Load PNG image - WORKS
        //mImage.Source(BitmapImage(Uri(L"ms-appx:///sample.png")));

        //Load SVG image - FAILS
        mImage.Source(SvgImageSource(Uri(L"ms-appx:///sample.svg")));

        //Show image on screen
        Window window = Window::Current();
        window.Content(mImage);
        window.Activate();
    }

    static void Init(ApplicationInitializationCallbackParams const &)
    {
        make<App>();
    }
};

int WINAPI wWinMain(HINSTANCE, HINSTANCE, PWSTR, int)
{
    Application::Start(App::Init);
}

sample.svg

<?xml version="1.0" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">

<svg width="100" height="100" version="1.1" xmlns="http://www.w3.org/2000/svg">
  <circle cx="50" cy="50" r="50"/>
</svg>

1 个答案:

答案 0 :(得分:2)

问题不在您的代码中,而在于文件未随应用内容一起复制。

单击解决方案资源管理器中的sample.svg文件,然后查看属性工具栏。您会看到Content设置为False。您需要将其设置为True,以便将文件与其他内容文件(如图像)一起复制到输出文件夹中(默认情况下为Content,这就是为什么您没有这样做。)

Content setting