Rss & SiteMap

Foxtable(狐表) http://www.foxtable.com

新一代数据库软件,完美融合Access、Foxpro、Excel、vb.net之优势,人人都能掌握的快速软件开发工具!
共12 条记录, 每页显示 10 条, 页签: [1] [2]
[浏览完整版]

标题:PDF转图片无效

1楼
keli0917 发表于:2024/7/28 20:37:00
http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&ID=77213&skin=0这个网址的

ConvertPDF2Image("d:\test.pdf", "d:\test", "test", 1, 5, ImageFormat.Jpeg, Definition.One)


使用这个方法PDF转图片,我这个PDF文档无法转换是怎么回事?有些PDF是可以的。
 


[此贴子已经被作者于2024/7/28 21:35:45编辑过]
2楼
有点蓝 发表于:2024/7/28 20:59:00
这种只能说是组件自己的兼容性问题。上网找找看看有没有新版的

或者试试其它组件,比如:

http://www.foxtable.com/bbs/dispbbs.asp?BoardID=2&ID=138154

http://www.foxtable.com/bbs/dispbbs.asp?boardid=2&id=151835
[此贴子已经被作者于2024/7/28 20:59:44编辑过]
3楼
keli0917 发表于:2024/7/28 21:52:00
好。那既然转换图片行不通。那么,专业报表,能将PDF格式的附件,加入打印吗
4楼
keli0917 发表于:2024/7/28 21:54:00
Dim doc As New PrintDoc '定义一个报表
Dim
 rt As New prt.RenderTable() '定义一个表格对象
Dim
 rx As New prt.RenderText '定义一个文本对象
Dim
 CurRow As Row = Tables("员工").Current
'加入标题

rx.text = 
"员工资料卡"
rx.Style.FontBold = 
True '字体加粗
rx.Style.FontSize = 
16 '大体大小为16磅
rx.Style.TextAlignHorz = prt.AlignHorzEnum.Center 
'水平居中排列
rx.Style.Spacing.Bottom = 
3 '和下面的对象(表格)距离3毫米
doc.Body.Children.Add(rx) 
'加入到报表中
'指定行数、列数、列宽、行高

rt.Rows.Count = 
7 '设置总行数
rt.Cols.Count = 
5 '设置总列数
rt.Height = 
80 '设置表格的高度为80毫米
rt.Rows(
6).Height = 40 '设置第7行(显示备注的行)的高度为40毫米,剩余高度被平均分排到其他行
rt.Cols(
0).Width = 24 '设置前四列的宽度,剩余的宽度被分配给5列(显示图片的那列)
rt.Cols(
1).Width = 35
rt.Cols(
2).Width = 24
rt.Cols(
3).Width = 40
'设置合并单元格

rt.Cells(
0,4).SpanRows = 6 '第1行第5个单元格向下合并6行(用于显示照片)
rt.Cells(
4,1).SpanCols = 3 '第5行第2个单元格向右合并3列(用于显示地址)
rt.Cells(
6,0).SpanCols = 5 '第7行第1个单元格向右合并5列(用于显示备注)
'设置表格样式

rt.CellStyle.Spacing.All = 
1 '单元格内容缩进1毫米
rt.Style.GridLines.All = New prt.Linedef 
'设置网格线
rt.Style.TextAlignVert = prt.AlignVertEnum.Center 
'内容垂直居中
rt.Rows(
6).Style.TextAlignVert = prt.AlignVertEnum.Top '唯独第7行是备注,内容靠上对齐
'下面很简单,指定每一个单元格的内容

rt.Cells(
0,0).Text= "姓名"
rt.Cells(
0,1).Text = CurRow("姓名")
rt.Cells(
0,2).Text= "出生日期"
rt.Cells(
0,3).Text = CurRow("出生日期")
rt.Cells(
1,0).Text= "部门"
rt.Cells(
1,1).Text = CurRow("部门")
rt.Cells(
1,2).Text= "雇佣日期"
rt.Cells(
1,3).Text = CurRow("雇佣日期")
rt.Cells(
2,0).Text= "性别"
rt.Cells(
2,1).Text = CurRow("性别")
rt.Cells(
2,2).Text= "职务"
rt.Cells(
2,3).Text = CurRow("职务")
rt.Cells(
3,0).Text= "城市"
rt.Cells(
3,1).Text = CurRow("城市")
rt.Cells(
3,2).Text= "邮政编码"
rt.Cells(
3,3).Text = CurRow("邮政编码")
rt.Cells(
4,0).Text= "地址"
rt.Cells(
4,1).Text = CurRow("地址")
rt.Cells(
5,0).Text= "家庭电话"
rt.Cells(
5,1).Text = CurRow("家庭电话")
rt.Cells(
5,2).Text= "办公电话"
rt.Cells(
5,3).Text = CurRow("办公电话")
rt.Cells(
6,0).Text = CurRow("备注")


rt.Cells(
0,4).Image = GetImage(CurRow("照片"))
doc.Body.Children.Add(rt) 
'将表格对象加入到报表中
Doc.Preview() 
'预览报表


这里的照片,如果是一个PDF文件,可以吗?
5楼
有点蓝 发表于:2024/7/28 21:56:00
这个没有办法的。只能先导出为图片再添加到专业报表使用
6楼
keli0917 发表于:2024/7/29 14:02:00
https://www.cnblogs.com/ywtk/p/3429377.html
这个引用Acrpbat.DLL转换图片的方法,能在FOXTABLE中使用吗?
本机已经安装Adobe Acrobat ,并正常使用。

1.引用Adobe Acrobat安装目录下的: Acrobat.dll 
2.将C#代码,转换成VB.NET。在FOXTABLE的全局代码里写

Public Shared Sub ConvertPDF2Image(ByVal pdfInputPath As String, ByVal imageOutputPath As String, ByVal imageName As String, ByVal startPageNum As Integer, ByVal endPageNum As Integer, ByVal imageFormat As ImageFormat, ByVal resolution As Double)
    Dim pdfDoc As Acrobat.CAcroPDDoc = Nothing
    Dim pdfPage As Acrobat.CAcroPDPage = Nothing
    Dim pdfRect As Acrobat.CAcroRect = Nothing
    Dim pdfPoint As Acrobat.CAcroPoint = Nothing
    pdfDoc = CType(Microsoft.VisualBasic.Interaction.CreateObject("AcroExch.PDDoc", ""), Acrobat.CAcroPDDoc)

    If Not pdfDoc.Open(pdfInputPath) Then
        Throw New FileNotFoundException()
    End If

    If Not Directory.Exists(imageOutputPath) Then
        Directory.CreateDirectory(imageOutputPath)
    End If

    If startPageNum <= 0 Then
        startPageNum = 1
    End If

    If endPageNum > pdfDoc.GetNumPages() OrElse endPageNum <= 0 Then
        endPageNum = pdfDoc.GetNumPages()
    End If

    If startPageNum > endPageNum Then
        Dim tempPageNum As Integer = startPageNum
        startPageNum = endPageNum
        endPageNum = startPageNum
    End If

    If imageFormat Is Nothing Then
        imageFormat = ImageFormat.Jpeg
    End If

    If resolution <= 0 Then
        resolution = 1
    End If

    For i As Integer = startPageNum To endPageNum
        pdfPage = CType(pdfDoc.AcquirePage(i - 1), Acrobat.CAcroPDPage)
        pdfPoint = CType(pdfPage.GetSize(), Acrobat.CAcroPoint)
        pdfRect = CType(Microsoft.VisualBasic.Interaction.CreateObject("AcroExch.Rect", ""), Acrobat.CAcroRect)
        Dim imgWidth As Integer = CInt((CDbl(pdfPoint.x) * resolution))
        Dim imgHeight As Integer = CInt((CDbl(pdfPoint.y) * resolution))
        pdfRect.Left = 0
        pdfRect.right = CShort(imgWidth)
        pdfRect.Top = 0
        pdfRect.bottom = CShort(imgHeight)
        pdfPage.CopyToClipboard(pdfRect, 0, 0, CShort((100 * resolution)))
        Dim clipboardData As IDataObject = Clipboard.GetDataObject()

        If clipboardData.GetDataPresent(DataFormats.Bitmap) Then
            Dim pdfBitmap As Bitmap = CType(clipboardData.GetData(DataFormats.Bitmap), Bitmap)
            pdfBitmap.Save(Path.Combine(imageOutputPath, imageName) & ".jpg", imageFormat)
            pdfBitmap.Dispose()
        End If
    Next

    pdfDoc.Close()
    Marshal.ReleaseComObject(pdfPage)
    Marshal.ReleaseComObject(pdfRect)
    Marshal.ReleaseComObject(pdfDoc)
    Marshal.ReleaseComObject(pdfPoint)
End Sub

到全局代码这步点确定提示:

编译错误:无法加载引用的库”C:\foxtable\Normal\Acrobat.dl”.试图加载格式
不正确的程序。



[此贴子已经被作者于2024/7/29 14:03:07编辑过]
7楼
keli0917 发表于:2024/7/29 14:04:00
我已经把Acrobat.dl复制到C:\foxtable\Normal\Acrobat.dl
8楼
keli0917 发表于:2024/7/29 14:10:00
是不是,Microsoft.CSharp.dll和Microsoft.VisualBasic.dll也要添加引用?
9楼
有点蓝 发表于:2024/7/29 14:15:00
Acrobat.dll是com组件,不能直接引用的

使用vs新建一个项目,在vs里引用Acrobat.dll,然后编译,会生成一个【Interop.】开头的dll,把这个dll和其它dll一起复制到foxtable的安装目录,然后添加【Interop.】开头的dll的引用
10楼
keli0917 发表于:2024/7/29 19:53:00
https://www.cnblogs.com/ywtk/p/3291034.html

利用免费的GhostScript 把PDF 转成图片


Public  Function PDFToImg(ByVal pdfFile As String, ByVal imgPath As String) As Integer
    Dim doc As PDFFile = PDFFile.Open(pdfFile)
    Dim pageCount As Integer = doc.PageCount
    Dim pdfFileName As String = Path.GetFileName(pdfFile)
    Dim imgFile As String = Path.Combine(imgPath, "page")
    If pageCount = 0 Then Return 0

    If pageCount = 1 Then
        imgFile += ".jpg"

        If File.Exists(imgFile) Then
            File.Delete(imgFile)
        End If
    Else

        For i As Integer = 0 To pageCount - 1
            Dim _imgFile As String = imgFile & (i).ToString() & ".jpg"

            If File.Exists(_imgFile) Then
                File.Delete(_imgFile)
            End If
        Next

        imgFile += "%d.jpg"
    End If

    Dim prc As Process = New Process()
    prc.StartInfo.UseShellExecute = False
    prc.StartInfo.CreateNoWindow = True
    prc.EnableRaisingEvents = True
    prc.Exited += New EventHandler(prc_Exited)
    prc.StartInfo.Arguments = "-dSAFER -dBATCH -dNOPAUSE -r150 -sDEVICE=jpeg -dGraphicsAlphaBits=4" & " -sOutputFile=" & imgFile & "  " & pdfFile
    prc.StartInfo.FileName = "C:\Program Files\gs\gs9.06\bin\gswin32.exe"
    prc.Start()
    Return pageCount
End Function


上面这个代码修改一下能在FOXTABLE中使用吗?可以的话帮忙修改一下咯。
我已经安装并在WINDOW的命令行下调试成功。
共12 条记录, 每页显示 10 条, 页签: [1] [2]

Copyright © 2000 - 2018 foxtable.com Tel: 4000-810-820 粤ICP备11091905号

Powered By Dvbbs Version 8.3.0
Processed in .05469 s, 2 queries.