Intrusismos diseñando…

Aunque en realidad ni siquiera son actividades intrusistas, pues me he dedicado a copiar una plantilla que Carmen había utilizado para hacer sus carteles promocionales de las temáticas diferenciadoras de sus Clases de Tango Argentino, que luego he incluido en su página web www.carmendelarosa.com

Ella utiliza unas cuantas apps del móvil y suele quedar «resultón», pero si quieres tenerlas juntas las imágenes o usarlas en una web… acaba siendo más fácil hacerlas con herramientas, digamos, serias, como las que utilizo para diseñar las cubiertas de los libros (Inkscape sobre Linux, en resumen).

Inkscape es un programa que tiene todo lo que yo pueda necesitar en los próximos años. Se le supone capacidad (o pretensión) de emular al poderoso Ilustrator, aunque no tiene ese «flow» que tienen los productos Adobe. Es parco, algo simplón y algo inestable… pero cumple sobradamente su función. De momento, no echo nada en falta, pero quizá es que sé demasiado poco.

De momento, me sirvió para hacer en un par de horas los siguientes cartelitos para Carmen de la Rosa y su web, amén de promociones en Instagram, etc…

Haiku Generator

Hoy una amiga (que durante años ha sido una de las más dadaístas asistentes a los talleres de poesía que coordino) ha publicado en una red social, riéndose de ello como corresponde, que hay en internet un generador de haikus.

Es una cosa tan graciosa o tan patética (y no en un buen sentido) como el generador de ideas para blog del que hablé hace no mucho en este mismo blog.

Algo tremendo está pasando cuando alguien quiere recurrir a una máquina para realizar lo más humano posible, que es expresarse.

¿Son las máquinas las que están tratando de decirnos algo? ¿Está la amenaza de Skynet más cerca de cumplirse de lo que nos creemos?

Unos cuantos haikus generados casi aleatoriamente por esta vía:

Evil october.
A tropical, large sun flip
above the dollar

Nippy summertime
A domestic, grand pig soars
before the giraffe

Tearless christmastide
A gray, grand squirrel frightens
because of the net

Cabe preguntarse si a la palabra poesía, a la palabra arte, a la palabra creación, no habría que añadirles (implícitamente) la palabra sujeto humano, pues no es sólo una cuestión de forma, ni de contenido, sino de riesgo, de intención, de fracaso… las máquinas (y quienes deciden usarlas para generar ideas para un blog, para escribir «haikus» o similar) lo que buscan es el éxito, carente de riesgo y con una intención que no es la de explorar sino la de fabricar.

La escritura creativa (creación como actitud ante la vida, no como eslogan), la poesía, es una fábrica de errores, de insensateces, de locura, de interrogantes en última instancia, y no una máquina de exclamaciones, afirmaciones, verdades, corduras ni, nunca, éxito asegurado.

Towi, alias Frankenstein

Parece mentira, pero la obsolescencia programada no parece ser tan certera como afirman quienes dicen que los PC duran 5 años o las impresoras 2.

Towi es el nombre en clave (hostname) de nuestro querido ordenador de torre que usa Carmen todos los días como equipo de trabajo, completamente funcional.

Este fin de semana pasado hemos empezado a dar por perdidos algunos equipos que no dejan de funcionar, a pesar de que las necesidades de este «mundo moderno», de redes sociales, teléfonos inteligentes y esas cosas, nos hagan sentir que las velocidades de los mismos no son admisibles o son indicio de fallo, cuando sencillamente no queremos quedarnos en la fila de los «pobretones» que navegan despacio.

Esta placa de hace ya más de 10 años sigue funcionando sin problemas. Es un Pentium (de antes de la época de la serie i-3,5,7), con un sólo núcleo, con 4Gb de RAM ocupando las dos ranuritas como se ve en la imagen, en sendas tarjetas de 2Gb.

El disco duro que traía montado tenía 640Gb (sigue teniéndolos) y poco a poco se le fueron añadiendo amigos dentro, como un SSD de 120Gb en el que instalar el sistema operativo Linux (UbuntuStudio) que ha permitido seguir funcionando con mayor rapidez de la que sería posible con el Windows 7 preinstalado en el HD convencional. Por si eso fuera poco, un disco duro muy muy viejo (IDE, de hecho PATA) que no tiene las conexiones apropiadas fue adaptado (adoptado), mediante un «chismito» que permite conectar 2 discos IDE y/o uno SATA a una conexión USB. Por supuesto, los discos necesitan alimentación directa, pues el aparatejo tan sólo se limita a transferencia de datos, que no es poco. (También había probado previamente una adaptación mediante otro dispositivo de IDE a SATA, pero no funcionó bien).

Ese disco duro IDE de 3,5″, que se ve «colgando» en la fotografía anterior, estaba en una carcasa interna que dejó de funcionar, tiene 300Gb y le denominamos LACIE que era el nombre de fábrica de ese primer disco externo que compramos, hará más de 15 años.

Para poder usar la conexión USB del adaptador, adquirí por un módico precio una tarjeta PCI que proporcionaba 4 enchufes USB fuera de la caja y uno hacia el interior de la misma, que es el que se ve en la imagen siguiente:

Esta es la caja de la tarjeta en cuesión:

Algo después, adquirimos un par de nuevas tarjetas PCI-E para aumentar el número de puertos USB (en este caso 3.0) tanto por la parte trasera de la torre como por la parte frontal, a medida que Carmen necesitaba más espacio de almacenamiento, pero la verdad es que ha llegado el momento de pasar a otro equipo, pues este pequeño Frankenstein que ha llegado a tener (internamente) su Intel NH-8280-1GB, 4Gb RAM, SSD 120Gb, HDD 640Gb SATA, HDD 300Gb IDE/USB, 4+5 USB 2.0 traseros, 2 USB 2.0 delanteros, 6 USB 3.0 vía PCI-e.

A punto estuve de conectarle un cuarto disco SATA de 500 Gb de un HP Pavillion que me salió muy malo y que ha terminado por romperse a los 12 años de su compra… (quizá no tan malo, después de todo), pero era bastante engorroso seguir haciendo ampliaciones mediocres para un PC saturado.

Ha llegado el momento de comprar un nuevo equipo, que empezará siendo directamente de segunda mano, para poder sumarle el SSD de 120Gb, quizá también el HDD 640Gb SATA y, por supuesto, las tarjetas PCI-e para extender el número de puertos USB 3.0, desnudando a un santo para vestir a otro, pero es que a veces hay que dejar morir a los santos ancianos.

Y no creo que lo haga del todo pues usaré cualquier cosita para poder arrancar el equipo y que siga sirviendo con sus 4Gb de RAM como un veterano de guerra.

¿Obsolescencia programada o consumismo irresponsable?

upgrade a linuxmint 19

¿Qué necesidad tengo de actualizar a LinuxMint 19.3 si todo me va bien con LinuxMint 18.1?

La realidad es que no tengo ninguna necesidad ahora de hacerlo, pero puede que no me venga mejor cuando el LM 18 pierda su soporte:

18.1 Serena Ubuntu Xenial Long term support release (LTS), supported until April 2021.

Es decir, que si ahora no hago nada, me veré en la tesitura de que me convenga hacer esa actualización allá por abril o mayo de este prometedor 2021, prometedor de incertidumbres y crisis sanitario-económico-sociales varias. Así que quizá es mejor planificar y anticiparme a ese año con una actualización que me dejará con la «conciencia tranquila» hasta abril del 2023.

Estoy siguiendo las instrucciones de la Comunidad de Linux Mint con todo el cuidado posible, pero sabiendo que muy probablemente algo irá mal. Así que estoy mentalizado para, en un momento dado, tener que llevar a cabo una instalación completa, borrando todo lo que tengo, reinstalando fuentes (lo que puede ser un lío), así como aplicaciones que uso y que ya ni recuerdo. A pesar de todo, hice copias de seguridad pertinentes, backups de mi trabajo en más de 5 dispositivos… y lo peor que puede pasar es que acabe perdiendo 3 días… en este periodo prevacacional en el que estoy.

Ahora mismo se está descargando todos los paquetes en local para proceder a la instalación. Cruzo los dedos y pulso Enter.

Mi web es una y es trina

A modo de taburete, la web en la que he estado trabajando desde primeros de marzo hasta ahora es una y es trina, sí, se trata de 3 patas que sustentan una especie de triunvirato que espero que no acabe tan mal como el famoso juliano.

La web Base

El esqueleto o lo que la aglutina es lo que llamo la base que está hecha casi «from scratch» en lo que se refiere al estilo, al aspecto, al comportamiento en diferentes dispositivos…

web base

El diario en WordPress.org

Sobre ella (o bajo ella, no sé) hay instalada una base de datos que gestiona, desde el 2011, mi diario, en el que escribo, como su nombre indica, casi diariamente, excepto en temporadas estivales o fiestas de guardar (el 1 de mayo o el 6 de diciembre).

De hecho, elegir el estilo del wordpress que la muestra me llevó gran parte del mes de marzo, hasta que di con una combinación de dos «themes» que me gustaban y de los que personalicé el definitivo, que pasó también a influir para unificar el estilo que usaría en las otras 2 patas de esta web trifásica.

web blog

La galería en Piwigo

Pero lo más sofisticado fue cuando decidí que no quería utilizar ninguna de las herramientas más habituales de gestión de álbumes de fotos o imágenes para almacenar el material visual que tenía (que había tenido previamente en picassa, luego en google-photos, o para el que había desarrollado o implementado «sliders» de javascript más o menos engorrosos).

Así que «inventé la rueda» instalando en mi hosting una aplicación llamada Piwigo (open source para más datos) que maneja y almacena las imágenes: la galería.

web galeria

Subirlas a ese espacio requerían, para no ser demasiado pesadas en término de tamaño de archivo, su procesamiento, reducción de resolución, renombrado para evitar caracteres especiales, minúsculas para homogeneizar, etc… que hice gracias a la programación, pues hablamos de más de 3000 imágenes.

Unificar estas tres componentes y que parezcan una sola web y no múltiples ha sido complejo, pero lo más difícil todavía fue revisar reordenar y modificar todo el trabajo que tenía más o menos mal documentado desde el 2008 (fecha de la última actualización importante de la web) hasta hoy.

12 años de trabajo que han sido fructíferos en términos de obra, de producción casi industrial, de proyectos complejos y largos… muchos de los cuales no habían visto la luz hasta hoy.

Ahora siento un alivio considerable y una extraña sensación de vacío, sigo teniendo material en curso, en lo que estoy trabajando que aún no está en esta web, pero ya sé dónde ponerlo cuando acabe.

En resumen:

  1. Marzo: Pruebas de personalización de temas de blog (con instalaciones en desarrollo sobre una raspberry, para no «romper» nada importante), así como elección de tipo de letra, colores…
  2. Abril: Ordenación de material visual, de documentación de acciones, revisión de trabajos pendientes de un final…
  3. Mayo: Creación de la base de datos Piwigo para almacenamiento de las imágenes. Elección y personalización del tema elegido. Por momentos, parece algo superfluo que se podría haber hecho agrupando esto con el Diario en WordPress.org, pero me resulta más fácil compartimentar.
  4. Junio: Creación de la web base. Generación de una plantilla dinámica, pero que no haga uso de javascript salvo en lo imprescindible sino que sea responsive y con animaciones pero exclusivamente basándome en estándares CSS3 y HTML5 (me encantan las etiquetas «semánticas»).

Han sido meses de confinamiento y agradezco (a mí mismo, supongo) haber tenido el tiempo para poder afrontar algo como esto que muchas de las veces, mientras lo estaba haciendo dudaba que tuviese el más mínimo sentido en esta época de red social y publicación en plantilla.

Espero que me dure el trabajo principal, si no una docena de años como la anterior web, por lo menos más de 5 años.

Plantilla HTML de mi web

Modificando mi página web, me encuentro con que, finalmente, acabo generando una especie de plantilla (hecha a mano, como debe ser todo molde) que hace que casi toda la web sea relativamente homogénea, lo que me simplifica la vida, obviamente, pero también aburre un poco porque tienes la sensación de que todas las páginas que estás visitando son un poco más de lo mismo… Pero qué le voy a hacer. Es mi forma de ser.

Aquí dejo la plantilla HTML y en breve publicaré también los documentos CSS y el javascript necesario para hacer una página responsive manejando una estructura de archivos HTML con más de 100 páginas individuales.

<!DOCTYPE html>
<html lang="es">
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <meta name="Description" content="Página Personal de Giusseppe Domínguez">
  <meta name="Keywords" content="Arte, Taller, Curso, Clase, Poesía, Escritura, Creatividad, Giusseppe Domínguez, Clave 53, Experimentación">
  <meta name="author" content="Giusseppe Domínguez">
  <title>Giusseppe Dom&iacute;nguez</title>
  <link rel="stylesheet" href="../estilos/gsp2020.css">
  <link rel="shortcut icon" href="../img/gsp.ico">
  <script src="../js/jquery.min.js"></script>
  <script src="../js/gsp.js"></script>
</head>

<body>
   <!-- Menú superior -->	
   <script type="text/javascript">
     creaheader('../'); // Crea menú - top (logo-header y nav)
   </script>
  <main>
  <section>
<a name=ACCIONES></a>
    <article>
            <hgroup>
                <h1>Acciones</h1>
                <h3>Performances, Acciones, Poesía Escénica...</h3>
            </hgroup>
    	<div class="content">

    <p>AQUÍ VA EL CONTENIDO</p>

            </div> <!-- /content -->
        </article> <!-- /article -->
    </section> <!-- / #main-content -->
  </main>
  <!-- Footer -->	
  <script type="text/javascript">
    creafooter(); // Crea footer (copyright y ref: giusseppe.net)
  </script>
</body>
</html>

 

Pruebas de edición

Este curso, estoy con total normalidad, ni nueva normalidad ni nada, maquetando el libro colectivo que suelo preparar casi a modo de regalo para las personas apuntadas a los Talleres de Poesía de Clave 53 y he apostado por un formato en el que el nombre de cada poeta figure incluido en la primera página de las 4 que tiene dedicadas, para desperdiciar el menor número de páginas posible, pues suelo dedicar una página a modo de comienzo de sección para el nombre del poeta o la poeta y su consiguiente página vacía par, lo que supone 2 páginas por cada poeta. Este año son 25 las autorías, así que sumábamos 50 páginas al libro, lo que además de encarecerlo, lo haría un poco más grueso de lo razonable.

Es un formato que ya había probado y quedaba muy elegante en el Libro Refugio que realizamos el curso pasado. Sin embargo, he querido apostar por una tipografía que no he usado hasta ahora en ningún libro y que me gusta bastante que es la Josephine Sans Serif, acompañada en citas y notas a pie de página por su familia hermana, Josephine Slab Serif, que mantiene el mismo criterio de diseño (gracias a Santiago Orozco) más o menos geométrico, pero también jugueteando con las formas de las letras, alejándome de mi habitual y bienamada Futura.

Lo que aún no he determinado es la imprenta con la que trabajaré, pero es posible que me vuelva a decantar por la que estoy ofreciendo últimamente, por su gran oferta de papeles de cubierta disponibles, Lozano Impresores, S.L. incluso aunque sea un poquito más cara. Ya veremos.

Eso sí, siempre usando, como se puede ver en las capturas de pantalla, Software Libre. En esta ocasión, Scribus 1.4.6 sobre Linux Mint 18.3 para la tripa e Inkscape 0.91 r13725 para la cubierta en vectorial.

Pruebas de páginas de impresora nueva

Tener Linux y cambiar de impresora es algo tedioso, porque siempre falta algún driver que hace que no sea tan fácil como dicen que es. Por otro lado, lo de instalar una impresora que se conecte por wifi puede ser una maldita locura, sobre todo si se trata de la conexión «simple» por WPS, pero afortunadamente la última impresora que hemos tenido que adquirir para sustituir a una Canon PIXMA que no ha funcionado nunca muy bien, permite conectarse sin hacer uso de esa presunta utilidad.

Después de instalada y conectada a la red, toca hacer las distintas pruebas de impresión desde todos los dispositivos que suelen usarla, que son principalmente nuestros dos equipos de sobremesa (que realmente están «bajomesa») y un móvil, por si alguna vez se quiere imprimir sin abrir un PC, o si deja de funcionar el driver de turno en Linux (cosa que ocurre con más frecuencia de lo que desearía cualquiera). Son hojas que me gustan mucho, aunque no tengan más que imágenes y textos técnicos orientados a probar las distintas capacidades de la impresora, pero también contienen algo de información técnica que suele ser conveniente almacenar.

Varias pruebas desde un Linux Mint 18.3 (mío) y un UbuntuStudio 18.04 (Carmen), así como desde una APP del móvil:

Esta copia es la impresa desde mi Linux Mint con el driver ippeve.ppd el martes 14 de mayo, cuando nos llegó para sustituir a la que teníamos rota.

Esta copia es la realizada tras instalar el driver del fabricante, que curiosamente funciona mucho peor que el proporcionado por Linux de manera «natural». En ella queda información sobre la IP que le asignó (y reservé posteriormente por MAC ADDRESS) el router.

Un comando utilísimo de Linux

Es una maravilla la de cosas que se pueden hacer desde línea de comandos de linux (unix, en general), así que pongo por ejemplo este pequeño portento para modificar el tamaño de todas las imágenes encontradas (podría hacer una búsqueda más restrictiva, solo basándome en la extensión de los archivos) y adaptarlas a las dimensiones que desee:

find . -type f -size +1000k -exec mogrify -resize 25% {} \;

Este comando busca los archivos mayores de 1000K (cerca de un megabyte) y reduce su tamaño (como imagen) en un 25% porcentualmente, lo que puede ser una reducción enorme de recursos para una librería de fotografías que se deseen usar en una web, que es para lo que lo estoy usando, de manera que las imágenes que sincronizo en mi base de datos de imágenes no sean desmesuradamente grandes para su posterior descarga y gestión o visualización por parte de Piwigo

Una herramienta tan poderosa como para eliminar o modificar espacios de nombres de archivos, o caracteres no admitidos, como nuestra bienamada ñ, o las acentuaciones, o todas las mayúsculas por minúsculas…

find . -name '* *' -exec rename 's/ /_/g' {} \;

Este comando busca archivos o carpetas (no está especificado el type) que contengan espacios en su nombre (podría haberse buscado otra cosa) y se sustituye por guiones bajos con el comando rename.

find . -depth -exec rename -n y/A-Z/a-z/ {} \;

Cambiamos todas las mayúsculas por minúsculas, tanto en archivos como en carpetas. (Quitando el «-n», lo efectuará, de lo contrario, muestra lo que haría, pero no lo hace)

También me permitiría cambiar las ñ o Ñ por caracteres de mi elección, pero eso es mejor hacerlo con cuidado, porque sustituir por «n» o «N» puede borrar otro archivo… así que es preferible, primero, saber dónde están esos archivos con un comando que los busque como este:

find . -name "*[ñ|Ñ]*" -print

 

Otras opciones increíbles del programa mogrify incluyen la rotación arbitraria de bloque de imágenes, o la reducción absoluta a, por ejemplo, 1024 de ancho forzoso con el atributo «resize 1024».

mogrify -resize 1024 *.jpg
mogrify -rotate "-90" *.jpg

Después de pasar la mañana del martes compleja y parte de la tarde con esto para modificar algunos cientos o miles de archivos, me encuentro esta joya del 2005 que contiene unos cuantos scripts mucho mejor documentados y programados de lo que yo hubiera hecho y con una sencillez tremenda para modificarlos y adaptarlos a lo que necesite.

Añadiendo movimiento con CSS

Después de la actualización del «theme» de WordPress que realicé ayer en el entorno de producción, he comenzado lo que podríamos denominar el ajuste fino.

La verdad es que estoy fascinado con las posibilidades que tiene CSS3, como generar animaciones tan sencillamente como diciendo «trasládete de acá a allá«… más o menos. Es formidable y ya había hecho uso de ello en la web del proyecto La Consulta, especialmente en el apartado de mostrar el tamaño aumentado de las imágenes de los garbanzos contados cuando se pasa el ratón por encima.

Es tan tentador usarlo una vez que se conoce que puede acabar pareciendo un circo en el peor de los sentidos. De momento, sólo incorporaré alguna traslación de «cajitas» en el blog y cuando comience (que ya estoy a punto) a remodelar la web, usaré las mismas, además de intentar utilizar los mismos colores, así que lo he añadido a un archivo CSS llamado animaciones.css que estoy creando a partir de la fantástica herramienta encontrada en animista.net.

Me habría gustado utilizar «@import» en el CSS adicional dentro del tema de wordpress, pero parece que no es viable hacerlo, así que me obliga a tener duplicadas (con lo poco que eso me gusta) esas directivas tanto en el hueco que la edición del tema WordPress me permite, así como en el archivo CSS /estilos/animaciones.css de la raíz de mi web.

De momento, dejo el código que ha generado esta aplicación online en esta entrada, por si alguna vez vuelvo a necesitarla:

.slide-in-left {
    -webkit-animation: slide-in-left 3s both;
            animation: slide-in-left 3s both;}
.slide-in-right {
    -webkit-animation: slide-in-right 3s both;
            animation: slide-in-right 3s both;
}

/* ----------------------------------------------
 * Generated by Animista on 2020-5-8 11:22:35
 * Licensed under FreeBSD License.
 * See http://animista.net/license for more info. 
 * w: http://animista.net, t: @cssanimista
 * ---------------------------------------------- */

/**
 * ----------------------------------------
 * animation slide-in-left
 * ----------------------------------------
 */
@-webkit-keyframes slide-in-left {
  0% {
    -webkit-transform: translateX(-1000px);
            transform: translateX(-1000px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}
@keyframes slide-in-left {
  0% {
    -webkit-transform: translateX(-1000px);
            transform: translateX(-1000px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}
/**
 * ----------------------------------------
 * animation slide-in-right
 * ----------------------------------------
 */
@-webkit-keyframes slide-in-right {
  0% {
    -webkit-transform: translateX(1000px);
            transform: translateX(1000px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}
@keyframes slide-in-right {
  0% {
    -webkit-transform: translateX(1000px);
            transform: translateX(1000px);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
    opacity: 1;
  }
}

 

Esto no es una broma