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 Renderer] Parse for SVG width and height #8256

Merged
merged 14 commits into from
Feb 22, 2023

Conversation

anna-dingler
Copy link
Contributor

@anna-dingler anna-dingler commented Jan 24, 2023

Related Issue

Fixes #8243

Description

RasterizedWidth and/or RasterizedHeight need to be set for all SVG images if possible. This PR addresses this in two ways:

  1. Before assigning the image source, we parse the provided SVG for the height and width. If the height/width is set to a real number, we updated the RasterizedWidth and/or RasterizedHeight. Once this is complete, we continue setting the image source.
  2. If an explicit height/width or height is provided in the card payload, we update the RasterizedWidth and/or RasterizedHeight with those values.

Note: Values set in 1 take priority over those set in 2.

This PR also includes refactoring for duplicate code in AdaptiveImageRenderer.

Sample Card

URL with size property

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

image

URL with explicit height & width

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

image

Resource resolver: fixed width & person style

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

image

Resource resolver: size property

{
  "type": "AdaptiveCard",
  "version": "0.5",
  "body": [
    {
      "type": "Image",
      "url": "symbol:adaptive-card-fixed-height.svg",
      "backgroundColor": "#000000",
      "horizontalAlignment": "right",
      "size": "medium"
    }
  ]
}

image

Data URI: size property

{
  "type": "AdaptiveCard",
  "version": "0.5",
  "body": [
    {
      "type": "Image",
      "url": "",
      "size": "medium"
    }
  ]
}

image

Data URI: explicit height and width

{
  "type": "AdaptiveCard",
  "version": "0.5",
  "body": [
    {
      "type": "Image",
      "url": "",
      "height": "300px",
      "width": "300px"
    }
  ]
}

image

How Verified

Verified manually on the AdaptiveCards Visualizer.

Microsoft Reviewers: Open in CodeFlow

anna-dingler and others added 2 commits January 27, 2023 09:53
* Temp branch

* svg updates

* Pass by value

* Remove temp var

* Use make_weak

* Fix spacing
@anna-dingler anna-dingler merged commit 1981284 into release/uwp-v3.1.0 Feb 22, 2023
@anna-dingler anna-dingler deleted the anna/svgUpdate branch February 22, 2023 19:04
anna-dingler added a commit that referenced this pull request Feb 28, 2023
* WIP: set raster height and width

* WIP: add template method

* WIP: parse svg for size

* Update resources and spacing

* update visualizer csproj

* Only set height

* Resolve PR comments

* Remove try catch blocks

* [UWP] Remove weak_ref from method headers and pass by value (#8295)

* Temp branch

* svg updates

* Pass by value

* Remove temp var

* Use make_weak

* Fix spacing

* Resolve PR comments

* Use image properties struct

* Resolve PR comments and handle errors

* Add test json
anna-dingler added a commit that referenced this pull request Mar 21, 2023
* Switch to gotFocus (#8148) (#8150)

* Update custom.props

* [UWP] Update custom.props for object model release (#8225)

* Update custom.props for object model release

* Updated Xcode version (#8222)

* removed build step as they are redundant (#8201)

* removed build step as they are redundant

* added pod installation step

Co-authored-by: Joseph Woo <Joseph.Woo@microsoft.com>

* [UWP Renderer] Add a null check to inline action rendering (#8228)

* Update custom.props for object model release

* Updated Xcode version (#8222)

* removed build step as they are redundant (#8201)

* removed build step as they are redundant

* added pod installation step

* Add a null check for inline Actions

Co-authored-by: Joseph Woo <Joseph.Woo@microsoft.com>

* [UWP][Infra] Update nuget files for release (#6576) (#8240)

* [UWP][Infra] Update nuget files for release (#6576)

* Add new nuspec files

* Fix nuspec

* Update build copy script

* Add dependency to renderer

* 1.5 website schema explorer updates (#6550)

* Updating schema explorer properties

* adding tableCell to toc and attempting whitespace fix

* indentation fix

indentation fix

* Removing filtered prop

Removing filtered prop - it's auto generated in our build

Co-authored-by: RahulAmlekar <raamleka@microsoft.com>

* Custom.props to 1.0.0 for Object model build

* Update dependency version

Co-authored-by: Rahul Amlekar <rahul.amlekar@mail.mcgill.ca>
Co-authored-by: RahulAmlekar <raamleka@microsoft.com>
Co-authored-by: Rebecca Muraira <rebecch@microsoft.com>

* Remove blank lines

Co-authored-by: almedina-ms <35784165+almedina-ms@users.noreply.github.com>
Co-authored-by: Rahul Amlekar <rahul.amlekar@mail.mcgill.ca>
Co-authored-by: RahulAmlekar <raamleka@microsoft.com>
Co-authored-by: Rebecca Muraira <rebecch@microsoft.com>

* [UWP Renderer] Parse for SVG width and height (#8256)

* WIP: set raster height and width

* WIP: add template method

* WIP: parse svg for size

* Update resources and spacing

* update visualizer csproj

* Only set height

* Resolve PR comments

* Remove try catch blocks

* [UWP] Remove weak_ref from method headers and pass by value (#8295)

* Temp branch

* svg updates

* Pass by value

* Remove temp var

* Use make_weak

* Fix spacing

* Resolve PR comments

* Use image properties struct

* Resolve PR comments and handle errors

* Add test json

* Update custom props (#8329)

* Update the object model dependency (#8331)

---------

Co-authored-by: Joseph Woo <Joseph.Woo@microsoft.com>
Co-authored-by: almedina-ms <35784165+almedina-ms@users.noreply.github.com>
Co-authored-by: Rahul Amlekar <rahul.amlekar@mail.mcgill.ca>
Co-authored-by: RahulAmlekar <raamleka@microsoft.com>
Co-authored-by: Rebecca Muraira <rebecch@microsoft.com>
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.

4 participants