4

この中にいくつかの画像を含むHTMLを解析しています。

この画像は、ファイルシステムではなく、埋め込みリソースとして保存されます。

私が知っているように、HtmlPipelineContext でカスタム イメージ プロバイダーを設定する必要があり、このプロバイダーはイメージ パスまたは itextsharp イメージを取得する必要があります。

問題は、抽象画像プロバイダーのどのメソッドを実装する必要があるか知っている人はいますか? そしてどうやって?

これは私のコードです:

            var list = new List<string> { text };
            byte[] renderedBuffer;
            using (var outputMemoryStream = new MemoryStream())
            {
                using (
                    var pdfDocument = new Document(PageSize.A4, 30, 30, 30, 30))
                {
                    var pdfWriter = PdfWriter.GetInstance(pdfDocument, outputMemoryStream);
                    pdfWriter.CloseStream = false;
                    pdfDocument.Open();
                    HtmlPipelineContext htmlContext = new HtmlPipelineContext(new CssAppliersImpl());
                    htmlContext.SetImageProvider(new MyImageProvider());
                    htmlContext.SetTagFactory(Tags.GetHtmlTagProcessorFactory());
                    ICSSResolver cssResolver = XMLWorkerHelper.GetInstance().GetDefaultCssResolver(true);
                    CssResolverPipeline pipeline = new CssResolverPipeline(cssResolver, new HtmlPipeline(htmlContext, new PdfWriterPipeline(pdfDocument, pdfWriter)));
                    XMLWorker worker = new XMLWorker(pipeline, true);
                    XMLParser p = new XMLParser(worker);
                    foreach (var htmlText in list)
                    {
                        using (var htmlViewReader = new StringReader(htmlText))
                        {
                            p.Parse(htmlViewReader);
                        }
                    }
                }

                renderedBuffer = new byte[outputMemoryStream.Position];
                outputMemoryStream.Position = 0;
                outputMemoryStream.Read(renderedBuffer, 0, renderedBuffer.Length);
            }

前もって感謝します。

4

1 に答える 1

3

カスタム イメージ プロバイダーの使用はサポートされていないようです。本当にサポートしているのは、ルート パスの変更だけです。

ただし、この問題に対する 1 つの解決策を次に示します。

という名前の新しい html タグを作成し、<resimg src="{resource name}"/>そのカスタム タグ プロセッサを記述します。

実装は次のとおりです。

/// <summary>
/// Our custom HTML Tag to add an IElement.
/// </summary>
public class ResourceImageHtmlTagProcessor : AbstractTagProcessor
{
    public override IList<IElement> End(IWorkerContext ctx, Tag tag, IList<IElement> currentContent)
    {
        var src = tag.Attributes["src"];
        var bitmap = (Bitmap)Resources.ResourceManager.GetObject(src);

        if (bitmap == null)
            throw new RuntimeWorkerException("No resource with the name: " + src);

        var converter = new ImageConverter();
        var image = Image.GetInstance((byte[])converter.ConvertTo(bitmap, typeof(byte[])));
        HtmlPipelineContext htmlPipelineContext = this.GetHtmlPipelineContext(ctx);
        return new List<IElement>(1)
            {
                this.GetCssAppliers().Apply(
                    new Chunk((Image)this.GetCssAppliers().Apply(image, tag, htmlPipelineContext), 0f, 0f, true),
                    tag,
                    htmlPipelineContext)
            };
    }
}

新しいプロセッサを構成するには、TagFactory を指定する行を次のように置き換えます。

var tagProcessorFactory = Tags.GetHtmlTagProcessorFactory();
tagProcessorFactory.AddProcessor(new ResourceImageHtmlTagProcessor(), new[] { "resimg" });
htmlContext.SetTagFactory(tagProcessorFactory);
于 2013-01-02T22:19:27.927 に答える