我有一个脚本应该展平,调整大小并导出初始图像。我坚持出口。我正在使用file-png-save。除了第三个参数外,我的参数看起来很好,它应该是一个可绘制的。
对于drawable,我使用的是从gimp-image-flatten得到的扁平层。我得到的答复是我的第三个论点无效。图层不总是作为drawables工作吗?我需要转换吗?
(define (script-fu-panel-export inImg drawable inWidth)
(define filename (car(gimp-image-get-filename inImg)))
(define comHeight (/ inWidth .75))
(define piece (car(cdr(cdr(cdr(cdr(cdr(strbreakup filename "/"))))))))
(define base (car(strbreakup piece ".")))
(define destination (string-append "/home/samjones/Dev/mobinge/lib/images/" base "-" (number->string inWidth) ".png"))
(let* ((duplicateImg (car(gimp-image-duplicate inImg))))
(gimp-image-scale duplicateImg inWidth comHeight)
(let* ((flatLayer (gimp-image-flatten duplicateImg)))
(file-png-save 1 duplicateImg flatLayer destination destination 1 0 0 0 0 0 0)
)
(gimp-display-new duplicateImg)
)
)
(script-fu-register
"script-fu-panel-export"
"Export Panel. . ."
"Creates a flattened image export to a selected size.."
"Sam Jones"
"copyright 2017, Sam Jones"
"December 19, 2017"
""
SF-IMAGE "Image" 0
SF-DRAWABLE "Maybe unused" 0
SF-ADJUSTMENT "Width" '(320 20 1200 10 50 0 SF-SLIDER)
)
(script-fu-menu-register "script-fu-panel-export" "<Image>/Filters")
答案 0 :(得分:1)
环顾那些从脚本中保存的人,我找到了一条有点不同的路线。我替换了这两行:
(let* ((flatLayer (gimp-image-flatten duplicateImg)))
(file-png-save 1 duplicateImg flatLayer destination destination 1 0 0 0 0 0 0))
有了这个:
(gimp-image-flatten duplicateImg)
(file-png-save 1 duplicateImg (car(gimp-image-get-active-drawable duplicateImg))_destination destination 1 0 0 0 0 0 0)
所以我认为gimp-image-flatten可能会返回一个列表,其中图层是第一个元素,而不是返回一个图层。我现在知道gimp-image-get-active返回带有元素的列表。
这很奇怪,但它确实有效。
答案 1 :(得分:0)
您没有访问gimp-image-flatten
结果的所需元素。使用car
进行访问:
(let* ((flatLayer (car (gimp-image-flatten duplicateImg))))
(file-png-save 1 duplicateImg flatLayer destination destination 1 0 0 0 0 0 0)
)