diff --git a/tests/PdfToSvg.Tests/ConversionTests.cs b/tests/PdfToSvg.Tests/ConversionTests.cs index e3fd872..7f65a55 100644 --- a/tests/PdfToSvg.Tests/ConversionTests.cs +++ b/tests/PdfToSvg.Tests/ConversionTests.cs @@ -145,6 +145,10 @@ private static string RecompressPngs(string svgMarkup) .Descendants(ns + "use") .ToLookup(el => el.Attribute("href").Value); + var maskReferences = svg + .Descendants(ns + "g") + .ToLookup(el => el.Attribute("mask")?.Value); + foreach (var image in svg.Descendants(ns + "image")) { var hrefAttribute = image.Attribute("href"); @@ -165,6 +169,19 @@ private static string RecompressPngs(string svgMarkup) foreach (var reference in useElements["#" + oldId]) { reference.SetAttributeValue("href", "#" + newId); + + if (reference.Parent.Name.LocalName == "mask") + { + var newMaskId = StableID.Generate("m", newId); + var oldMaskId = reference.Parent.Attribute("id").Value; + + reference.Parent.SetAttributeValue("id", newMaskId); + + foreach (var maskReference in maskReferences["url(#" + oldMaskId + ")"]) + { + maskReference.SetAttributeValue("mask", "url(#" + newMaskId + ")"); + } + } } } } diff --git a/tests/TestFiles/Own/expected/masked-images.svg b/tests/TestFiles/Own/expected/masked-images.svg new file mode 100644 index 0000000..5bb1b00 --- /dev/null +++ b/tests/TestFiles/Own/expected/masked-images.svg @@ -0,0 +1,53 @@ + + + + + + + + + + + + + + + + + + + + +Color key mask + + + +Stencil mask + + + +Masked JPEG + + + +Inverted stencil mask + + + +Masked JPEG + + + +Soft mask + + + +Masked JPEG + + + + + \ No newline at end of file