PIKApp/plug-ins/script-fu/scripts/script-fu-set-cmap.scm

66 lines
2.2 KiB
Scheme
Raw Normal View History

2023-09-26 00:35:21 +02:00
; Set Colormap v1.1 September 29, 2004
; by Kevin Cozens <kcozens@interlog.com>
;
; Change the colormap of an image to the colors in a specified palette.
; Included is script-fu-make-cmap-array (available for use in scripts) which
; returns a GBytes containing the colors from a specified palette.
; This array can be used as the cmap argument for pika-image-set-colormap.
; PIKA - Photo and Image Kooker Application
; 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/>.
(define (script-fu-make-cmap-array palette)
(let* (
(num-colors (car (pika-palette-get-color-count palette)))
; cons-array is not Scheme standard
; but was in SIOD and is in script-fu-compat.init
(cmap (cons-array (* num-colors 3) 'byte))
(color 0)
(i 0)
)
(while (< i num-colors)
(set! color (car (pika-palette-entry-get-color palette i)))
(aset cmap (* i 3) (car color))
(aset cmap (+ (* i 3) 1) (cadr color))
(aset cmap (+ (* i 3) 2) (caddr color))
(set! i (+ i 1))
)
cmap
)
)
(define (script-fu-set-cmap img drawable palette)
(pika-image-set-colormap img
(script-fu-make-cmap-array palette))
(pika-displays-flush)
)
(script-fu-register "script-fu-set-cmap"
_"Se_t Colormap..."
_"Change the colormap of an image to the colors in a specified palette."
"Kevin Cozens <kcozens@interlog.com>"
"Kevin Cozens"
"September 29, 2004"
"INDEXED*"
SF-IMAGE "Image" 0
SF-DRAWABLE "Drawable" 0
SF-PALETTE _"Palette" "Default"
)
(script-fu-menu-register "script-fu-set-cmap" "<Image>/Colors/Map/[Colormap]")