; selection-rounded-rectangle.scm -*-scheme-*-

; GIMP - The GNU Image Manipulation Program
; Copyright (C) 1995 Spencer Kimball and Peter Mattis
;
; 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 3 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.
;
; You should have received a copy of the GNU General Public License
; along with this program.  If not, see <https://www.gnu.org/licenses/>.

; CHANGE-LOG:
; 1.00 - initial release
; 1.01 - some code cleanup, no real changes
; 1.02 - made script undoable

; 2.00 - ALAN's Branch.  changed name, menu, location, and description
; 2.01 - fixed to work if there was no current selection.
; 2.02 - changed scale to percentages, usability tweaking.
; 2.10 - added concave round edges, updated description.
; 2.11 - tweeked description, changed comments, relinquished any rights.

; Copyright (C) 1997, 1998, Sven Neumann
; Copyright (C) 2004, Alan Horkan.
; Alan Horkan relinquishes all rights to his changes,
; full ownership of this script belongs to Sven Neumann.

(define (script-fu-selection-rounded-rectangle image drawable radius concave)
  (gimp-image-undo-group-start image)

  (if (= (car (gimp-selection-is-empty image)) TRUE) (gimp-selection-all image))
  (let* (
        (radius (/ radius 100)) ; convert from percentages
        (radius (min radius 1.0))
        (radius (max radius 0.0))
        (select-bounds (gimp-selection-bounds image))
        (has-selection (car select-bounds))
        (select-x1 (cadr select-bounds))
        (select-y1 (caddr select-bounds))
        (select-x2 (cadr (cddr select-bounds)))
        (select-y2 (caddr (cddr select-bounds)))
        (select-width (- select-x2 select-x1))
        (select-height (- select-y2 select-y1))
        (cut-radius 0)
        (ellipse-radius 0)
        )

    (gimp-context-push)
    (gimp-context-set-defaults)

    ;; select to the full bounds of the selection,
    ;; fills in irregular shapes or holes.
    (gimp-image-select-rectangle image CHANNEL-OP-ADD
              select-x1 select-y1 select-width select-height)

    (if (> select-width select-height)
      (set! cut-radius (trunc (+ 1 (* radius (/ select-height 2)))))
      (set! cut-radius (trunc (+ 1 (* radius (/ select-width 2)))))
    )
    (set! ellipse-radius (* cut-radius 2))

    (gimp-context-set-antialias TRUE)
    ;; cut away rounded (concave) corners
    ; top right
    (gimp-image-select-ellipse image CHANNEL-OP-SUBTRACT
                               (- select-x1 cut-radius)
                               (- select-y1 cut-radius)
                               (* cut-radius 2)
                               (* cut-radius 2))
    ; lower left
    (gimp-image-select-ellipse image CHANNEL-OP-SUBTRACT
                               (- select-x1 cut-radius)
                               (- select-y2 cut-radius)
                               (* cut-radius 2)
                               (* cut-radius 2))
    ; top right
    (gimp-image-select-ellipse image CHANNEL-OP-SUBTRACT
                               (- select-x2 cut-radius)
                               (- select-y1 cut-radius)
                               (* cut-radius 2)
                               (* cut-radius 2))
    ; bottom left
    (gimp-image-select-ellipse image CHANNEL-OP-SUBTRACT
                               (- select-x2 cut-radius)
                               (- select-y2 cut-radius)
                               (* cut-radius 2)
                               (* cut-radius 2))

    ;; add in rounded (convex) corners
    (if (= concave FALSE)
      (begin
        (gimp-image-select-ellipse image
                                   CHANNEL-OP-ADD
                                   select-x1
                                   select-y1
                                   ellipse-radius
                                   ellipse-radius)
        (gimp-image-select-ellipse image
                                   CHANNEL-OP-ADD
                                   select-x1
                                   (- select-y2 ellipse-radius)
                                   ellipse-radius
                                   ellipse-radius)
        (gimp-image-select-ellipse image
                                   CHANNEL-OP-ADD
                                   (- select-x2 ellipse-radius)
                                   select-y1
                                   ellipse-radius
                                   ellipse-radius)
        (gimp-image-select-ellipse image
                                   CHANNEL-OP-ADD
                                   (- select-x2 ellipse-radius)
                                   (- select-y2 ellipse-radius)
                                   ellipse-radius
                                   ellipse-radius)
      )
    )

    (gimp-image-undo-group-end image)
    (gimp-displays-flush)
    (gimp-context-pop)
  )
)


(define (script-fu-selection-round image drawable radius)
  (script-fu-selection-rounded-rectangle image drawable (* radius 100) FALSE)
)


(script-fu-register "script-fu-selection-rounded-rectangle"
  _"Rounded R_ectangle..."
  _"Round the corners of the current selection"
  "Alan Horkan, Sven Neumann" ; authors
  "Sven Neumann"              ; copyright
  "2004/06/07"
  "*"
  SF-IMAGE       "Image"      0
  SF-DRAWABLE    "Drawable"   0
  SF-ADJUSTMENT _"R_adius (%)" '(50 0 100 1 10 0 0)
  SF-TOGGLE     _"Co_ncave"    FALSE
)

(script-fu-register "script-fu-selection-round"
  ""
  "This procedure is deprecated! Use 'script-fu-selection-rounded-rectangle' instead."
  "Sven Neumann"              ; authors
  "Sven Neumann"              ; copyright
  "1998/02/06"
  "*"
  SF-IMAGE       "Image"      0
  SF-DRAWABLE    "Drawable"   0
  SF-ADJUSTMENT  "Relative radius" '(1 0 128 0.1 1 1 1)
)

(script-fu-menu-register "script-fu-selection-rounded-rectangle"
                         "<Image>/Select/Modify")