| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- package pdf
- import (
- "bytes"
- "fmt"
- "gbase/glog"
- "github.com/axgle/mahonia" //编码转换
- "os"
- "os/exec"
- "path/filepath"
- )
- // @title XPdfToPng
- // @description 把整个pdf渲染成png
- // @param
- // @return
- func ConvertPdfFileToPng(pdfPath string, subPath, fileName string) error {
- currentDir, _ := os.Getwd()
- xpdfPath := filepath.Join(currentDir, "tool", "pdftopng.exe")
- //println(xpdfPath)
- _, err := os.Stat(xpdfPath)
- if os.IsNotExist(err) {
- fmt.Println("file no exist.")
- return fmt.Errorf("pdftopng.exe not found in ./tools")
- }
- //cmdLine := fmt.Sprintf("cd %s && %s %s %s", subPath,xpdfPath,pdfPath, fileName)
- //println(cmdLine)
- cmdArgs := []string{
- "/C",
- "cd",
- subPath,
- "&&",
- xpdfPath,
- "-f",
- "1",
- "-l",
- "1",
- "-r",
- "250",
- pdfPath,
- fileName,
- }
- c := exec.Command("cmd.exe", cmdArgs...)
- var stdout bytes.Buffer
- var stderr bytes.Buffer
- var enc mahonia.Decoder
- enc = mahonia.NewDecoder("gbk")
- c.Stdout = &stdout
- c.Stderr = &stderr
- err = c.Run()
- if err != nil {
- fmt.Printf("XPdfToPng Error: %s %s\n", err, enc.ConvertString(stderr.String()))
- //go Xlog(logPath, strings.Join(cmdArgs, " "))
- glog.XWarning(fmt.Sprintf("%s,XPdfToPng Error: %s %s\n", pdfPath, err, enc.ConvertString(stderr.String())))
- return fmt.Errorf("%s,XPdfToPng Error: %s %s\n", pdfPath, err, enc.ConvertString(stderr.String()))
- }
- //fmt.Printf("XPdfToPng Result: %s\n", stdout.String())
- return nil
- }
|