Skip to content

Commit

Permalink
fix(docx): honour percentage widths for SVG images
Browse files Browse the repository at this point in the history
Signed-off-by: Edwin Török <edwin@etorok.net>
  • Loading branch information
edwintorok committed Dec 27, 2023
1 parent d56f9bb commit 438a451
Show file tree
Hide file tree
Showing 5 changed files with 12 additions and 8 deletions.
10 changes: 7 additions & 3 deletions src/Text/Pandoc/ImageSize.hs
Original file line number Diff line number Diff line change
Expand Up @@ -166,8 +166,8 @@ sizeInPoints s = (pxXf * 72 / dpiXf, pxYf * 72 / dpiYf)
-- | Calculate (height, width) in points, considering the desired dimensions in the
-- attribute, while falling back on the image file's dpi metadata if no dimensions
-- are specified in the attribute (or only dimensions in percentages).
desiredSizeInPoints :: WriterOptions -> Attr -> ImageSize -> (Double, Double)
desiredSizeInPoints opts attr s =
desiredSizeInPoints :: WriterOptions -> Attr -> Maybe Integer -> ImageSize -> (Double, Double)
desiredSizeInPoints opts attr pageWidthPoints' s =
case (getDim Width, getDim Height) of
(Just w, Just h) -> (w, h)
(Just w, Nothing) -> (w, w / ratio)
Expand All @@ -176,7 +176,11 @@ desiredSizeInPoints opts attr s =
where
ratio = fromIntegral (pxX s) / fromIntegral (pxY s)
getDim dir = case dimension dir attr of
Just (Percent _) -> Nothing
Just (Percent a) ->
case (dir, pageWidthPoints') of
(Width, Just pageWidthPoints) ->
Just $ fromIntegral pageWidthPoints * a
_ -> Nothing
Just dim -> Just $ inPoints opts dim
Nothing -> Nothing

Expand Down
4 changes: 2 additions & 2 deletions src/Text/Pandoc/Writers/Docx.hs
Original file line number Diff line number Diff line change
Expand Up @@ -1530,15 +1530,15 @@ inlineToOpenXML' opts (Link _ txt (src,_)) = do
return i
return [ Elem $ mknode "w:hyperlink" [("r:id",id')] contents ]
inlineToOpenXML' opts (Image attr@(imgident, _, _) alt (src, title)) = do
pageWidth <- asks envPrintWidth
pageWidth <- asks envPrintWidth -- in Points
imgs <- gets stImages
let
stImage = M.lookup (T.unpack src) imgs
generateImgElt (ident, fp, mt, img) = do
docprid <- getUniqueId
nvpicprid <- getUniqueId
let
(xpt,ypt) = desiredSizeInPoints opts attr
(xpt,ypt) = desiredSizeInPoints opts attr (Just pageWidth)
(either (const def) id (imageSize opts img))
-- 12700 emu = 1 pt
pageWidthPt = case dimension Width attr of
Expand Down
2 changes: 1 addition & 1 deletion src/Text/Pandoc/Writers/ICML.hs
Original file line number Diff line number Diff line change
Expand Up @@ -613,7 +613,7 @@ imageICML opts style attr (src, _) = do
report $ CouldNotFetchResource src $ tshow e
return def)
let (ow, oh) = sizeInPoints imgS
(imgWidth, imgHeight) = desiredSizeInPoints opts attr imgS
(imgWidth, imgHeight) = desiredSizeInPoints opts attr Nothing imgS
hw = showFl $ ow / 2
hh = showFl $ oh / 2
scale = showFl (imgWidth / ow) <> " 0 0 " <> showFl (imgHeight / oh)
Expand Down
2 changes: 1 addition & 1 deletion src/Text/Pandoc/Writers/RTF.hs
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ rtfEmbedImage opts x@(Image attr _ (src,_)) = catchError
<> "\\pichgoal" <> tshow (floor (ypt * 20) :: Integer)
-- twip = 1/1440in = 1/20pt
where (xpx, ypx) = sizeInPixels sz
(xpt, ypt) = desiredSizeInPoints opts attr sz
(xpt, ypt) = desiredSizeInPoints opts attr Nothing sz
let raw = "{\\pict" <> filetype <> sizeSpec <> " " <>
T.concat bytes <> "}"
if B.null imgdata
Expand Down
2 changes: 1 addition & 1 deletion test/command/9288.md
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,6 @@
^D
2> [trace] rsvg-convert -f png -a --dpi-x 96 --dpi-y 96 --width 360.000000pt --height 360.000000pt
2> [trace] rsvg-convert -f png -a --dpi-x 96 --dpi-y 96 --width 360.000000pt --height 360.000000pt
2> [trace] rsvg-convert -f png -a --dpi-x 96 --dpi-y 96 --width 75.000000pt --height 75.000000pt
2> [trace] rsvg-convert -f png -a --dpi-x 96 --dpi-y 96 --width 336.000000pt --height 336.000000pt
2> [trace] rsvg-convert -f png -a --dpi-x 96 --dpi-y 96 --width 75.000000pt --height 75.000000pt
```

0 comments on commit 438a451

Please sign in to comment.