Blame Scripts/Bash/Functions/Render/render_doIdentityImageSyslinux.sh

4c79b5
#!/bin/bash
4c79b5
#
4c79b5
# render_doIdentityImageSyslinux.sh -- This function provides
4c79b5
# post-rendering action used to produce syslinux images.
4c79b5
#
4c79b5
# Copyright (C) 2009-2010 Alain Reguera Delgado
4c79b5
# 
4c79b5
# This program is free software; you can redistribute it and/or modify
4c79b5
# it under the terms of the GNU General Public License as published by
4c79b5
# the Free Software Foundation; either version 2 of the License, or
4c79b5
# (at your option) any later version.
4c79b5
# 
4c79b5
# This program is distributed in the hope that it will be useful, but
4c79b5
# WITHOUT ANY WARRANTY; without even the implied warranty of
4c79b5
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
4c79b5
# General Public License for more details.
4c79b5
#
4c79b5
# You should have received a copy of the GNU General Public License
4c79b5
# along with this program; if not, write to the Free Software
4c79b5
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
4c79b5
# USA.
4c79b5
# 
4c79b5
# ----------------------------------------------------------------------
4c79b5
# $Id: render_doIdentityImageSyslinux.sh 71 2010-09-18 05:41:11Z al $
4c79b5
# ----------------------------------------------------------------------
4c79b5
4c79b5
function render_doIdentityImageSyslinux {
4c79b5
4c79b5
    local FILE=$1
f16762
    local ACTION="$2"
f16762
    local OPTIONS=''
f16762
f16762
    # Define 16 colors images default file name prefix.
f16762
    local PREFIX='-16c'
f16762
f16762
    # Define options using those passed to actions from pre-rendering
f16762
    # configuration script. These options are applied to pnmremap when
f16762
    # doing color reduction, so any option available for pnmremap
f16762
    # command can be passed to renderSyslinux functionality.
379ebf
    OPTIONS=$(echo -n "$ACTION" | cut -d: -f2-)
f16762
f16762
    # Check options passed to action. This is required in order to
f16762
    # aviod using options used already in this script. For example
f16762
    # -verbose and -mapfile options.
f16762
    for OPTION in $OPTIONS;do
f16762
        # Remove anything after equal sign inside option.
f16762
        OPTION=$(echo $OPTION | cut -d'=' -f1)
f16762
        if [[ "$OPTION" =~ "-(mapfile|verbose)" ]];then
f16762
            cli_printMessage "`eval_gettext "The \\\$OPTION option is already used."`"
f16762
            cli_printMessage "$(caller)" "AsToKnowMoreLine"
f16762
        fi
f16762
    done
4c79b5
379ebf
    # Re-define 16 colors images default file name prefix using
379ebf
    # options as reference. This is useful to differenciate final
379ebf
    # files produced using Floyd-Steinberg dithering and final files
379ebf
    # which are not.
379ebf
    if [[ "$OPTIONS" =~ '-floyd' ]];then
379ebf
        PREFIX="${PREFIX}-floyd"
379ebf
    fi
379ebf
379ebf
    # Define absolute location to motif's palette of colors.
f16762
    local PALETTES=/home/centos/artwork/trunk/Identity/Themes/Motifs/$(cli_getThemeName)/Colors
4c79b5
   
4c79b5
    # Define the Netpbm color palette used when reducing colors. This
4c79b5
    # palette should be 16 colors based. For more information on this
4c79b5
    # see the isolinux documentation.
4c79b5
    local PALETTE_PPM=$PALETTES/syslinux.ppm
4c79b5
4c79b5
    # Define hexadecimal color information used by ppmtolss16.  Color
4c79b5
    # information and order used on PALETTE_HEX and PALETTE_PPM should
4c79b5
    # match exactly.
4c79b5
    local PALETTE_HEX=$PALETTES/syslinux.hex
4c79b5
4c79b5
    # Check syslinux's palettes existence:  If there is no palette
4c79b5
    # assume that this is the first time you are rendering syslinux
4c79b5
    # images. If that is the case the script will provide you with the
4c79b5
    # PNG format which should be used as base to produce (using GIMP)
4c79b5
    # the .gpl palette.  The .gpl palette information is used to
4c79b5
    # produced (using GIMP) the colormap (.ppm) which is used to
4c79b5
    # automate the syslinux's 16 colors image (syslinux-splash.png)
4c79b5
    # rendering.  If there is no palette available, do not apply color
4c79b5
    # reduction, show a message, and continue.
e4d34a
    cli_checkFiles $PALETTE_PPM
e4d34a
    cli_checkFiles $PALETTE_HEX
4c79b5
4c79b5
    # Create Netpbm superformat (PNM). PNM file is created from the
4c79b5
    # PNG image rendered previously. PNM is a common point for image
4c79b5
    # manipulation using Netpbm tools.
4c79b5
    cli_printMessage "$FILE.pnm" "AsSavedAsLine"
4c79b5
        pngtopnm -verbose \
4c79b5
        < $FILE.png \
4c79b5
        2>$FILE.log > $FILE.pnm
4c79b5
   
4c79b5
    # Reduce colors. Here we use the Netpbm color $PALETTE_PPM to
4c79b5
    # enforce the color position in the image index and the
4c79b5
    # Floyd-Steinberg dithering in order to improve color reduction.
f16762
    cli_printMessage "$FILE${PREFIX}.pnm" "AsSavedAsLine"
379ebf
    pnmremap -verbose -mapfile=$PALETTE_PPM $OPTIONS \
4c79b5
        < $FILE.pnm \
f16762
        2>>$FILE.log > $FILE${PREFIX}.pnm
f16762
4c79b5
    # Create LSS16 image. As specified in isolinux documentation the
4c79b5
    # background color should be indexed on position 0 and forground
4c79b5
    # in position 7 (see /usr/share/doc/syslinux-X.XX/isolinux.doc).
4c79b5
    # This order of colors is specified in $PALETTE_PPM and redefined
4c79b5
    # here again for the LSS16 image format. Both $PALETTE_PPM and
4c79b5
    # LSS16 color map redefinition ($PALETTE_HEX) should have the same
4c79b5
    # colors and index order. PALETTE_HEX should return just one line
4c79b5
    # with the color information as described in isolinux
4c79b5
    # documentation (i.e #RRGGBB=0 #RRGGBB=1 ... [all values in the
4c79b5
    # same line]).
f16762
    cli_printMessage "$FILE${PREFIX}.lss" "AsSavedAsLine"
4c79b5
    PALETTE_HEX=$(cat $PALETTE_HEX | tr "\n" ' ' | tr -s ' ')
4c79b5
    ppmtolss16 $PALETTE_HEX \
f16762
        < $FILE${PREFIX}.pnm \
4c79b5
        2>>$FILE.log \
f16762
        > $FILE${PREFIX}.lss
4c79b5
     
4c79b5
    # Create the PPM image indexed to 16 colors. Also the colormap
4c79b5
    # used in the LSS16 image is saved on $FILE.log; this is useful to
4c79b5
    # verify the correct order of colors in the image index.
f16762
    cli_printMessage "$FILE${PREFIX}.ppm" "AsSavedAsLine"
f16762
    lss16toppm -map < $FILE${PREFIX}.lss \
4c79b5
       2>>$FILE.log \
f16762
       > $FILE${PREFIX}.ppm
4c79b5
      
4c79b5
    # Create the 16 colors PNG image.
f16762
    cli_printMessage "$FILE${PREFIX}.png" "AsSavedAsLine"
4c79b5
    pnmtopng -verbose -palette=$PALETTE_PPM \
f16762
       < $FILE${PREFIX}.pnm \
4c79b5
       2>>$FILE.log \
f16762
       > $FILE${PREFIX}.png
4c79b5
   
4c79b5
}