GIMP Script-fu

Artifact [6a55a4ed4d]
Login

Artifact [6a55a4ed4d]

Artifact 6a55a4ed4d3a628ff5cef05338d2736037b9c09b:


; This program is free software; you can redistribute it and/or modify
; it under the terms of the GNU General Public License as published by
; the Free Software Foundation; either version 2 of the License, or
; (at your option) any later version.
;
; This program is distributed in the hope that it will be useful,
; but WITHOUT ANY WARRANTY; without even the implied warranty of
; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
; GNU General Public License for more details.

; Crops image to the selection and scales so that max dimension is 1600.
; Adds watermark (either text or file) and saves to specified directory.
;
; "File->Mgwalk Save First..." prompts user for settings.
; "File->Mgwalk Save Next" execute without prompting.

(define (sg-mgwalk-save orig-image 
                        max-dimension
                        output-directory
                        filename-suffix
                        output-type ; JPG, PNG, or XCF
                        watermark-filename ; #f if unused
                        watermark-opacity
                        watermark-x
                        watermark-y
                        )
  (let ((image (car (gimp-image-duplicate orig-image))))
    (gimp-image-undo-disable image)
    (let ((x-offset 0)
          (y-offset 0)
          (width (car (gimp-image-width image)))
          (height (car (gimp-image-height image)))
          (bounds (gimp-selection-bounds image)) )
      (unless (zero? (car bounds))
        (set! x-offset (cadr bounds))
        (set! y-offset (caddr bounds))
        (set! width (- (cadddr bounds) x-offset))
        (set! height (- (car (cddddr bounds)) y-offset)) )
      (gimp-image-crop image width height x-offset y-offset)
      (gimp-selection-none image)
      (let ((aspect (/ height width)))
        (cond
          ((< width height)
            (gimp-image-scale-full image (/ max-dimension aspect) max-dimension INTERPOLATION-LANCZOS))
          ((> width height)
            (gimp-image-scale-full image max-dimension (* max-dimension aspect) INTERPOLATION-LANCZOS) ))))
    (if watermark-filename
      (let ((watermark-layer (catch #f (car (gimp-file-load-layer RUN-NONINTERACTIVE image watermark-filename)))))
        (if watermark-layer
          (begin
            (gimp-image-add-layer image watermark-layer 0)
            (gimp-layer-set-offsets watermark-layer watermark-x watermark-y)
            (gimp-layer-set-opacity watermark-layer watermark-opacity) )
          (gimp-message "Watermark image file not found!") )))
    (let ((layer (case output-type
                   ((0)
                     (car (gimp-image-flatten image)) )
                   ((1)
                     (car (gimp-image-merge-visible-layers image CLIP-TO-IMAGE )) )
                   ((2)
                     (vector-ref (cadr (gimp-image-get-layers image)) 0) ))))

      (if (> (car (gimp-image-width image)) 1600)
        (gimp-image-scale-full image 1600 1600 INTERPOLATION-CUBIC) )
      (let ((raw-filename (car (gimp-image-get-name orig-image))))
        (if (string=? raw-filename "Untitled")
          (gimp-message "File Not Saved!")
          (let* ((basename (unbreakupstr (butlast (strbreakup raw-filename ".")) "."))
                 (filename (string-append output-directory
                                          DIR-SEPARATOR 
                                          basename 
                                          filename-suffix
                                          (case output-type
                                            ((0) ".jpg") 
                                            ((1) ".png")
                                            ((2) ".xcf") ))))
            (gimp-file-save RUN-NONINTERACTIVE image layer filename raw-filename) ))))
    (gimp-image-delete image) ))

(define (script-fu-sg-mgwalk-save image 
                                  max-dimension
                                  output-directory
                                  filename-suffix
                                  output-type
                                  use-watermark
                                  watermark-filename
                                  watermark-opacity
                                  watermark-x
                                  watermark-y
                                  )
  (sg-mgwalk-save image 
                  max-dimension
                  output-directory
                  filename-suffix
                  output-type ; JPG, PNG, or XCF
                  (if (zero? use-watermark)
                    #f
                    watermark-filename )
                  watermark-opacity
                  watermark-x
                  watermark-y
                  )  
  (let ((directory-parasite (list "mgwalk-save-directory" 
                                  3 
                                  output-directory ))
        (watermark-parasite (list "mgwalk-save-watermark"
                                  3
                                  (if (zero? use-watermark)
                                    "ignore"
                                    watermark-filename )))
        (settings-parasite  (list "mgwalk-save-settings"
                                  3
                                  (string-append (number->string max-dimension)
                                                 " "
                                                 filename-suffix
                                                 " "
                                                 (number->string output-type)
                                                 " "
                                                 (number->string use-watermark)
                                                 " "
                                                 (number->string watermark-opacity)
                                                 " "
                                                 (number->string watermark-x)
                                                 " "
                                                 (number->string watermark-y) ))))
    (gimp-parasite-attach directory-parasite)
    (gimp-parasite-attach watermark-parasite)
    (gimp-parasite-attach settings-parasite) )
  (gimp-image-clean-all image)
  )

(define (script-fu-sg-mgwalk-save-next image)
  (let ((output-directory (catch #f (caddar (gimp-parasite-find "mgwalk-save-directory"))))
        (watermark-filename (catch #f (caddar (gimp-parasite-find "mgwalk-save-watermark"))))
        (settings-parasite  (catch #f (caddar (gimp-parasite-find "mgwalk-save-settings")))) )
    (when (and output-directory watermark-filename settings-parasite)
      (let ((settings (strbreakup settings-parasite " ")))
        (let ((max-dimension (string->number (car settings)))
              (filename-suffix (cadr settings))
              (output-type (string->number (caddr settings)))
              (use-watermark (string->number (cadddr settings)))
              (watermark-opacity (string->number (car (cddddr settings))))
              (watermark-x (string->number (cadr (cddddr settings))))
              (watermark-y (string->number (caddr (cddddr settings)))) )
          (sg-mgwalk-save image 
                          max-dimension
                          output-directory
                          filename-suffix
                          output-type ; JPG, PNG, or XCF
                          (if (zero? use-watermark)
                            #f
                            watermark-filename )
                          watermark-opacity
                          watermark-x
                          watermark-y
                          )))))
  (gimp-image-clean-all image)
  )

(script-fu-register "script-fu-sg-mgwalk-save"
 "Mgwalk Save First..."
 "Save image per Mgwalk"
 "Saul Goode"
 "Saul Goode"
 "Sept 2012"
 "*"
 SF-IMAGE    "Image"    0
 SF-ADJUSTMENT "Max dimension" '( 1600 10 10000 1 10 0 1 )
 SF-DIRNAME "Output directory" ""
 SF-TEXT "Filename suffix" "-RESIZED"
 SF-OPTION "Output type" '("JPG" "PNG" "XCF")
 SF-TOGGLE "Add watermark" FALSE
 SF-FILENAME "Watermark file" "watermark.png"
 SF-ADJUSTMENT "Watermark opacity" '( 50 1 100 1 10 0 1 )
 SF-ADJUSTMENT "Watermark location X" '( 20 0 10000 1 10 0 1 )
 SF-ADJUSTMENT "Watermark location Y" '( 20 0 10000 1 10 0 1 )
 )
(script-fu-menu-register "script-fu-sg-mgwalk-save"
 "<Image>/File/Save"
 )
 
(script-fu-register "script-fu-sg-mgwalk-save-next"
 "Mgwalk Save Next"
 "Save Next per Mgwalk"
 "Saul Goode"
 "Saul Goode"
 "Sept 2012"
 "*"
 SF-IMAGE    "Image"    0
 )
(script-fu-menu-register "script-fu-sg-mgwalk-save-next"
 "<Image>/File/Save"
 )