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-2021   http://manualinux.eu



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 - (10.2.0) o Clang - (11.0.2)
* CMake - (3.19.3)
* Ninja - (1.10.2)
* Intltool - (0.51.0)
* Gettext - (0.21)
* Pkg-config - (0.29.2)

Librerías de Desarrollo

* Xorg - (7.7 / xorg-server 1.20.10)
   LibX11 - (1.7.0)
   LibXext - (1.3.4)
* Aspell - (0.60.8)
* Boost - (1.75.0)
* Cairo - (1.16.0)
* Double-conversion - (3.1.5)
* Fontconfig - (2.12.6)
* Freetype2 - (2.8)
* GC - (8.0.4)
* GDL - (3.34.0)
* Glibmm - (2.68.0)
* GSL - (2.6)
* GTKMM - (3.24.3)
* GTKSpell - (3.0.9)
* Jemalloc - (5.2.1)
* Libcdr - (0.1.6)
* Libjpeg - (9d)
* Liblcms - (2.11)
* LibMagick++ (ImageMagick) - (6.9.11-58)
* Libpng - (1.6.37)
* Libpotrace - (1.16)
* Librevenge - (0.0.4)
* Libsoup - (2.72.0)
* Libvisio - (0.1.7)
* Libwpg - (0.3.3)
* Pango - (1.42.4)
* Poppler - (21.01.0)
* Zlib - (1.2.11)

Módulos de Perl

* XML::Parser - (2.46)

Módulos de Python

* Lxml - (4.6.2)



Descarga

inkscape-1.0.2.tar.xz

Firma Digital  Clave pública PGP

inkscape-1.0.2.tar.xz.asc

Verificar la firma digital del paquete

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

Optimizaciones

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

Donde pone znver2 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
VIA
IDT

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=$(getconf _NPROCESSORS_ONLN)'
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+=' -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
New Pass Manager
$ export {C,CXX}FLAGS+=' -fexperimental-new-pass-manager'
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+=" -lomp"
LTO
$ export AR=llvm-ar RANLIB=llvm-ranlib NM=llvm-nm
$ export {C,CXX}FLAGS+=' -flto'
ThinLTO
$ export AR=llvm-ar RANLIB=llvm-ranlib NM=llvm-nm
$ 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.
PGO
1) Fase inicial de compilación e instalación del paquete.
$ export {C,CXX}FLAGS+=' -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"

Establecer el RPATH correspondiente si utilizamos una versión de GCC que no es la principal del sistema
$ export LDFLAGS+=" -Wl,-rpath,/opt/gcc10/lib64 -lstdc++ -lgomp"
Sustituir /opt/gcc10/lib64 por la ruta de instalación de la versión de GCC alternativa que se vaya a utilizar en el proceso de compilación de este paquete. El parámetro -lgomp se añade para poder enlazar correctamente los binarios, si los compilamos con soporte de OpenMP. Si compilamos el paquete con Clang, omitiremos este parámetro.

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-new-pass-manager -Wl,--lto-aa-pipeline=globals-aa -Wl,--lto-newpm-passes=pgo-memop-opt'
Optimizaciones complementarias LTO de LLD
$ export LDFLAGS+=" -Wl,--lto-partitions=$(getconf _NPROCESSORS_ONLN)"
Optimizaciones complementarias ThinLTO de LLD
$ export LDFLAGS+=" -Wl,--thinlto-jobs=$(getconf _NPROCESSORS_ONLN)"

Establecer la variable de entorno de uso de compilador para Clang
$ export CC=clang CXX=clang++
Si utilizamos Clang con Ccache, establecemos la variable de entorno correspondiente de uso de compilador.
$ export CC="ccache clang" CXX="ccache clang++"

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

$ tar Jxvf inkscape-1.0.2.tar.xz
$ cd inkscape-1.0.2
$ mkdir build; cd build
$ export PKG_CONFIG_PATH=/opt/imagemagick-6/lib64/pkgconfig:$PKG_CONFIG_PATH
$ cmake -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.

-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.

-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.

-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

Parámetros de compilación opcionales  

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

-j$(getconf _NPROCESSORS_ONLN) : 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 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 gl gu he hi hr hu id is it ja km kn ko kok kok@latin \
ks@aran ks@deva 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 3 3100 4-Core Processor
MHz 3593.246
RAM 8 GB
Sistema de archivos XFS
Versión del Kernel 5.10.8-ck1 SMP PREEMPT x86_64
Modo de frecuencia de la CPU performance
Versión de Glibc 2.32
Enlazador dinámico LLD 11.0.1
Compilador Clang 11.0.1 + Ccache 4.1
Parámetros de optimización -03 -march=znver2 -mtune=znver2 -fexperimental-new-pass-manager -mllvm -polly -mllvm -polly-vectorizer=stripmine -mllvm polly-parallel -mllvm -polly-omp-backend=LLVM -fopenmp=libomp -fopenmp-version=50 -flto=thin -fprofile-use=/var/pgo/inkscape -Wl,--lto-new-pass-manager -Wl,--lto-aa-pipeline=globals-aa -Wl,--lto-newpm-passes=pgo-memop-opt
Parámetros de compilación V=1 -j8
Ocupación de espacio en disco del proceso de compilación 536,7 MB
Tiempo de compilación 5' 36"
Archivos instalados 2.423
Mostrar/Ocultar la lista de archivos instalados
Ocupación de espacio en disco 53,9 MB

Consumo inicial de CPU y RAM de Inkscape

Consumo inicial de CPU y RAM de Inkscape
Programa
CPU RAM
inkscape 0 % 240,4 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 "make 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.0.2-scripts.tar.gz

$ su
# tar zxvf inkscape-1.0.2-scripts.tar.gz
# cd inkscape-1.0.2-scripts
# ./Desinstalar_inkscape-1.0.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.0.2-scripts.tar.gz
# cd inkscape-1.0.2-scripts
# ./Respaldar_inkscape-1.0.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.0.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 18-01-2021

Editores Gráficos - Inkscape

Editores Gráficos - HeliosPaintEditores Gráficos - mtPaint