使用PDFSharp-gdi C#将Tiff格式转换为pdf

3

我卡住了。我正在尝试模拟从数据库中提取二进制数据块,并将其视为TIFF图像。我使用这个代码片段image.tif中的图像变量进行操作。我相信我已经接近实现了这一点。问题可能与我如何将字符串转换为字节数组有关。基本上,该应用程序会抛出一个异常,指出它无法创建帧数为0的PDF。在这一点上,我必须承认我可能在这个问题上头脑不太够用了。是否有人可以友善地帮我解决这个问题的剩余部分呢?

以下是代码:

using System;
using System.Drawing;
using PdfSharp.Pdf;
using PdfSharp.Drawing;
using System.IO;
using System.Drawing.Imaging;
using System.Text;

namespace ConvertTifToPDFFile
{
    class Program
    {

        static void Main(string[] args)
        {
            string image = "";

            byte[] imageAsByteStream = Encoding.ASCII.GetBytes(image);

            int imageByteStreamLength = imageAsByteStream.Length;

            string base64EncodedImage = Convert.ToBase64String(imageAsByteStream);

            imageAsByteStream = Encoding.ASCII.GetBytes(base64EncodedImage);

            Stream imageStream = TiffImageSplitter.ByteArrayToMemoryStream(imageAsByteStream);
            // Image splitImage = TiffImageSplitter.getTiffImage(imageStream, 1);
            TiffImageSplitter.tiff2PDF(imageStream);


        }
    }

    public class TiffImageSplitter
    {
        private static TiffImageSplitter tiff = new TiffImageSplitter();

        public static void tiff2PDF(Stream imageByteStream)
        {

            PdfDocument doc = new PdfDocument();

            int pageCount = getPageCount(imageByteStream);

            for (int i = 0; i < pageCount; i++)
            {
                PdfPage page = new PdfPage();
                Image img = getTiffImage(imageByteStream, 1);
                XImage imgFrame = XImage.FromGdiPlusImage(img);

                page.Width = imgFrame.PointWidth;
                page.Height = imgFrame.PointHeight;
                doc.Pages.Add(page);

                XGraphics xgr = XGraphics.FromPdfPage(doc.Pages[i]);

                xgr.DrawImage(img, 0, 0);
            }

            doc.Save("C:/temp/test.pdf");

            doc.Close();

        }


        public static Image getTiffImage(Stream imageStream, int pageNumber)
        {
            MemoryStream ms = null;
            Image returnImage = null;

            try
            {
                ms = new MemoryStream();
                Image sourceImage = Image.FromStream(imageStream, true, true);

                Guid objGuid = sourceImage.FrameDimensionsList[0];

                FrameDimension objDimension = new FrameDimension(objGuid);

                sourceImage.SelectActiveFrame(objDimension, pageNumber);

                sourceImage.Save(ms, ImageFormat.Tiff);

                returnImage = Image.FromStream(ms);
            }
            catch (Exception ex)
            {
                Console.WriteLine("{0} Exception caught.", ex);
                returnImage = null;
            }

            return returnImage;
        }

        public static MemoryStream ByteArrayToMemoryStream(byte[] bytestream)
        {

            MemoryStream stream = new MemoryStream();
            stream.Write(bytestream, 0, bytestream.Length);

            return stream;
        }

        public static int getPageCount(Stream imageStream)
        {
            int pageCount = -1;
            try
            {
                Image img = Image.FromStream(imageStream, true, true);
                pageCount = img.GetFrameCount(FrameDimension.Page);
                img.Dispose();

            }
            catch (Exception ex)
            {
                Console.WriteLine("{0} Exception caught.", ex);
                pageCount = 0;
            }

            return pageCount;
        }
    }
}

我不明白为什么你要进行BASE64编码(还有其他一些我不理解的事情)。 - I liked the old Stack Overflow
我试图确定是否需要对字符串进行解码或编码以使其有效。 - ozfive
在我看来,这似乎是一个HEX编码的字符串,应该解码为二进制格式。 - I liked the old Stack Overflow
你能建议我如何将十六进制解码为二进制吗? - ozfive
你的十六进制字符串不合法,它应该有偶数个字符。 - ScottyD0nt
1个回答

6

重要提示!!!首先,你的tiff示例根本无效。它无法被任何文件编辑器读取。我不得不使用这些进行测试。

其次,代码中有几个错误:

1)我不理解你对字符串所做的操作,但读取文件和BLOB是相同的:

        static void Main(string[] args)
        {
            //string image = "";

            //byte[] imageAsByteStream = Encoding.ASCII.GetBytes(image);

            byte[] imageAsByteStream = File.ReadAllBytes("../../../MARBIBM.TIF");

            //int imageByteStreamLength = imageAsByteStream.Length;

            //string base64EncodedImage = Convert.ToBase64String(imageAsByteStream);

            //imageAsByteStream = Encoding.ASCII.GetBytes(base64EncodedImage);

            Stream imageStream = TiffImageSplitter.ByteArrayToMemoryStream(imageAsByteStream);
            // Image splitImage = TiffImageSplitter.getTiffImage(imageStream, 1);
            TiffImageSplitter.tiff2PDF(imageStream);


        }

2) tiff2PDF 方法应该如下:


        public static void tiff2PDF(Stream imageByteStream)
        {

            PdfDocument doc = new PdfDocument();

            int pageCount = getPageCount(imageByteStream);

            for (int i = 0; i < pageCount; i++)
            {
                PdfPage page = new PdfPage();
                Image img = getTiffImage(imageByteStream, i); //<---HERE WAS ANOTHER ERROR, LOOK AT i
                XImage imgFrame = XImage.FromGdiPlusImage(img);

3)

        public static MemoryStream ByteArrayToMemoryStream(byte[] bytestream)
        {

            MemoryStream stream = new MemoryStream(bytestream);
            //stream.Write(bytestream, 0, bytestream.Length); 

            return stream;
        }

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接