diff --git a/samples/v1.5/Tests/Image.Svg.json b/samples/v1.5/Tests/Image.Svg.json index 2b79c89ff4..8764012062 100644 --- a/samples/v1.5/Tests/Image.Svg.json +++ b/samples/v1.5/Tests/Image.Svg.json @@ -60,6 +60,11 @@ "backgroundColor": "#eeeeee", "style": "person", "url": "" + }, + { + "type": "Image", + "url": "data:image/svg+xml;utf8, ", + "size": "medium" } ] } diff --git a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp index b1576d387e..d7277deb6c 100644 --- a/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp +++ b/source/uwp/SharedRenderer/lib/AdaptiveImageRenderer.cpp @@ -9,6 +9,7 @@ #include "AdaptiveBase64Util.h" #include "AdaptiveCardGetResourceStreamArgs.h" #include +#include "Util.h" #include "WholeItemsPanel.h" namespace winrt::AdaptiveCards::Rendering::Xaml_Rendering::implementation @@ -356,14 +357,22 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering if (schemeName == L"data") { - // Decode base 64 string - winrt::hstring dataPath = imageUrl.Path(); - std::string data = AdaptiveBase64Util::ExtractDataFromUri(HStringToUTF8(dataPath)); - std::vector decodedData = AdaptiveBase64Util::Decode(data); - winrt::DataWriter dataWriter{winrt::InMemoryRandomAccessStream{}}; - - dataWriter.WriteBytes(std::vector{decodedData.begin(), decodedData.end()}); + auto imagePath = HStringToUTF8(imageUrl.Path()); + auto foundBase64 = imagePath.find("base64"); + if (foundBase64 != std::string::npos) + { + // Decode base 64 string + std::string data = AdaptiveBase64Util::ExtractDataFromUri(imagePath); + std::vector decodedData = AdaptiveBase64Util::Decode(data); + dataWriter.WriteBytes(std::vector{decodedData.begin(), decodedData.end()}); + } + else if (imgProperties.isImageSvg) + { + // Extract ... string + std::string data = ExtractSvgDataFromUri(imageUrl); + dataWriter.WriteBytes(std::vector{data.begin(), data.end()}); + } auto image = CreateImageSource(imgProperties.isImageSvg); @@ -428,6 +437,11 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering strongThis->SetSvgUriSource(strongImageSource, imageUrl); } } + else if (status == winrt::AsyncStatus::Error) + { + // Handle error + winrt::hresult error = operation.ErrorCode(); + } } }); } diff --git a/source/uwp/SharedRenderer/lib/Util.cpp b/source/uwp/SharedRenderer/lib/Util.cpp index 9a012648e7..f8af698534 100644 --- a/source/uwp/SharedRenderer/lib/Util.cpp +++ b/source/uwp/SharedRenderer/lib/Util.cpp @@ -643,3 +643,17 @@ namespace AdaptiveCards::Rendering::Xaml_Rendering registration->Set(L"Action.Execute", winrt::make()); } } + +std::string ExtractSvgDataFromUri(winrt::Windows::Foundation::Uri const& imageUrl) +{ + winrt::Windows::Foundation::Uri uriObj(imageUrl); + winrt::hstring unescapedUri = uriObj.UnescapeComponent(uriObj.AbsoluteUri()); + std::string dataUri = HStringToUTF8(unescapedUri); + size_t svgPosition = dataUri.find("