Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[UWP Render] Add Static SVG Support to ImageRenderer #8107

Merged
merged 17 commits into from
Dec 14, 2022
Merged

Conversation

anna-dingler
Copy link
Contributor

@anna-dingler anna-dingler commented Dec 7, 2022

Related Issue

Fixes #8124

Description

This PR adds SVG support to the UWP Image Renderer.

Note: Provided SVGs cannot have an explicit height or width set. This will interfere with the provided styles and sizing and can cause rendering issues.

Files Changes

AdaptiveImageRenderer.cpp

  • Most updates are made to SetImageOnUIElement to add additional logic for SVG handling
    • The largest conditionals are for SetSourceAsync handling because SvgImageSource and BitmapImage handle these responses differently
  • winrt::ImageSource XamlBuilder::CreateImageSource(bool isImageSvg) method returns the correct type of ImageSource for rendering
  • boolean XamlBuilder::IsSvgImage(std::string url) method determines if the url is an SVG

ImageLoadTracker.cpp

  • Add void TrackImage(winrt::ImageSource const& image) method that calls the respective tracking method for each image type
  • Add void TrackSvgImage(winrt::SvgImageSource const& svgImage) for SVG handling
  • Rename MarkFailedLoadBitmapImage to MarkFailedLoadImage and add logic for SVGs
  • Add overload of UnsubscribeFromEvents method that handles TrackedSvgImageDetails
  • Add TrackedImage_SvgImageLoaded(winrt::IInspectable const& sender, winrt::SvgImageSourceOpenedEventArgs const& eventArgs)
  • Add TrackedImage_SvgImageFailed(winrt::IInspectable const& sender, winrt::SvgImageSourceFailedEventArgs const& eventArgs)

ImageLoadTracker.h

  • New struct: TrackedSvgImageDetails : winrt::implements<TrackedSvgImageDetails, winrt::IInspectable> to handle Svg loading events
  • Rename: m_eventRevokers -> m_bitmapEventRevokers
  • Add std::unordered_map<winrt::IInspectable, winrt::com_ptr<TrackedSvgImageDetails>> m_svgEventRevokers; to track SVG
  • Rename: TrackedImage_ImageLoaded -> TrackedImage_BitmapImageLoaded
  • Rename: TrackedImage_ImageFailed -> TrackedImage_BitmapImageFailed

XamlBuilder.h

  • Add isImageSvg parameter to SetImageOnUIElement and PopulateImageFromUrlAsync methods
  • Add boolean IsSvgImage(std::string url) method.
  • Add winrt::ImageSource CreateImageSource(bool isImageSvg) method

XamlHelpers.cpp

  • SetAutoImageSize method
    • Determine if the ImageSource is Bitmap or SVG to get the height and width.

XamlHelpers.h

  • Updated SetAutoImageSize method to take ImageSource instead of BitmapSource

Visualizer Changes

  • Added a new svg asset
  • Updated the resource resolver so that we can test SVGs

Sample Cards

{
  "type": "AdaptiveCard",
  "version": "0.5",
  "body": [
    {
      "type": "Image",
      "url": "symbol:adaptive-card.svg",
      "backgroundColor": "#000000",
      "horizontalAlignment": "right",
      "width": "100px"
    }
  ]
}

image

{
    "type": "AdaptiveCard",
    "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
    "version": "1.5",
    "body": [
        {
            "type": "Image",
            "size": "medium",
            "url": ""
        }
    ]
}

image

{
  "type": "AdaptiveCard",
  "version": "0.5",
  "body": [
    {
      "type": "Image",
      "url": "https://adaptivecards.io/content/adaptive-card.svg"
    }
  ]
}

image

{
    "type": "AdaptiveCard",
    "$schema": "http://adaptivecards.io/schemas/adaptive-card.json",
    "version": "1.5",
    "body": [
        {
            "type": "Image",
            "backgroundColor": "#eeeeee",
            "style": "person",
            "url": ""
        }
    ]
}

image

How Verified

  • Verified manually on the UWP Visualizer with the cards above.
  • Added a new asset to test the resource resolver

In Progress

  • Finish testing ImageTracking.
  • Add samples

Future Work

Microsoft Reviewers: Open in CodeFlow

@anna-dingler anna-dingler marked this pull request as ready for review December 8, 2022 17:50
@anna-dingler anna-dingler changed the title [DRAFT] [UWP Render] Add Static SVG Support to ImageRenderer [UWP Render] Add Static SVG Support to ImageRenderer Dec 8, 2022
Copy link
Member

@jwoo-msft jwoo-msft left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this code works: have you thought about having small classes for SVG and Bitmap image?
and each classes implementing SetImageOnUIElement() so that we don't have to pass in isImageSvg boolean? We are likely going to support more image types. Relying on parameters to branch out to different images types could become a burden on later development.

Within the SetImageOnUIElement methods, we have similar code segments for two different image types, if we organize them into classes, you may find additional opportunities to refactor codes.

source/uwp/Renderer/lib/AdaptiveImageRenderer.cpp Outdated Show resolved Hide resolved
@anna-dingler
Copy link
Contributor Author

anna-dingler commented Dec 13, 2022

this code works: have you thought about having small classes for SVG and Bitmap image? and each classes implementing SetImageOnUIElement() so that we don't have to pass in isImageSvg boolean? We are likely going to support more image types. Relying on parameters to branch out to different images types could become a burden on later development.

Within the SetImageOnUIElement methods, we have similar code segments for two different image types, if we organize them into classes, you may find additional opportunities to refactor codes.

@jwoo-msft I can look into doing this. I originally had two separate methods for SetImageOnUIElement, but a significant portion was duplicate code which is why I combined them.

Update: we synced offline, and I'll work on refactoring after this PR is completed

@anna-dingler anna-dingler merged commit 78fb118 into main Dec 14, 2022
@anna-dingler anna-dingler deleted the anna/svg branch December 14, 2022 22:54
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[UWP Renderer] Add SVG Support
3 participants