田草博客

互联网田草博客


网友交流QQ群:11740834 需注明申请加入原因

微信 公众号:ByCAD

邮箱:tiancao1001x126.com
ByCAD,微信公众号
首页 | 普通 | 电脑 | AutoCAD | VB/VB.NET | FLash | 结构 | 建筑 | 电影 | BIM | 规范 | 软件 | ID
-随机-|-分布-
-博客论坛-|-﨣﨤﨧﨨-
-网站导航-|-规范下载-
-BelovedFLash欣赏-

用户登陆
用户:
密码:
 

站点日历
73 2024 - 12 48
1234567
891011121314
15161718192021
22232425262728
293031


站点统计

最新评论



请教 ,能通过.net 将剪切板中的BMP图像直接以OLE方式插入CAD吗 MaxtoCode Professional 3.03(含破解补丁)
未知 iTextSharp导出pdf中的图片   [ 日期:2016-10-10 ]   [ 来自:本站原创 ]  HTML
iTextSharp导出pdf中的图片
Imports System.IO
Imports iTextSharp.text
Imports iTextSharp.text.pdf
Public Class Form1
    Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
        Dim pdf As New PdfReader("C:/1.pdf")
        Dim N As Int16
        Try
            Dim numberOfPages As Integer = pdf.NumberOfPages
            Dim pageNumber As Integer = 1
            While pageNumber <= numberOfPages
                Dim pg As PdfDictionary = pdf.GetPageN(pageNumber)
                Dim img As System.Drawing.Image = GetImage(pg, pdf)
                If img IsNot Nothing Then
                    N = N + 1
                    img.Save("C:/" & N & ".bmp", System.Drawing.Imaging.ImageFormat.Bmp)
                End If
                System.Math.Max(System.Threading.Interlocked.Increment(pageNumber), pageNumber - 1)
            End While
        Catch
            Throw
        Finally
            pdf.Close()
        End Try
    End Sub
    Private Shared Function GetImage(ByVal dict As PdfDictionary, ByRef doc As PdfReader) As System.Drawing.Image
        Dim res As PdfDictionary = CType(PdfReader.GetPdfObject(dict.[Get](PdfName.RESOURCES)), PdfDictionary)
        Dim xobj As PdfDictionary = CType(PdfReader.GetPdfObject(res.[Get](PdfName.XOBJECT)), PdfDictionary)
        If xobj IsNot Nothing Then
            Dim width As Integer = 0, height As Integer = 0
            Dim bmp As New Bitmap(2048, 2048)
            Dim g As Graphics = Graphics.FromImage(bmp)
            For Each name As PdfName In xobj.Keys
                Dim obj As PdfObject = xobj.[Get](name)
                If obj.IsIndirect() Then
                    Dim tg As PdfDictionary = CType(PdfReader.GetPdfObject(obj), PdfDictionary)
                    Dim type As PdfName = CType(PdfReader.GetPdfObject(tg.[Get](PdfName.SUBTYPE)), PdfName)
                    If PdfName.IMAGE.Equals(type) Then
                        Dim XrefIndex As Integer = Convert.ToInt32(CType(obj, PRIndirectReference).Number.ToString(System.Globalization.CultureInfo.InvariantCulture))
                        Dim pdfObj As PdfObject = doc.GetPdfObject(XrefIndex)
                        Dim pdfStrem As PdfStream = CType(pdfObj, PdfStream)
                        Dim bytes As Byte() = PdfReader.GetStreamBytesRaw(CType(pdfStrem, PRStream))
                        If bytes Is Nothing Then
                            Continue For
                        End If
                        Using memory As New System.IO.MemoryStream(bytes)
                            Try
                                memory.Position = 0
                                Dim tmp As New Bitmap(System.Drawing.Image.FromStream(memory))
                                width = Math.Max(tmp.Width, width)
                                g.DrawImage(tmp, 0, height)
                                height = height + tmp.Height
                            Catch

                            End Try
                        End Using
                    End If
                End If
            Next
            Dim cloneRect As New RectangleF(0, 0, width, height)
            Dim format As Imaging.PixelFormat = bmp.PixelFormat
            Dim cloneBitmap As Bitmap = bmp.Clone(cloneRect, format)
            bmp.Dispose()
            Return cloneBitmap
        End If
        Return Nothing
    End Function

    Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load

    End Sub
End Class



【iTextSharp导出pdf中的图片.rar】点击下载此文件



暂时没有评论
发表评论 - 不要忘了输入验证码哦!
作者: 用户:  密码:   注册? 验证:  防止恶意留言请输入问题答案:2*8=?  
评论:

禁止表情
禁止UBB
禁止图片
识别链接
识别关键字

字体样式 文字大小 文字颜色
插入粗体文本 插入斜体文本 插入下划线
左对齐 居中对齐 右对齐
插入超级链接 插入邮件地址 插入图像
插入 Flash 插入代码 插入引用
插入列表 插入音频文件 插入视频文件
插入缩进符合
点击下载按钮 下标 上标
水平线 简介分割标记
表  情
 
Tiancao Blog All Rights Reserved 田草博客 版权所有
Copyright ©