Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/html/86.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/7/css/37.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Html Itext不渲染base64变换旋转图像_Html_Css_Image_Itext - Fatal编程技术网

Html Itext不渲染base64变换旋转图像

Html Itext不渲染base64变换旋转图像,html,css,image,itext,Html,Css,Image,Itext,我尝试使用transform rotate在html中旋转base64嵌入图像,图像在html页面中旋转良好,但当我尝试使用itext在pdf中呈现相同图像时,转换属性无效。 下面是我的示例html代码 <?xml version="1.0" encoding="utf-8"?> <html> <head> <style type="text/css"> body,div,td,th,span,h1,

我尝试使用transform rotate在html中旋转base64嵌入图像,图像在html页面中旋转良好,但当我尝试使用itext在pdf中呈现相同图像时,转换属性无效。 下面是我的示例html代码

<?xml version="1.0" encoding="utf-8"?>
<html>
    <head>
        <style type="text/css">
            body,div,td,th,span,h1,h2 {
                font:9pt/12pt "Roboto", serif;
            }
           .fleft {
                float:left;
                overflow-x: wrap;
            }
            .rotate90 {
                -webkit-transform: rotate(90deg);
                -moz-transform: rotate(90deg);
                -o-transform: rotate(90deg);
                -ms-transform: rotate(90deg);
                transform: rotate(90deg);
            }
            .gift-icon{
                width: 21mm;
                height: 21mm;
            }
        </style>
    </head>
    <body>
        <div>
            <img class="fleft gift-icon rotate90" alt="" src=""/>  
        </div>
    </body>
</html>
有人能帮我解决这个问题吗?
提前感谢

您只得到实际的
Base64
字符串。这个还没有旋转。网站本身使用CSS实现了这一点,当您获取图像数据时,CSS不会被读入。您需要单独处理旋转。我认为这是与
fsImage.setRotationDegrees(90)-记不起实际的方法。@Darren尝试了((ITextFSImage)fsImage.getImage().setRotationDegrees(90);缩放后不使用它,但不旋转图像
public class B64ImgReplacedElementFactory implements ReplacedElementFactory {

    public ReplacedElement createReplacedElement(LayoutContext c, BlockBox box, UserAgentCallback uac, int cssWidth, int cssHeight) {
        Element e = box.getElement();
        if (e == null) {
            return null;
        }
        String nodeName = e.getNodeName();
        if (nodeName.equals("img")) {
            String attribute = e.getAttribute("src");
            FSImage fsImage;
            try {
                fsImage = buildImage(attribute, uac);
            } catch (BadElementException e1) {
                fsImage = null;
            } catch (IOException e1) {
                fsImage = null;
            }
            if (fsImage != null) {
                if (cssWidth != -1 || cssHeight != -1) {
                    fsImage.scale(cssWidth, cssHeight);
                }
                return new ITextImageElement(fsImage);
            }
        }
        return null;
    }

    protected FSImage buildImage(String srcAttr, UserAgentCallback uac) throws IOException, BadElementException {
        FSImage fsImage;
        if (srcAttr.startsWith("data:image/")) {
            String b64encoded = srcAttr.substring(srcAttr.indexOf("base64,") + "base64,".length(), srcAttr.length());
            byte[] decodedBytes = Base64.decode(b64encoded);
            fsImage = new ITextFSImage(Image.getInstance(decodedBytes));
        } else {
            fsImage = uac.getImageResource(srcAttr).getImage();
        }
        return fsImage;
    }

    public void remove(Element e) {
    }

    public void reset() {
    }

    @Override
    public void setFormSubmissionListener(FormSubmissionListener listener) {
    }
}