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("