Manualinux
http://www.nvu.com http://www.gimp.org InicioPresentaciónActualizacionesManualesDescargasNoticiasAgradecimientoEnlaces

Entornos GráficosAplicaciones

DesarrolloEmuladoresInternetJuegosMultimediaSistema

GráficosSonidoVídeo

Editores Gráficos - HeliosPaintEditores Gráficos - mtPaint

Editores Gráficos - Inkscape




Editores Gráficos - Inkscape




Copyright

Copyright © José Luis Lara Carrascal  2009-2024   http://manualinux.es



Sumario

Introducción
Instalación
Iniciamos Inkscape
Enlaces




Introducción  

Inkscape
 es una escisión del abandonado proyecto Sodipodi, destinado a la edición de gráficos utilizando el formato de gráficos vectoriales, SVG. Su desarrollo y aceptación por parte de los usuarios hace del mismo uno de los proyectos de más éxito dentro del mundo del Open Source. En combinación con El Gimp se convierte en una herramienta indispensable para los diseñadores gráficos y supone una alternativa seria y fiable a los habituales programas comerciales del mundo del diseño gráfico.



Instalación  

Dependencias

Herramientas de Compilación


Entre paréntesis la versión con la que se ha compilado Inkscape para la elaboración de este documento.

* GCC - (13.2.0) o Clang - (18.1.0)
* CMake - (3.28.3)
* Cython - (3.0.9)
* Ninja - (1.11.1)
* Intltool - (0.51.0)
* Gettext - (0.22.5)
* Pkg-config - (0.29.2)
* Ragel - (6.10)

Librerías de Desarrollo

* Xorg - (7.7 / xorg-server 21.1.11)
   LibICE - (1.1.1)
   LibX11 - (1.8.7)
   LibXext - (1.3.6)
* Boost - (1.84.0)
* Cairo - (1.18.0)
* Double-conversion - (3.3.0)
Epoxy - (1.5.10)
* Fontconfig - (2.15.0)
* GC - (8.2.6)
* GDL - (3.40.0)
* GLib - (2.74.7)
* Glibmm - (2.66.6)
* GSL - (2.7.1)
* Gspell - (1.12.2)
* GTK+ - (3.24.41)
* GTKMM - (3.24.8)
* GTKSourceView - (4.8.4)
* HarfBuzz - (8.3.0)
* Jemalloc - (5.3.0)
* Libcdr - (0.1.7)
* Libjpeg-turbo - (3.0.2)
* Liblcms - (2.16)
* LibMagick++ (ImageMagick) - (6.9.13-7)
* Libpng - (1.6.43)
* Libpotrace - (1.16)
* Librevenge - (0.0.5)
* Libsigc++ - (2.12.1)
* Libsoup - (2.74.3)
* Libvisio - (0.1.7)
* Libwpg - (0.3.4)
* Libxml2 - (2.11.7)
Libxslt - (1.1.39)
* Pango - (1.52.1)
* Poppler - (24.03.0)
* Readline - (8.2)
* Zlib - (1.3.1)

Módulos de Perl

* XML::Parser - (2.47)

Módulos de Python

* Lxml - (5.1.0)



Descarga

inkscape-1.3.2.tar.xz

Firma Digital  Clave pública PGP

inkscape-1.3.2.tar.xz.asc

Verificar la firma digital del paquete

$ gpg --import manualinux.asc
$ gpg --verify inkscape-1.3.2.tar.xz.asc inkscape-1.3.2.tar.xz

Optimizaciones

$ export {C,CXX}FLAGS='-O3 -march=znver3 -mtune=znver3'

Donde pone znver3 se indica el procesador respectivo de cada sistema seleccionándolo de la siguiente tabla:
Nota informativa sobre las optimizaciones para GCC
* La opción '-march=' establece el procesador mínimo con el que funcionará el programa compilado, la opción '-mtune=' el procesador específico para el que será optimizado. 

* Los valores separados por comas, son equivalentes, es decir, que lo mismo da poner '-march=k8' que '-march=athlon64'.

* En versiones de GCC 3.2 e inferiores se utiliza la opción '-mcpu=' en lugar de '-mtune='.
Nota informativa sobre las optimizaciones para Clang
* La opción '-mtune=' está soportada a partir de la versión 3.4 de Clang.

* Los valores de color azul no son compatibles con Clang.

* Las filas con el fondo de color amarillo son valores exclusivos de Clang y, por lo tanto, no son aplicables con GCC.
Valores CPU
Genéricos
Intel
AMD

Optimizaciones adicionales

Optimizaciones adicionales
GCC
Graphite
$ export {C,CXX}FLAGS+=' -ftree-loop-linear -floop-strip-mine -floop-block'
IPA
$ export {C,CXX}FLAGS+=' -fipa-pta'
OpenMP
$ export {C,CXX}FLAGS+=' -ftree-parallelize-loops=$(nproc)'
LTO
$ export AR=gcc-ar RANLIB=gcc-ranlib NM=gcc-nm
$ export {C,CXX}FLAGS+=' -fuse-linker-plugin -flto=auto'
En versiones inferiores a GCC 10, sustituir auto por el número de núcleos que tenga nuestro procesador. Si sólo tiene uno, utilizar el parámetro -flto
PGO
1) Fase inicial de compilación e instalación del paquete.
$ export {C,CXX}FLAGS+=' -O2 -g1 -fprofile-generate=/var/pgo/inkscape'
2) Ejecución y testeo del programa.
3) Fase final de compilación e instalación del paquete.
$ export {C,CXX}FLAGS+=' -fprofile-use=/var/pgo/inkscape -Wno-error=coverage-mismatch'
Clang
Polly
$ export {C,CXX}FLAGS+=' -O3 -mllvm -polly -mllvm -polly-vectorizer=stripmine -mllvm -polly-parallel -mllvm -polly-omp-backend=LLVM'
OpenMP
$ export {C,CXX}FLAGS+=' -fopenmp=libomp -fopemp-version=50'
$ export LDFLAGS+=" -L$(llvm-config --libdir) -lomp"
LTO
$ export {C,CXX}FLAGS+=' -flto'
ThinLTO
$ export {C,CXX}FLAGS+=' -flto=thin'
La aplicación de esta optimización es alternativa a la tradicional LTO, a partir de Clang 3.9 y, por lo tanto, no es combinable con la misma.
Unified LTO
LTO >> ThinLTO
$ export {C,CXX}FLAGS+=' -flto funified-lto'
$ export LDFLAGS+=' -Wl,--lto=thin'
ThinLTO >> LTO
$ export {C,CXX}FLAGS+=' -flto=thin -funified-lto'
$ export LDFLAGS+=' -Wl,--lto=full'
La aplicación de esta optimización es aplicable, a partir de Clang 17, y sólo es combinable con LLD.
PGO
1) Fase inicial de compilación e instalación del paquete.
$ export {C,CXX}FLAGS+=' -O2 -g1 -fprofile-generate=/var/pgo/inkscape'
2) Ejecución y testeo del programa.
3) Conversión del perfil de optimización a un formato legible por Clang.
$ PGODIR=/var/pgo/inkscape; llvm-profdata merge $PGODIR/default_*.profraw --output=$PGODIR/default.profdata
4) Fase final de compilación e instalación del paquete.
$ export {C,CXX}FLAGS+=' -fprofile-use=/var/pgo/inkscape'

Parámetros adicionales

Parámetros adicionales de eliminación de avisos en el proceso de compilación
$ export {C,CXX}FLAGS+=' -w'

Establecer la ruta de búsqueda de directorios de librerías en sistemas de 64 bits multiarquitectura
$ export LDFLAGS+=" -L/usr/lib64 -L/usr/local/lib64 -L/opt/gcc13/lib64"
Cada usuario tendrá que establecer la ruta de búsqueda de directorios, en función de la distribución que utilice.

Establecer el uso de enlazador dinámico para Mold
$ export LDFLAGS+=' -fuse-ld=mold'

Establecer el uso de enlazador dinámico para LLD
$ export LDFLAGS+=' -fuse-ld=lld'
Optimizaciones complementarias LTO/ThinLTO/PGO de LLD
$ export LDFLAGS+=' -Wl,--lto-aa-pipeline=globals-aa -Wl,--lto-newpm-passes=pgo-memop-opt'
Optimizaciones complementarias LTO de LLD
$ export LDFLAGS+=" -Wl,--lto-partitions=$(expr $(nproc) / 2)"
Optimizaciones complementarias ThinLTO de LLD
$ export LDFLAGS+=" -Wl,--thinlto-jobs=$(expr $(nproc) / 2)"

Establecer la variable de entorno de uso de compilador para Clang
$ export CC=clang CXX=clang++

Extracción y Configuración  Bloc de Notas Información general sobre el uso de los comandos

$ tar Jxvf inkscape-1.3.2.tar.xz
$ cd inkscape-1.3.2
$ export PKG_CONFIG_PATH=/opt/imagemagick-6/lib64/pkgconfig:$PKG_CONFIG_PATH
$ cmake -S . -B build -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_AR=$(which $AR) \
-DCMAKE_RANLIB=$(which $RANLIB) -DCMAKE_NM=$(which $NM) \
-DBUILD_TESTING=OFF -DWITH_JEMALLOC=ON -DCMAKE_INSTALL_LIBDIR=lib64 -G Ninja ..

Explicación de los comandos

export PKG_CONFIG_PATH=/opt/imagemagick-6/lib64/pkgconfig:$PKG_CONFIG_PATH : Establecemos la correspondiente variable de entorno PKG_CONFIG_PATH, para poder compilar el soporte de ImageMagick 6, cuya instalación se explica en el manual de ImageMagick. Ya que Inkscape no es compatible con la versión 7 de ImageMagick.

Si no tenemos instalada una versión de la serie 6 de ImageMagick, pero sí tenemos instalado GraphicsMagick, el paquete se compilará con el soporte de esta dependencia concreta.

-S . -B build : Establece el directorio del código fuente y crea de forma automática el directorio de compilación.

-DCMAKE_INSTALL_PREFIX=/usr : Instala el programa en el directorio principal, /usr.

-DCMAKE_AR=$(which $AR) -DCMAKE_RANLIB=$(which $RANLIB) -DCMAKE_NM=$(which $NM) : Sincroniza las variables de entorno establecidas en el manual, relativas a los binarios ejecutables intermedios, gcc-ar, gcc-ranlib y gcc-nm, con los parámetros de configuración utilizados por CMake, relativos a los programas ar, ranlib y nm, para poder aplicar correctamente la optimización LTO. Se utiliza el comando which para buscar los ejecutables porque desde hace ya varias versiones, CMake no establece correctamente la ruta al ejecutable en cuestión. Esto no es necesario hacerlo, si compilamos el paquete con Clang.

-DBUILD_TESTING=OFF : Desactiva la compilación de los tests del paquete.

-DWITH_JEMALLOC=ON : Activa el soporte del asignador de memoria, Jemalloc.

-DCMAKE_INSTALL_LIBDIR=lib64 : Instala la librería base de Inkscape en /usr/lib64/inkscape en sistemas de 64 bits multiarquitectura. La ubicación y el nombre de este directorio, puede variar en función de la distribución que cada usuario use.

-G Ninja : Utiliza Ninja en lugar de GNU Make para compilar el paquete (opcional).

Parámetros de configuración opcionales

-DWITH_OPENMP=OFF : Si no tenemos un procesador multinúcleo, añadir esta opción.

Compilación

$ ninja -C build

Parámetros de compilación opcionales  

-v : Muestra más información en el proceso de compilación.

-j$(nproc) : Establece el número de procesos de compilación en paralelo, en función del número de núcleos e hilos que tenga nuestro procesador, tomando como referencia la información mostrada por el sistema con el comando correspondiente. Si nuestro procesador es mononúcleo de un solo hilo, no añadir esta opción.

Instalación como root

$ su -c "ninja -C build install/strip"

Borrar las locales adicionales instaladas con la utilidad BleachBit

$ su -c "bleachbit -c system.localizations"

Borrar las plantillas y tutoriales localizados adicionales instalados

$ su
# for i in ar as be bg bn_BD br brx ca ca@valencia cs da de doi el eo et \
es_MX eu fa fi fr ga gl gu he hi hr hu id is it ja km kn ko kok kok@latin \
ks@aran ks@deva lt lv mai ml mni mni@beng mr nb nl nn or pl pt pt_BR ro ru \
sa sat sat@deva sd sd@deva sk sl sr sr@latin sv ta te tr uk ur vi zh_CN zh_TW ; do
rm -f /usr/share/inkscape/templates/default.$i.svg ;
rm -f /usr/share/inkscape/tutorials/{potrace.$i.png,pixelart-dialog.$i.png,\
tutorial-{advanced,basic,calligraphy,elements,interpolate,shapes,tips,\
tracing-pixelart,tracing}.$i.svg} ;
done

Estadísticas de Compilación e Instalación de Inkscape

Estadísticas de Compilación e Instalación de Inkscape
CPU AMD Ryzen 5 5500
MHz 3593.250 (BoostMax=4457.000)
RAM 32 GB
Sistema de archivos XFS
Versión del Kernel 6.7.9-ml SMP PREEMPT_DYNAMIC x86_64
Modo de frecuencia de la CPU powersave (balance performance)
Planificador de CPU BORE
Versión de Glibc 2.39
Enlazador dinámico LLD 18.1.0
Compilador Clang 18.1.0 + BuildCache 0.28.9
Parámetros de optimización -03 -march=znver3 -mtune=znver3 -mllvm -polly -mllvm -polly-vectorizer=stripmine -mllvm polly-parallel -mllvm -polly-omp-backend=LLVM -fopenmp=libomp -fopenmp-version=50 -flto -funified-lto -fprofile-use=/var/pgo/inkscape -Wl,--lto=thin -Wl,--thinlto-jobs=6 -Wl,--lto-aa-pipeline=globals-aa -Wl,--lto-newpm-passes=pgo-memop-opt
Parámetros de compilación -v -j12
Ocupación de espacio en disco del proceso de compilación 601,0 MB
Tiempo de compilación 6' 22"
Archivos instalados 3.478
Mostrar/Ocultar la lista de archivos instalados
Enlaces simbólicos creados 1
/usr/lib64/inkscape/libinkscape_base.so
Ocupación de espacio en disco 70,8 MB

Consumo inicial de CPU y RAM de Inkscape

Consumo inicial de CPU y RAM de Inkscape
Programa
CPU RAM
inkscape 0 % 672,6 MB
Para medir el consumo de CPU se utiliza el programa top, y para medir el consumo de RAM se utiliza el script de Python, ps_mem.py, creado por Pádraig Brady, que podemos encontrar en este enlace.

Directorio de configuración personal

~/.config/inkscape Es el directorio de configuración personal de Inkscape en nuestro home.

Desinstalación como root

1) MODO TRADICIONAL

En el directorio de compilación ejecutamos el siguiente comando:

$ su -c "ninja uninstall"

2) MODO MANUALINUX

El principal inconveniente del comando anterior es que tenemos que tener el directorio de compilación en nuestro sistema para poder desinstalar el programa. En algunos casos esto supone muchos megas de espacio en disco. Con el paquete de scripts que pongo a continuación logramos evitar el único inconveniente que tiene la compilación de programas, y es el tema de la desinstalación de los mismos sin la necesidad de tener obligatoriamente una copia de las fuentes compiladas.

inkscape-1.3.2-scripts.tar.gz

$ su
# tar zxvf inkscape-1.3.2-scripts.tar.gz
# cd inkscape-1.3.2-scripts
# ./Desinstalar_inkscape-1.3.2

Copia de Seguridad como root

Con este otro script creamos una copia de seguridad de los binarios compilados, recreando la estructura de directorios de los mismos en un directorio de copias de seguridad (copibin) que se crea en el directorio /var. Cuando se haya creado el paquete comprimido de los binarios podemos copiarlo como usuario a nuestro home y borrar el que ha creado el script de respaldo, teniendo en cuenta que si queremos volver a restaurar la copia, tendremos que volver a copiarlo al lugar donde se ha creado.

$ su
# tar zxvf inkscape-1.3.2-scripts.tar.gz
# cd inkscape-1.3.2-scripts
# ./Respaldar_inkscape-1.3.2

Restaurar la Copia de Seguridad como root

Y con este otro script (que se copia de forma automática cuando creamos la copia de respaldo del programa) restauramos la copia de seguridad como root cuando resulte necesario.

$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_inkscape-1.3.2



Iniciamos Inkscape

Basta teclear el comando inkscape en una terminal o en un lanzador para que el editor se inicie,


Captura - Inkscape - 01


Captura - Inkscape - 02


Captura- Inkscape - 03




Enlaces


http://www.inkscape.org >> La web de Inkscape.


Foro Galería Blog


Actualizado el 08-03-2024

Editores Gráficos - Inkscape

Editores Gráficos - HeliosPaintEditores Gráficos - mtPaint