GIF

Familia de formatos de archivos de imágenes de mapa de bits

GIF
Un GIF animado de un globo terráqueo giratorio
Extensión de nombre de archivo
.gif
Tipo de medio de Internet
image/gif
Código de tipoGIFf
Identificador de tipo uniforme (UTI)com.compuserve.gif
Número mágicoGIF87a/GIF89a
Desarrollado porCompuServe
Lanzamiento inicial15 de junio de 1987 ; hace 37 años [1] ( 15 de junio de 1987 )
Último lanzamiento
89a
1989 ; hace 35 años [2] ( 1989 )
Tipo de formato formato de imagen de mapa de bits sin pérdida
Sitio webwww.w3.org/Graphics/GIF/spec-gif89a.txt

El formato de intercambio de gráficos ( GIF; /ɡɪf/ GHIF o / dʒɪf / JIF , véase § Pronunciación ) es un formato de imagen de mapa de bits que fue desarrollado por un equipo del proveedor de servicios en línea CompuServe dirigido por el científico informático estadounidense Steve Wilhite y lanzado el 15 de junio de 1987. [1]

El formato puede contener hasta 8 bits por píxel , lo que permite que una sola imagen haga referencia a su propia paleta de hasta 256 colores diferentes elegidos del espacio de color RGB de 24 bits . También puede representar varias imágenes en un archivo, que se puede utilizar para animaciones , y permite una paleta separada de hasta 256 colores para cada fotograma. Estas limitaciones de la paleta hacen que GIF sea menos adecuado para reproducir fotografías en color y otras imágenes con degradados de color , pero adecuado para imágenes más simples, como gráficos o logotipos con áreas sólidas de color.

Las imágenes GIF se comprimen utilizando la técnica de compresión de datos sin pérdida Lempel–Ziv–Welch (LZW) para reducir el tamaño del archivo sin degradar la calidad visual.

Si bien en su momento se utilizó ampliamente en la World Wide Web debido a su amplia implementación y portabilidad entre aplicaciones y sistemas operativos, el uso del formato ha disminuido por razones de espacio y calidad, y a menudo se lo reemplaza con formatos de video como el formato de archivo MP4 . Estos reemplazos, a su vez, a veces se denominan "GIF", a pesar de no tener relación con el formato de archivo original. [3]

Historia

CompuServe introdujo GIF el 15 de junio de 1987 para proporcionar un formato de imagen en color para sus áreas de descarga de archivos. Esto reemplazó a su anterior formato de codificación de longitud de ejecución , que era solo en blanco y negro. GIF se hizo popular porque usaba la compresión de datos Lempel–Ziv–Welch . Como era más eficiente que la codificación de longitud de ejecución utilizada por PCX y MacPaint , se podían descargar imágenes bastante grandes con bastante rapidez incluso con módems lentos .

La versión original de GIF se llamó 87a. [1] Esta versión ya admitía varias imágenes en una transmisión.

En 1989, CompuServe lanzó una versión mejorada, llamada 89a, [2] Esta versión agregó:

  • Soporte para retrasos en la animación
  • colores de fondo transparentes
  • almacenamiento de metadatos específicos de la aplicación
  • Permitir que las etiquetas de texto se muestren como texto (sin incrustarlas en los datos gráficos). Sin embargo, como hay poco control sobre las fuentes de visualización, esta función rara vez se utiliza.

Las dos versiones se pueden distinguir observando los primeros seis bytes del archivo (el " número mágico " o firma), que, al interpretarse como ASCII , se leen "GIF87a" o "GIF89a", respectivamente.

CompuServe fomentó la adopción de GIF al proporcionar utilidades de conversión descargables para muchos ordenadores. En diciembre de 1987, por ejemplo, un usuario de Apple IIGS podía ver imágenes creadas en un Atari ST o un Commodore 64. [ 4] GIF fue uno de los dos primeros formatos de imagen utilizados comúnmente en los sitios web, el otro era el XBM en blanco y negro . [5]

En septiembre de 1995, Netscape Navigator 2.0 agregó la capacidad de reproducir GIF animados en bucle.

Aunque el formato GIF fue desarrollado por CompuServe , utilizaba el algoritmo de compresión de datos sin pérdida Lempel–Ziv–Welch (LZW), patentado por Unisys en 1985. La controversia sobre el acuerdo de licencia entre Unisys y CompuServe en 1994 impulsó el desarrollo del estándar Portable Network Graphics (PNG). En 2004, expiraron todas las patentes relacionadas con la compresión patentada utilizada para GIF.

La función de almacenar múltiples imágenes en un archivo, acompañadas de datos de control, se utiliza ampliamente en la Web para producir animaciones simples .

La función de entrelazado opcional , que almacena las líneas de escaneo de imágenes fuera de orden de tal manera que incluso una imagen parcialmente descargada era algo reconocible, también ayudó a la popularidad de GIF, [6] ya que un usuario podía abortar la descarga si no era lo que se requería.

En mayo de 2015, Facebook agregó soporte para GIF. [7] [8] En enero de 2018, Instagram también agregó stickers GIF al modo historia. [9]

Terminología

Como sustantivo , la palabra GIF se encuentra en las ediciones más recientes de muchos diccionarios. En 2012, la sección estadounidense de la Oxford University Press reconoció GIF también como verbo , que significa "crear un archivo GIF", como en "GIFing fue el medio perfecto para compartir escenas de los Juegos Olímpicos de verano ". Los lexicógrafos de la prensa la votaron como su palabra del año , diciendo que los GIF han evolucionado hasta convertirse en "una herramienta con aplicaciones serias que incluyen la investigación y el periodismo". [10] [11]

Pronunciación

Una infografía humorística que anuncia el lanzamiento en 2013 de una cuenta de Tumblr para la Casa Blanca sugiere pronunciar GIF con g dura .

La pronunciación de la primera letra de GIF ha sido objeto de controversia desde la década de 1990. Las pronunciaciones más comunes en inglés son / dʒɪf / (con unagsuavecomo engin) y/ ɡ ɪ f / (con unagduracomo enregalo), que difiere en elfonemarepresentado por la letraG.Los creadores del formato pronunciaron el acrónimoGIFcomo/ɪ f /, con unagsuave, y Wilhite afirmó que pretendía que la pronunciación hiciera eco deliberadamente de lamarcade mantequilla de maníJif, y los empleados de CompuServe solían bromear "los desarrolladores selectivos eligen GIF", una parodia de los comerciales de televisión de Jif.[12]Sin embargo, la palabra se pronuncia ampliamente como/ ɡ ɪ f /, con unagdura,[13]y las encuestas generalmente han demostrado que estages más frecuente.[14][15]

Dictionary.com [16] cita ambas pronunciaciones, indicando / ɪ f / como la pronunciación principal, mientras que Cambridge Dictionary of American English [17] ofrece solo la pronunciación con g dura . Merriam-Webster's Collegiate Dictionary [18] y Oxford Dictionaries citan ambas pronunciaciones, pero colocan la g dura primero: / ɡ ɪ f , ɪ f / . [19] [20] [21] [22] El New Oxford American Dictionary solo dio / ɪ f / en su segunda edición [23] pero lo actualizó a / ɪ f , ɡ ɪ f / en la tercera edición. [24]

El desacuerdo sobre la pronunciación ha dado lugar a un acalorado debate en Internet. Con motivo de recibir un premio a la trayectoria en la ceremonia de los Premios Webby de 2013 , Wilhite rechazó públicamente la pronunciación de la g dura ; [13] [25] [26] su discurso dio lugar a más de 17.000 publicaciones en Twitter y decenas de artículos de prensa. [27] La ​​Casa Blanca [13] y el programa de televisión Jeopardy! también entraron en el debate en 2013. [26] En febrero de 2020, The JM Smucker Company , los propietarios de la marca Jif, se asociaron con la base de datos de imágenes animadas y el motor de búsqueda Giphy para lanzar un tarro de mantequilla de maní de edición limitada "Jif vs. GIF" ( con el hashtag #JIFvsGIF) que tenía una etiqueta que declaraba humorísticamente que la pronunciación de la g suave se refería exclusivamente a la mantequilla de maní, y que GIF se pronunciaba exclusivamente con la pronunciación de la g dura . [28]

Uso

Los GIF son adecuados para dibujos lineales de bordes nítidos con un número limitado de colores, como logotipos. Esto aprovecha la compresión sin pérdida del formato, que favorece las áreas planas de color uniforme con bordes bien definidos. [29] También se pueden utilizar para almacenar datos de sprites de bajo color para juegos. [30] Los GIF se pueden utilizar para pequeñas animaciones y videoclips de baja resolución, o como reacciones en mensajes en línea utilizados para transmitir emociones y sentimientos en lugar de usar palabras. Son populares en plataformas de redes sociales como Tumblr , [31] Facebook y Twitter . [32]

Formato de archivo

En teoría, un archivo GIF describe un área gráfica de tamaño fijo (la "pantalla lógica") poblada con cero o más "imágenes". Muchos archivos GIF tienen una sola imagen que llena toda la pantalla lógica. Otros dividen la pantalla lógica en subimágenes independientes. Las imágenes también pueden funcionar como cuadros de animación en un archivo GIF animado, pero nuevamente no es necesario que llenen toda la pantalla lógica.

Los archivos GIF comienzan con un encabezado de longitud fija ("GIF87a" o "GIF89a") que indica la versión, seguido de un descriptor de pantalla lógica de longitud fija que indica las dimensiones en píxeles y otras características de la pantalla lógica. El descriptor de pantalla también puede especificar la presencia y el tamaño de una tabla de colores global (GCT), que aparece a continuación si está presente.

A continuación, el archivo se divide en segmentos de los siguientes tipos, cada uno introducido por un centinela de 1 byte:

  • Una imagen (introducida por 0x2C, una coma ASCII ',')
  • Un bloque de extensión (introducido por 0x21, un signo de exclamación ASCII '!')
  • El tráiler (un solo byte de valor 0x3B, un punto y coma ASCII ';'), que debe ser el último byte del archivo.

Una imagen comienza con un descriptor de imagen de longitud fija, que puede especificar la presencia y el tamaño de una tabla de colores local (que sigue a continuación si está presente). A continuación, se muestran los datos de la imagen: un byte que indica el ancho en bits de los símbolos no codificados (que debe tener al menos 2 bits de ancho, incluso para imágenes bicolores), seguido de una serie de subbloques que contienen los datos codificados con LZW.

Los bloques de extensión (bloques que "extienden" la definición 87a a través de un mecanismo ya definido en la especificación 87a) consisten en el centinela, un byte adicional que especifica el tipo de extensión y una serie de subbloques con los datos de extensión. Los bloques de extensión que modifican una imagen (como la extensión de control gráfico que especifica el tiempo de retardo de animación opcional y el color de fondo transparente opcional) deben preceder inmediatamente al segmento con la imagen a la que hacen referencia.

Cada subbloque comienza con un byte que indica el número de bytes de datos subsiguientes en el subbloque (de 1 a 255). La serie de subbloques termina con un subbloque vacío (un byte 0).

Esta estructura permite analizar el archivo incluso si no se comprenden todas sus partes. Un GIF marcado como 87a puede contener bloques de extensión; la intención es que un decodificador pueda leer y mostrar el archivo sin las características cubiertas por extensiones que no comprende.

Los detalles completos del formato de archivo están cubiertos en la especificación GIF. [2]

Paletas

Un ejemplo de una imagen GIF guardada con una paleta segura para la web y tramada mediante el método Floyd-Steinberg ; como consecuencia de los relativamente pocos colores permitidos en dicha imagen, el contraste y el colorido de la imagen son notablemente pobres.

GIF se basa en paletas: los colores utilizados en una imagen (un fotograma) en el archivo tienen sus valores RGB definidos en una tabla de paleta que puede albergar hasta 256 entradas, y los datos de la imagen hacen referencia a los colores por sus índices (0-255) en la tabla de paleta. Las definiciones de color en la paleta se pueden extraer de un espacio de color de millones de tonos (2 24 tonos, 8 bits para cada primario), pero el número máximo de colores que un fotograma puede utilizar es 256. Esta limitación era razonable cuando se desarrolló GIF porque el hardware que podía mostrar más de 256 colores simultáneamente era poco común. Los gráficos simples, los dibujos lineales, las caricaturas y las fotografías en escala de grises normalmente necesitan menos de 256 colores.

Cada cuadro puede designar un índice como "color de fondo transparente": cualquier píxel asignado a este índice adquiere el color del píxel en la misma posición del fondo, que puede haber sido determinado por un cuadro de animación anterior.

Se han desarrollado muchas técnicas, llamadas colectivamente dithering , para aproximarse a una gama más amplia de colores con una paleta de colores pequeña mediante el uso de píxeles de dos o más colores para aproximarse a los colores intermedios. Estas técnicas sacrifican la resolución espacial para aproximarse a una resolución de color más profunda. Si bien no forma parte de la especificación GIF, el dithering se puede utilizar en imágenes codificadas posteriormente como imágenes GIF. A menudo, esta no es una solución ideal para las imágenes GIF, tanto porque la pérdida de resolución espacial generalmente hace que una imagen se vea borrosa en la pantalla como porque los patrones de dithering a menudo interfieren con la compresibilidad de los datos de la imagen, lo que va en contra del propósito principal de GIF.

En los primeros días de los navegadores web gráficos [ ¿cuándo? ] , las tarjetas gráficas con buffers de 8 bits (que permitían solo 256 colores) eran comunes y era bastante común crear imágenes GIF utilizando la paleta websafe . [ ¿según quién? ] Esto garantizaba una visualización predecible, pero limitaba severamente la elección de colores. Cuando el color de 24 bits se convirtió en la norma, las paletas se podían completar con los colores óptimos para imágenes individuales.

Una tabla de colores pequeña puede ser suficiente para imágenes pequeñas, y mantener la tabla de colores pequeña permite que el archivo se descargue más rápido. Tanto la especificación 87a como la 89a permiten tablas de colores de 2 n colores para cualquier n de 1 a 8. La mayoría de las aplicaciones gráficas leerán y mostrarán imágenes GIF con cualquiera de estos tamaños de tabla; pero algunas no admiten todos los tamaños al crear imágenes. Las tablas de 2, 16 y 256 colores son ampliamente compatibles.

Color verdadero

Aunque GIF casi nunca se utiliza para imágenes en color verdadero , es posible hacerlo. [33] [34] Una imagen GIF puede incluir múltiples bloques de imagen, cada uno de los cuales puede tener su propia paleta de 256 colores, y los bloques se pueden colocar en mosaico para crear una imagen completa. Alternativamente, la especificación GIF89a introdujo la idea de un color "transparente" donde cada bloque de imagen puede incluir su propia paleta de 255 colores visibles más un color transparente. Se puede crear una imagen completa colocando en capas bloques de imagen con la parte visible de cada capa mostrándose a través de las partes transparentes de las capas superiores.

Un GIF animado que ilustra una técnica para mostrar más del límite típico de 256 colores.

Para reproducir una imagen a todo color como GIF, la imagen original debe dividirse en regiones más pequeñas que no tengan más de 255 o 256 colores diferentes. Cada una de estas regiones se almacena luego como un bloque de imagen separado con su propia paleta local y cuando los bloques de imagen se muestran juntos (ya sea mediante mosaicos o mediante la superposición de bloques de imagen parcialmente transparentes), aparece la imagen completa a todo color. Por ejemplo, dividir una imagen en mosaicos de 16 por 16 píxeles (256 píxeles en total) garantiza que ningún mosaico tenga más que el límite de la paleta local de 256 colores, aunque se pueden usar mosaicos más grandes y combinar colores similares, lo que da como resultado cierta pérdida de información de color. [33]

Dado que cada bloque de imagen puede tener su propia tabla de colores local, un archivo GIF que tenga muchos bloques de imagen puede ser muy grande, lo que limita la utilidad de los GIF a todo color. [34] Además, no todos los programas de renderizado de GIF manejan correctamente las imágenes en mosaico o en capas. Muchos programas de renderizado interpretan los mosaicos o las capas como cuadros de animación y los muestran en secuencia como una animación [33] y la mayoría de los navegadores web muestran automáticamente los cuadros con un tiempo de retraso de 0,1 segundos o más. [35] [36] [ se necesita una mejor fuente ]

Ejemplo de archivo GIF

Microsoft Paint guarda una pequeña imagen en blanco y negro como el siguiente archivo GIF (ilustrado ampliado).
Paint no hace un uso óptimo de GIF; debido a la tabla de colores innecesariamente grande (almacena 256 colores en lugar de los 2 utilizados) y al ancho de los símbolos, este archivo GIF no es una representación eficiente de la imagen de 15 píxeles.
Aunque el bloque de extensión de control gráfico declara que el índice de color 16 (hexadecimal 10) es transparente, ese índice no se utiliza en la imagen. Los únicos índices de color que aparecen en los datos de la imagen son los decimales 40 y 255, que la tabla de colores global asigna a blanco y negro, respectivamente.

Imagen de muestra (ampliada), tamaño real 3 píxeles de ancho por 5 de alto

Los números hexadecimales en las siguientes tablas están en orden de bytes little-endian , como lo prescribe la especificación del formato.

Tabla de valores de imágenes GIF de ejemplo
Byte n.° (hexadecimal)HexadecimalTexto o valorSignificado
047 49 46 38 39 61GIF89aEncabezamiento
Descriptor de pantalla lógica
603 003Ancho de pantalla lógico
805 005Altura de pantalla lógica
AF7GCT sigue para 256 colores con una resolución de 3  ×  8 bits/primario, los 3 bits más bajos representan la profundidad de bits menos 1, el bit verdadero más alto significa que el GCT está presente
B000Color de fondo: índice #0; #000000 negro
do000Relación de aspecto de píxeles predeterminada: 0:0
Tabla de colores global
D00 00 00
R (rojo)G (verde)B (azul)
000
Tabla de colores global, color n.° 0: #000000, negro
Los bytes D h a 30 C h del ejemplo definen una paleta de 256 colores. Los índices utilizados en la imagen de muestra para blanco y negro son 28 h y FF h .
1080 00 00
R (rojo)G (verde)B (azul)
12800
Tabla de colores global, color n.° 1: bit transparente, no se utiliza en la imagen
.........La tabla de colores global se extiende hasta 30 A
30A¡Bah, bah, bah!
R (rojo)G (verde)B (azul)
255255255
Tabla de colores global, color n.° 255: #ffffff, blanco
Extensión de control gráfico
30D21'!'Un bloque de extensión (introducido por un signo de exclamación ASCII '!')
30EF9Una extensión de control gráfico
30F044Cantidad de datos GCE, 4 bytes
31001Color de fondo transparente; este es un campo de bits, el bit más bajo significa transparencia
31100 00Retraso de la animación en centésimas de segundo; no se utiliza
3131016Número de color del píxel transparente en GCT
31400Fin del bloque GCE
Descriptor de imagen
3152C','Un descriptor de imagen (introducido por 0x2C, una coma ASCII ',')
31600 00 00 00(0, 0)Posición de la esquina noroeste de la imagen en la pantalla lógica
31A03 00 05 00(3, 5)Ancho y alto de la imagen en píxeles
31E000Bit de tabla de colores local, 0 significa ninguno
Datos de imagen
31F088Inicio de la imagen, tamaño mínimo del código LZW
3200B11Comienzo del primer subbloque de datos, especificando 11 bytes de datos codificados a seguir
32100 51 FC 1B 28 70 A0 C1 83 01 01<datos de imagen>11 bytes de datos de imagen, consulte el campo 320
32 °C000Subbloque de datos final, que especifica que no hay bytes de datos siguientes (y el final de la imagen)
Tráiler
32D3B';'Indicador de bloque de terminación de archivo (un punto y coma ASCII ';')

Codificación de imágenes

Los datos de píxeles de la imagen, escaneados horizontalmente desde la parte superior izquierda, se convierten mediante la codificación LZW en códigos que luego se asignan a bytes para almacenarlos en el archivo. Los códigos de píxeles normalmente no coinciden con el tamaño de 8 bits de los bytes, por lo que los códigos se empaquetan en bytes mediante un esquema "little-Endian": el bit menos significativo del primer código se almacena en el bit menos significativo del primer byte, los bits de orden superior del código en los bits de orden superior del byte, y se desbordan hacia los bits de orden inferior del siguiente byte según sea necesario. Cada código posterior se almacena comenzando por el bit menos significativo que no se haya utilizado.

Este flujo de bytes se almacena en el archivo como una serie de "subbloques". Cada subbloque tiene una longitud máxima de 255 bytes y está precedido por un byte que indica la cantidad de bytes de datos en el subbloque. La serie de subbloques termina con un subbloque vacío (un único byte 0, que indica un subbloque con 0 bytes de datos).

Para la imagen de muestra anterior se muestra a continuación el mapeo reversible entre códigos de 9 bits y bytes.

Mapeo reversible
Código de 9 bitsByte
HexadecimalBinarioBinarioHexadecimal
1001 000000000000000000
02800 01010000101000 151
0FF011 111111111111 00FC
1031000 0001100011 0111B
10210000 00100010 100028
103100000 011011 1000070
1061000001 1010 100000A0
10710000011 11 1000001C1
1000001183
1011 000000010000000101
0000000 101

Se evidencia una ligera compresión: los colores de los píxeles definidos inicialmente por 15 bytes se representan exactamente con 12 bytes de código, incluidos los códigos de control. El proceso de codificación que produce los códigos de 9 bits se muestra a continuación. Una cadena local acumula números de colores de píxeles de la paleta, sin ninguna acción de salida mientras la cadena local se pueda encontrar en una tabla de códigos. Hay un tratamiento especial de los dos primeros píxeles que llegan antes de que la tabla crezca a partir de su tamaño inicial mediante la adición de cadenas. Después de cada código de salida, la cadena local se inicializa con el último color de píxel (que no se pudo incluir en el código de salida).

 Tabla de cadena de 9 bits  --> código código Acción #0 | 000h Inicializar la tabla raíz de códigos de 9 bits paleta | : colores | : #255 | 0FFh 100 horas fin | 101h | 100h ClaroPíxel local |Paleta de colores cadena |NEGRO #40 28 | 028h 1er píxel siempre a la salidaBLANCO #255 FF | Cadena encontrada en la tabla 28 FF | 102h Siempre agregue la primera cadena a la tabla FF | Inicializar cadena localBLANCO #255 FF FF | Cadena no encontrada en la tabla | 0FFh - código de salida para la cadena anterior FF FF | 103h - agregar la última cadena a la tabla FF | - inicializa cadena localBLANCO #255 FF FF | Cadena encontrada en la tablaNEGRO #40 FF FF 28 | Cadena no encontrada en la tabla | 103h - código de salida para la cadena anterior FF FF 28 | 104h - añadir la última cadena a la tabla 28 | - inicializar cadena localBLANCO #255 28 FF | Cadena encontrada en la tablaBLANCO #255 28 FF FF | Cadena no encontrada en la tabla | 102h - código de salida para la cadena anterior 28 FF FF | 105h - agregar la última cadena a la tabla FF | - inicializa cadena localBLANCO #255 FF FF | Cadena encontrada en la tablaBLANCO #255 FF FF FF | Cadena no encontrada en la tabla | 103h - código de salida para la cadena anterior FF FF FF | 106h - agregar la última cadena a la tabla FF | - inicializa cadena localBLANCO #255 FF FF | Cadena encontrada en la tablaBLANCO #255 FF FF FF | Cadena encontrada en la tablaBLANCO #255 FF FF FF FF | Cadena no encontrada en la tabla | 106h - código de salida para la cadena anterior FF FF FF FF| 107h - agregar la última cadena a la tabla FF | - inicializa cadena localBLANCO #255 FF FF | Cadena encontrada en la tablaBLANCO #255 FF FF FF | Cadena encontrada en la tablaBLANCO #255 FF FF FF FF | Cadena encontrada en la tabla No más píxeles 107h - código de salida para la última cadena 101h Fin

Para mayor claridad, la tabla que se muestra arriba está formada por cadenas de longitud creciente. Este esquema puede funcionar, pero la tabla consume una cantidad impredecible de memoria. En la práctica, se puede ahorrar memoria teniendo en cuenta que cada nueva cadena que se almacene consta de una cadena almacenada previamente aumentada con un carácter. Resulta económico almacenar en cada dirección sólo dos palabras: una dirección existente y un carácter.

El algoritmo LZW requiere una búsqueda en la tabla para cada píxel. Una búsqueda lineal a través de hasta 4096 direcciones haría que la codificación fuera lenta. En la práctica, los códigos se pueden almacenar en orden de valor numérico; esto permite que cada búsqueda se realice mediante un SAR (Registro de Aproximación Sucesiva, como se usa en algunos ADC ), con solo 12 comparaciones de magnitud. Para lograr esta eficiencia, se necesita una tabla adicional para convertir entre códigos y direcciones de memoria reales; el mantenimiento de la tabla adicional solo se necesita cuando se almacena un nuevo código, lo que ocurre a una velocidad mucho menor que la de los píxeles.

Decodificación de imágenes

La decodificación comienza asignando los bytes almacenados a códigos de 9 bits. Estos se decodifican para recuperar los colores de los píxeles, como se muestra a continuación. Se crea una tabla idéntica a la utilizada en el codificador agregando cadenas según esta regla:

¿Se encuentra el código entrante en la tabla?
Agrega una cadena para el código local seguida del primer byte de la cadena para el código entrante
NoAgrega una cadena para el código local seguida de una copia de su primer byte
 desplazamiento de 9 bits ----> Código de píxel de tabla local Código de código --> cadena Paleta de colores Acción100h 000h | #0 Inicializar la tabla raíz de códigos de 9 bits  : | paleta  : | colores 0FFh | #255 100 h | claro 101h | fin028h | #40 NEGRO Descodificar 1er píxel0FFh 028h | Código entrante encontrado en la tabla | #255 BLANCO - cadena de salida de la tabla 102h | 28 FF - añadir a la tabla103h 0FFh | Código entrante no encontrado en la tabla 103h | FF FF - añadir a la tabla | - cadena de salida de la tabla | #255 BLANCO | #255 BLANCO102h 103h | Código entrante encontrado en la tabla | - cadena de salida de la tabla | #40 NEGRO | #255 BLANCO 104h | FF FF 28 - añadir a la tabla103h 102h | Código entrante encontrado en la tabla | - cadena de salida de la tabla | #255 BLANCO | #255 BLANCO 105h | 28 FF FF - añadir a la tabla106h 103h | Código entrante no encontrado en la tabla 106h | FF FF FF - añadir a la tabla | - cadena de salida de la tabla | #255 BLANCO | #255 BLANCO | #255 BLANCO107h 106h | Código entrante no encontrado en la tabla 107h | FF FF FF FF - añadir a la tabla | - cadena de salida de la tabla | #255 BLANCO | #255 BLANCO | #255 BLANCO | #255 BLANCO101h | Fin

Longitudes de código LZW

Se pueden utilizar longitudes de código más cortas para paletas más pequeñas que los 256 colores del ejemplo. Si la paleta tiene solo 64 colores (por lo que los índices de color tienen 6 bits de ancho), los símbolos pueden variar de 0 a 63, y el ancho del símbolo puede tomarse como 6 bits, con códigos que comienzan en 7 bits. De hecho, el ancho del símbolo no necesita coincidir con el tamaño de la paleta: siempre que los valores decodificados sean siempre menores que el número de colores en la paleta, los símbolos pueden tener cualquier ancho de 2 a 8, y el tamaño de la paleta cualquier potencia de 2 de 2 a 256. Por ejemplo, si solo se utilizan los primeros cuatro colores (valores de 0 a 3) de la paleta, los símbolos pueden tomarse como de 2 bits de ancho con códigos que comienzan en 3 bits.

Por el contrario, el ancho del símbolo podría establecerse en 8, incluso si solo se utilizan los valores 0 y 1; estos datos solo requerirían una tabla de dos colores. Aunque no tendría sentido codificar el archivo de esa manera, algo similar suele ocurrir con las imágenes bicolores: el ancho mínimo del símbolo es 2, incluso si solo se utilizan los valores 0 y 1.

La tabla de códigos contiene inicialmente códigos que son un bit más largos que el tamaño del símbolo para acomodar los dos códigos especiales clr y end y los códigos para cadenas que se agregan durante el proceso. Cuando la tabla está llena, la longitud del código aumenta para dar espacio a más cadenas, hasta un código máximo de 4095 = FFF(hex). A medida que el decodificador construye su tabla, rastrea estos aumentos en la longitud del código y puede descomprimir los bytes entrantes en consecuencia.

GIF sin comprimir

GIF sin comprimir de 46×46 con símbolos de 7 bits (128 colores, códigos de 8 bits).
Haga clic en la imagen para obtener una explicación del código.

El proceso de codificación GIF se puede modificar para crear un archivo sin compresión LZW que aún se pueda ver como una imagen GIF. Esta técnica se introdujo originalmente como una forma de evitar la infracción de patentes. El GIF sin comprimir también puede ser un formato intermedio útil para un programador de gráficos porque los píxeles individuales son accesibles para leer o pintar. Un archivo GIF sin comprimir se puede convertir en un archivo GIF normal simplemente pasándolo por un editor de imágenes.

El método de codificación modificado ignora la creación de la tabla LZW y emite únicamente los códigos de la paleta raíz y los códigos para CLEAR y STOP. Esto produce una codificación más simple (una correspondencia 1 a 1 entre los valores de código y los códigos de paleta) pero sacrifica toda la compresión: cada píxel de la imagen genera un código de salida que indica su índice de color. Al procesar un GIF sin comprimir, no se impedirá que un decodificador GIF estándar escriba cadenas en su tabla de diccionario, pero el ancho del código nunca debe aumentar, ya que eso activa un empaquetamiento diferente de bits a bytes.

Si el ancho del símbolo es n , los códigos de ancho n +1 se dividen naturalmente en dos bloques: el bloque inferior de 2n códigos para codificar símbolos individuales y el bloque superior de 2n códigos que utilizará el decodificador para secuencias de longitud mayor que uno. De ese bloque superior, los dos primeros códigos ya están tomados: 2n para CLEAR y 2n +1 para STOP. También se debe evitar que el decodificador utilice el último código del bloque superior, 2n + 1-1 , porque cuando el decodificador llena esa ranura, aumentará el ancho del código. Por lo tanto, en el bloque superior hay 2n -3 códigos disponibles para el decodificador que no activarán un aumento en el ancho del código. Debido a que el decodificador siempre está un paso por detrás en el mantenimiento de la tabla, no genera una entrada de tabla al recibir el primer código del codificador, sino que generará una para cada código sucesivo. De esta manera, el codificador puede generar 2 n − 2 códigos sin provocar un aumento en el ancho del código. Por lo tanto, el codificador debe emitir códigos CLEAR adicionales a intervalos de 2 n − 2 códigos o menos para hacer que el decodificador restablezca el diccionario de codificación. El estándar GIF permite que dichos códigos CLEAR adicionales se inserten en los datos de la imagen en cualquier momento. El flujo de datos compuesto se divide en subbloques que contienen cada uno de 1 a 255 bytes.

Para la imagen de muestra 3×5 anterior, los siguientes códigos de 9 bits representan "borrar" (100) seguido de los píxeles de la imagen en orden de escaneo y "detener" (101).

100 028 0FF 0FF 0FF 028 0FF 0FF 0FF 0FF 0FF 0FF 0FF 0FF 0FF 0FF 101

Una vez que los códigos anteriores se asignan a bytes, el archivo sin comprimir se diferencia del archivo comprimido de la siguiente manera:

Byte n.° (hexadecimal)HexadecimalTexto o valorSignificado
3201420Siguen 20 bytes de datos de imagen sin comprimir
32100 51 FC FB F7 0F C5 BF 7F FF FE FD FB F7 EF DF BF 7F 01 01
335000Fin de los datos de la imagen

Ejemplo de compresión

El ejemplo trivial de una imagen grande de color sólido demuestra la compresión LZW de longitud variable utilizada en archivos GIF.

Ejemplo de compresión de un archivo GIF
CódigoPíxelesNotas
No.
yo
Valor
Ni + 256
Longitud
(pedazos)
Este código
yo
Acumulado
Ni (Ni + 1 )/2
Las relaciones que utilizan N i solo se aplican a los píxeles del mismo color hasta que la tabla de codificación esté llena.
0100 horas9Borrar tabla de códigos
1Ffh11Color del píxel superior izquierdo elegido como el índice más alto de una paleta de 256 colores
2102 horas23
3
255
103 horas
1FFh
3
255
6
32640
Último código de 9 bits
256
767
200 horas
3FFh
10256
767
32896
294528
Último código de 10 bits
768
1791
400 horas
7FFh
11768
1791
295296
1604736
Último código de 11 bits
1792
3839
800 horas
¡Ay!
121792
3839
1606528
7370880
Tabla de códigos completa
¡Ay!3839El código máximo puede repetirse para más píxeles del mismo color.
La compresión general de datos se aproxima asintóticamente a 3839 × 8/12 = ⁠2559+1/3
101 horasFin de los datos de la imagen

Los valores de código que se muestran se empaquetan en bytes que, a su vez, se empaquetan en bloques de hasta 255 bytes. Un bloque de datos de imagen comienza con un byte que declara la cantidad de bytes que le seguirán. El último bloque de datos de una imagen está marcado por un byte de longitud de bloque cero.

Entrelazado

Captura de pantalla de un GIF entrelazado cargándose en un navegador web

La especificación GIF permite que cada imagen dentro de la pantalla lógica de un archivo GIF especifique que está entrelazada, es decir, que el orden de las líneas de trama en su bloque de datos no es secuencial. Esto permite una visualización parcial de la imagen que se puede reconocer antes de que se pinte la imagen completa.

Una imagen entrelazada se divide de arriba a abajo en tiras de 8 píxeles de alto, y las filas de la imagen se presentan en el siguiente orden:

  • Pase 1: Línea 0 (la línea más alta) de cada tira.
  • Pase 2: Línea 4 de cada tira.
  • Pase 3: Líneas 2 y 6 de cada tira.
  • Pase 4: Líneas 1, 3, 5 y 7 de cada tira.

Los píxeles de cada línea no están entrelazados, sino que se presentan de forma consecutiva de izquierda a derecha. Al igual que con las imágenes no entrelazadas, no hay interrupción entre los datos de una línea y los de la siguiente. El indicador de que una imagen está entrelazada es un bit establecido en el bloque Descriptor de imagen correspondiente.

GIF animado

GIF se puede utilizar para mostrar animación, como en esta imagen de la cuna de Newton .

Aunque GIF no fue diseñado como un medio de animación, su capacidad para almacenar múltiples imágenes en un archivo sugirió naturalmente el uso del formato para almacenar los fotogramas de una secuencia de animación. Para facilitar la visualización de animaciones, la especificación GIF89a agregó la Extensión de Control Gráfico (GCE), que permite que las imágenes (fotogramas) en el archivo se dibujen con retrasos de tiempo, formando un videoclip . Cada fotograma en un GIF de animación se introduce por su propia GCE que especifica el retraso de tiempo que se debe esperar después de que se dibuje el fotograma. La información global al comienzo del archivo se aplica de forma predeterminada a todos los fotogramas. Los datos están orientados a la transmisión, por lo que el desplazamiento del archivo del inicio de cada GCE depende de la longitud de los datos anteriores. Dentro de cada fotograma, los datos de imagen codificados con LZW se organizan en subbloques de hasta 255 bytes; el tamaño de cada subbloque se declara por el byte que lo precede.

De forma predeterminada, una animación muestra la secuencia de fotogramas solo una vez y se detiene cuando se muestra el último fotograma. Para permitir que una animación se repita en bucle, Netscape utilizó en la década de 1990 el bloque de extensión de aplicación (destinado a permitir que los proveedores agregaran información específica de la aplicación al archivo GIF) para implementar el bloque de aplicación Netscape (NAB). [37] Este bloque, colocado inmediatamente antes de la secuencia de fotogramas de la animación, especifica el número de veces que se debe reproducir la secuencia de fotogramas (de 1 a 65535 veces) o que se debe repetir de forma continua (cero indica que se repetirá en bucle para siempre). El soporte para estas animaciones repetidas apareció por primera vez en la versión 2.0 de Netscape Navigator y luego se extendió a otros navegadores. [38] La mayoría de los navegadores ahora reconocen y admiten NAB, aunque no es estrictamente parte de la especificación GIF89a.

El siguiente ejemplo muestra la estructura del archivo de animación Tierra giratoria (grande).gif que se muestra (como miniatura) en el cuadro de información del artículo.

Estructura del GIF
Byte n.° (hexadecimal)HexadecimalTexto o valorSignificado
047 49 46 38 39 61GIF89aDescriptor de pantalla lógica
690 01400Ancho en píxeles
890 01400Altura en píxeles
AF7GCT sigue para 256 colores con resolución 3  ×  8 bits/primario
B000Color de fondo: #000000, negro
do000Relación de aspecto de píxeles predeterminada: 0:0
D00Tabla de colores global
30D21'!'Un bloque de extensión (introducido por un signo de exclamación ASCII '!')
30EFFExtensión de la aplicación
30F0B11Tamaño del bloque que incluye el nombre de la aplicación y los bytes de verificación (siempre 11)
3104E 45 54 53 43 41 50 45 32 2E 30NETSCAPE 2.0Nombre de aplicación de 8 bytes más 3 bytes de verificación
31B033Número de bytes en el siguiente subbloque
31C011Índice del subbloque de datos actual (siempre 1 para el bloque NETSCAPE)
31D¡Ay, ay!65535Número de repeticiones sin signo
31F00Fin de la cadena de subbloques para el bloque de extensión de la aplicación
32021'!'Un bloque de extensión (introducido por un signo de exclamación ASCII '!')
321F9Extensión de control gráfico para el cuadro n.° 1
322044Número de bytes (4) en el subbloque actual
32304
000........001........0........0
(dividido en secciones para facilitar la lectura)
Reservado, los 5 bits inferiores son campos de bits
Método de eliminación 1: no eliminar
Sin entrada de usuario
Color transparente, 0 significa que no se proporciona
32409 009Retraso de cuadro: 0,09 segundos de retraso antes de pintar el siguiente cuadro
326FFÍndice de color transparente (no utilizado en este marco)
32700Fin de la cadena de subbloques para el bloque de extensión de control gráfico
3282C','Un descriptor de imagen (introducido por 0x2C, una coma ASCII ',')
32900 00 00 00(0, 0)Posición de la esquina noroeste de la imagen en la pantalla lógica: (0, 0)
32D90 01 90 01(400, 400)Ancho y alto del marco: 400  ×  400 píxeles
331000Tabla de colores local: 0 significa ninguno y sin entrelazado
332088Tamaño mínimo del código LZW para los datos de imagen del cuadro n.° 1
333FF255Número de bytes de datos de imagen LZW en el siguiente subbloque: 255 bytes
334...<datos de imagen>Datos de imagen, 255 bytes
433FF255Número de bytes de datos de imagen LZW en el siguiente subbloque, 255 bytes
434...<datos de imagen>Datos de imagen, 255 bytes
Repetir para los siguientes bloques
92C000Fin de la cadena de subbloques para este marco
92C121'!'Un bloque de extensión (introducido por un signo de exclamación ASCII '!')
92C2F9Extensión de control gráfico para el cuadro n.° 2
Repetir para los siguientes fotogramas
EDABD21'!'Un bloque de extensión (introducido por un signo de exclamación ASCII '!')
EDABEF9Extensión de control gráfico para el cuadro n.° 44
Información y datos de la imagen del cuadro n.° 44
F48F53BTráiler: Último byte del archivo, que indica EOF

El retardo de animación de cada fotograma se especifica en el GCE en centésimas de segundo. Es posible ahorrar datos cuando un fotograma solo necesita reescribir una parte de los píxeles de la pantalla, ya que el descriptor de imagen puede definir un rectángulo más pequeño para volver a escanearlo en lugar de la imagen completa. Los navegadores u otras pantallas que no admiten GIF animados suelen mostrar solo el primer fotograma.

El tamaño y la calidad del color de los archivos GIF animados pueden variar significativamente según la aplicación que se utilice para crearlos. Las estrategias para minimizar el tamaño de los archivos incluyen el uso de una tabla de colores global común para todos los fotogramas (en lugar de una tabla de colores local completa para cada fotograma) y la minimización del número de píxeles cubiertos en fotogramas sucesivos (de modo que solo los píxeles que cambian de un fotograma al siguiente se incluyan en el último fotograma). Las técnicas más avanzadas implican la modificación de las secuencias de colores para que coincidan mejor con el diccionario LZW existente, una forma de compresión con pérdida . Simplemente empaquetar una serie de imágenes de fotogramas independientes en una animación compuesta tiende a producir archivos de gran tamaño. Hay herramientas disponibles para minimizar el tamaño de archivo dado un GIF existente.

Metadatos

Los metadatos se pueden almacenar en archivos GIF como un bloque de comentarios, un bloque de texto sin formato o un bloque de extensión de aplicación específico de la aplicación. Varios editores de gráficos utilizan bloques de extensión de aplicación no oficiales para incluir los datos utilizados para generar la imagen, de modo que se puedan recuperar para su posterior edición.

Todos estos métodos requieren técnicamente que los metadatos se dividan en subbloques para que las aplicaciones puedan navegar por el bloque de metadatos sin conocer su estructura interna.

El estándar de metadatos Extensible Metadata Platform (XMP) introdujo un bloque de extensión de aplicación no oficial, pero ahora muy extendido, "XMP Data", para incluir datos XMP en archivos GIF. [39] Dado que los datos XMP se codifican utilizando UTF-8 sin caracteres NUL, no hay bytes 0 en los datos. En lugar de dividir los datos en subbloques formales, el bloque de extensión termina con un "truco mágico" que enruta cualquier aplicación que trate los datos como subbloques a un byte 0 final que termina la cadena de subbloques.

Cumplimiento de patentes de Unisys y LZW

En 1977 y 1978, Jacob Ziv y Abraham Lempel publicaron un par de artículos sobre una nueva clase de algoritmos de compresión de datos sin pérdida, ahora denominados colectivamente LZ77 y LZ78 . En 1983, Terry Welch desarrolló una variante rápida de LZ78 que se denominó Lempel–Ziv–Welch (LZW). [40] [41]

Welch presentó una solicitud de patente para el método LZW en junio de 1983. La patente resultante, US4558302, [42] concedida en diciembre de 1985, fue asignada a Sperry Corporation, que posteriormente se fusionó con Burroughs Corporation en 1986 y formó Unisys . [40] Se obtuvieron otras patentes en el Reino Unido, Francia, Alemania, Italia, Japón y Canadá.

Además de las patentes mencionadas anteriormente, la patente de Welch de 1983 también incluye citas de varias otras patentes que la influyeron, entre ellas:

  • dos patentes japonesas de 1980 de Jun Kanatsu de NEC , [43] [44]
  • Patente estadounidense 4.021.782 (1974) de John S. Hoerning,
  • Patente estadounidense 4.366.551 (1977) de Klaus E. Holtz, y
  • una patente alemana de 1981 de Karl Eckhart Heinz. [45] [46]

En junio de 1984, se publicó un artículo de Welch en la revista IEEE que describía públicamente la técnica LZW por primera vez. [47] LZW se convirtió en una técnica de compresión de datos popular y, cuando se concedió la patente, Unisys firmó acuerdos de licencia con más de cien empresas. [40] [48]

La popularidad de LZW llevó a CompuServe a elegirla como técnica de compresión para su versión de GIF, desarrollada en 1987. En ese momento, CompuServe no conocía la patente. [40] Unisys se enteró de que la versión de GIF utilizaba la técnica de compresión LZW y entabló negociaciones de licencia con CompuServe en enero de 1993. El acuerdo posterior se anunció el 24 de diciembre de 1994. [41] Unisys declaró que esperaba que todas las principales empresas de servicios de información en línea comerciales que emplearan la patente LZW obtuvieran la licencia de la tecnología de Unisys a una tasa razonable, pero que no exigirían licencias ni el pago de tasas para aplicaciones basadas en GIF no comerciales y sin fines de lucro, incluidas las que se utilizarían en los servicios en línea. [48]

Tras este anuncio, hubo una condena generalizada de CompuServe y Unisys, y muchos desarrolladores de software amenazaron con dejar de utilizar GIF. El formato PNG (ver más abajo) se desarrolló en 1995 como un reemplazo previsto. [40] [41] [47] Sin embargo, obtener el apoyo de los fabricantes de navegadores web y otro software para el formato PNG resultó difícil y no fue posible reemplazar a GIF, aunque PNG ha aumentado gradualmente en popularidad. [40] Por lo tanto, se desarrollaron variaciones de GIF sin compresión LZW. Por ejemplo, la biblioteca libungif, basada en giflib de Eric S. Raymond , permite la creación de GIF que seguían el formato de datos pero evitaban las funciones de compresión, evitando así el uso de la patente LZW de Unisys. [49] Un artículo del Dr. Dobb de 2001 describió una forma de lograr una codificación compatible con LZW sin infringir sus patentes. [50]

En agosto de 1999, Unisys cambió los detalles de su práctica de licencias, anunciando la opción para los propietarios de ciertos sitios web no comerciales y privados de obtener licencias mediante el pago de una tarifa única de licencia de $5000 o $7500. [51] Dichas licencias no eran necesarias para los propietarios de sitios web u otros usuarios de GIF que habían utilizado software con licencia para generar GIF. Sin embargo, Unisys fue objeto de miles de ataques en línea y correos electrónicos abusivos de usuarios que creían que se les iba a cobrar $5000 o demandar por usar GIF en sus sitios web. [52] A pesar de otorgar licencias gratuitas a cientos de organizaciones sin fines de lucro, escuelas y gobiernos, Unisys fue completamente incapaz de generar ninguna buena publicidad y continuó siendo condenada por individuos y organizaciones como la Liga para la Libertad de Programación que inició la campaña "Burn All GIFs" en 1999. [53] [54]

La patente estadounidense de LZW expiró el 20 de junio de 2003. [55] Las patentes equivalentes en el Reino Unido, Francia, Alemania e Italia expiraron el 18 de junio de 2004, las patentes japonesas expiraron el 20 de junio de 2004 y la patente canadiense expiró el 7 de julio de 2004. [55] En consecuencia, si bien Unisys tiene más patentes y solicitudes de patentes relacionadas con mejoras a la técnica LZW, [55] la propia LZW (y en consecuencia GIF) han sido libres de usar desde julio de 2004. [56]

Alternativas

PNG

Portable Network Graphics (PNG) fue diseñado como reemplazo de GIF para evitar la infracción de la patente de Unisys sobre la técnica de compresión LZW. [40] PNG ofrece una mejor compresión y más funciones que GIF, [57] siendo la animación la única excepción significativa. PNG es más adecuado que GIF en casos en los que se requieren imágenes con colores verdaderos y transparencia alfa .

Aunque el soporte para el formato PNG llegó lentamente, los nuevos navegadores web admiten PNG. Las versiones anteriores de Internet Explorer no admiten todas las características de PNG. Las versiones 6 y anteriores no admiten la transparencia del canal alfa sin utilizar extensiones HTML específicas de Microsoft. [58] La corrección gamma de las imágenes PNG no era compatible antes de la versión 8, y la visualización de estas imágenes en versiones anteriores puede tener un tono incorrecto. [59]

Para datos de imágenes idénticos de 8 bits (o menos), los archivos PNG suelen ser más pequeños que los GIF equivalentes, debido a las técnicas de compresión más eficientes utilizadas en la codificación PNG. [60] El soporte completo para GIF se complica principalmente por la compleja estructura de lienzo que permite, aunque esto es lo que habilita las funciones de animación compactas.

Formatos de animación

Los videos resuelven muchos de los problemas que presentan los GIF a través de su uso común en la web. Entre ellos, se incluyen tamaños de archivo drásticamente más pequeños , la capacidad de superar la restricción de color de 8 bits y un mejor manejo y compresión de fotogramas mediante la codificación entre fotogramas . El soporte prácticamente universal para el formato GIF en los navegadores web y la falta de soporte oficial para el video en el estándar HTML hicieron que el GIF cobrara importancia con el propósito de mostrar archivos cortos similares a videos en la web.

  • MNG ("Multiple-image Network Graphics") se desarrolló originalmente como una solución basada en PNG para animaciones. MNG alcanzó la versión 1.0 en 2001, pero pocas aplicaciones lo admiten.
  • APNG ("Animated Portable Network Graphics") fue propuesto por Mozilla en 2006. APNG es una extensión del formato PNG como alternativa al formato MNG. APNG es compatible con la mayoría de los navegadores a partir de 2019. [61] APNG proporciona la capacidad de animar archivos PNG, al tiempo que conserva la compatibilidad con versiones anteriores en decodificadores que no pueden comprender el fragmento de animación (a diferencia de MNG). Los decodificadores más antiguos simplemente renderizarán el primer fotograma de la animación.
El grupo de Papúa Nueva Guinea rechazó oficialmente la APNG como extensión oficial el 20 de abril de 2007. [62]
Ha habido varias propuestas posteriores para un formato de gráficos animados simple basado en PNG utilizando varios enfoques diferentes. [63] Sin embargo, APNG aún está en desarrollo por Mozilla y es compatible con Firefox 3.0 [64] [65] mientras que se abandonó la compatibilidad con MNG. [66] [67] APNG actualmente es compatible con todos los navegadores web principales, incluidos Chrome (desde la versión 59.0), Opera, Firefox y Edge.
  • En algunos sitios web se utilizaban objetos Adobe Flash y archivos MPEG integrados para mostrar vídeos sencillos, pero era necesario utilizar un complemento de navegador adicional.
  • WebM y WebP están en desarrollo y son compatibles con algunos navegadores web. [68]
  • Otras opciones para la animación web incluyen servir cuadros individuales usando AJAX , o animar imágenes SVG ("Gráficos vectoriales escalables") usando JavaScript o SMIL ("Lenguaje de integración multimedia sincronizada"). [69]
  • Con la introducción de la compatibilidad generalizada de la etiqueta de video HTML ( <video>) en la mayoría de los navegadores web, algunos sitios web utilizan una versión en bucle de la etiqueta de video generada por funciones de JavaScript . Esto da la apariencia de un GIF, pero con las ventajas de tamaño y velocidad del video comprimido.
Ejemplos notables son Gfycat e Imgur y su metaformato GIFV, que es en realidad una etiqueta de vídeo que reproduce un vídeo comprimido en formato MP4 o WebM en bucle . [70]
En comparación con el formato GIF, que carece de compresión DCT, HEIF permite una compresión significativamente más eficiente. HEIF almacena más información y produce imágenes animadas de mayor calidad en una pequeña fracción del tamaño de un GIF equivalente. [72]

Usos

En abril de 2014, 4chan agregó soporte para videos WebM silenciosos de menos de 3 MB de tamaño y 2 minutos de duración, [74] [75] y en octubre de 2014, Imgur comenzó a convertir cualquier archivo GIF cargado al sitio a video H.264 y a darle al enlace al reproductor HTML la apariencia de un archivo real con una .gifvextensión. [76] [77]

En enero de 2016, Telegram comenzó a recodificar todos los GIF a videos MPEG-4 que "requieren hasta un 95% menos de espacio en disco para la misma calidad de imagen". [78]

Véase también

Referencias

  1. ^ abc «Graphics Interchange Format, Version 87a». W3C . 15 de junio de 1987. Archivado desde el original el 22 de diciembre de 2018 . Consultado el 13 de octubre de 2012 .
  2. ^ abc «Graphics Interchange Format, Version 89a». W3C . 31 de julio de 1990. Archivado desde el original el 22 de diciembre de 2018 . Consultado el 6 de marzo de 2009 .
  3. ^ Tiffany, Kaitlyn (7 de octubre de 2022). "El GIF está en su lecho de muerte". The Atlantic . Consultado el 21 de octubre de 2023 .
  4. ^ "Arte en línea". Aplicaciones Apple de Compute!. Diciembre de 1987. pág. 10. Consultado el 14 de septiembre de 2016 .
  5. ^ Holdener III, Anthony (2008). Ajax: La guía definitiva: aplicaciones interactivas para la Web . O'Reilly Media. ISBN 978-0596528386.
  6. ^ Furht, Borko (2008). Enciclopedia de Multimedia . Saltador. ISBN 978-0387747248.
  7. ^ McHugh, Molly (29 de mayo de 2015). "Por fin puedes publicar GIFs en Facebook de verdad". Wired . Archivado desde el original el 30 de mayo de 2015. Consultado el 29 de mayo de 2015 .
  8. ^ Perez, Sarah (29 de mayo de 2015). «Facebook confirma que admitirá oficialmente GIF». TechCrunch . Archivado desde el original el 30 de mayo de 2015. Consultado el 29 de mayo de 2015 .
  9. ^ "Presentamos los GIF Stickers". Instagram . 23 de enero de 2018. Archivado desde el original el 12 de diciembre de 2019 . Consultado el 19 de septiembre de 2019 .
  10. ^ "Palabra del año 2012 de Oxford Dictionaries USA". Blog de OxfordWords . Oxford American Dictionaries. 13 de noviembre de 2012. Archivado desde el original el 3 de agosto de 2014. Consultado el 1 de mayo de 2013 .
  11. ^ Flood, Alison (27 de abril de 2013). «¿Gif es la palabra del año en Estados Unidos? Eso sí que es un desastre». Blog de libros. The Guardian . Londres. Archivado desde el original el 1 de diciembre de 2016. Consultado el 1 de mayo de 2013 .
  12. ^ Olsen, Steve. «La página de pronunciación de GIF». Archivado desde el original el 25 de febrero de 2009. Consultado el 6 de marzo de 2009 .
  13. ^ abc "El inventor del GIF dice que ignoremos los diccionarios y digamos 'Jif'". BBC News . 22 de mayo de 2013. Archivado desde el original el 27 de junio de 2018 . Consultado el 22 de mayo de 2013 .
  14. ^ Buck, Stephanie (21 de octubre de 2014). «El 70 por ciento de las personas en todo el mundo pronuncia GIF con g dura». Mashable . Archivado desde el original el 23 de diciembre de 2021 . Consultado el 24 de diciembre de 2021 .
  15. ^ van der Meulen, Marten (22 de mayo de 2019). «Obama, SCUBA o regalo?: Autoridad y argumentación en la discusión en línea sobre la pronunciación de GIF». English Today . 36 (1): 45–50. Archivado desde el original el 24 de mayo de 2022 . Consultado el 22 de mayo de 2022 .
  16. ^ "GIF". Diccionario de abreviaturas de la herencia estadounidense, tercera edición . Houghton Mifflin Company. 2005. Archivado desde el original el 3 de septiembre de 2011. Consultado el 15 de abril de 2007 .
  17. ^ "GIF". Diccionario Cambridge de inglés americano . Cambridge University Press. Archivado desde el original el 27 de febrero de 2014. Consultado el 19 de febrero de 2014 .
  18. ^ "Gif - Definición del Diccionario Merriam-Webster". Diccionario Merriam-Webster . Merriam-Webster, Incorporated. Archivado desde el original el 22 de octubre de 2013 . Consultado el 6 de junio de 2013 .
  19. ^ "GIF". Oxford Dictionaries Online . Oxford University Press. Archivado desde el original el 12 de octubre de 2014 . Consultado el 7 de octubre de 2014 .
  20. ^ "gif sustantivo - Definición, imágenes, pronunciación y notas de uso | Oxford Advanced Learner's Dictionary". Oxford Learner's Dictionaries . Archivado desde el original el 24 de noviembre de 2020. Consultado el 6 de febrero de 2021 .
  21. ^ "GIF | Definición de GIF según el Diccionario Oxford". Lexico . Archivado desde el original el 13 de febrero de 2021 . Consultado el 6 de febrero de 2021 .
  22. ^ Stevenson, Angus, ed. (2010). Oxford Dictionary of English (3.ª ed.). Oxford University Press. ISBN 9780199571123. OCLC  729551189. Archivado desde el original el 23 de agosto de 2022 . Consultado el 6 de febrero de 2021 .
  23. ^ The New Oxford American Dictionary (2.ª ed.). Oxford University Press. 2005. pág. 711.
  24. ^ El nuevo diccionario americano de Oxford (3.ª ed.). 2012.(parte de los diccionarios integrados de Macintosh).
  25. ^ O'Leary, Amy (21 de mayo de 2013). «Un honor para el creador del GIF». The New York Times . Archivado desde el original el 22 de mayo de 2013. Consultado el 22 de mayo de 2013 .
  26. ^ ab Rothberg, Daniel (4 de diciembre de 2013). «'Jeopardy' entra en la batalla de la pronunciación de 'GIF'». Los Angeles Times . Archivado desde el original el 6 de diciembre de 2013. Consultado el 4 de diciembre de 2013 .
  27. ^ O'Leary, Amy (23 de mayo de 2013). "Estalla la batalla por la pronunciación de 'GIF'". The New York Times . Archivado desde el original el 16 de diciembre de 2013. Consultado el 5 de diciembre de 2013 .
  28. ^ Valinsky, Jordan (25 de febrero de 2020). "Jif resuelve el gran debate con un tarro de mantequilla de maní GIF". CNN . Archivado desde el original el 25 de febrero de 2020. Consultado el 25 de febrero de 2020 .
  29. ^ Marur, DR; Bhaskar, V. (marzo de 2012). "Conferencia internacional sobre dispositivos, circuitos y sistemas (ICDCS) de 2012". Dispositivos, circuitos y sistemas (ICDCS) . Conferencia internacional sobre dispositivos, circuitos y sistemas (ICDCS). Universidad Karunya; Coimbatore, India: IEEE. págs. 297–301. doi :10.1109/ICDCSyst.2012.6188724. ISBN 9781457715457Archivado desde el original el 2 de julio de 2017 . Consultado el 11 de marzo de 2015 .
  30. ^ S. barbilla; D. Iverson; O. Campesato; P. Trani (2011). Flash profesional de Android (PDF) . Nueva York: Apress. pag. 350.ISBN 9781430232315. Archivado (PDF) del original el 2 de abril de 2015 . Consultado el 11 de marzo de 2015 .
  31. ^ Bakhshi, Saeideh; Shamma, David A.; Kennedy, Lyndon; Song, Yale; de ​​Juan, Paloma; Kaye, Joseph "Jofish" (7 de mayo de 2016). "Rápido, barato y bueno: por qué nos atraen los GIF animados". Actas de la Conferencia CHI de 2016 sobre factores humanos en sistemas informáticos . págs. 575–586. doi :10.1145/2858036.2858532. ISBN 9781450333627. S2CID  7417853 . Consultado el 17 de agosto de 2022 .
  32. ^ Highfield, Tim; Leaver, Tama (2016). «Instagrammatics and digital methods: studying visual social media, from selfies and GIFs to memes and emoji». Investigación y práctica en comunicación . 2 (1): 47–62. doi :10.1080/22041451.2016.1155332. hdl : 20.500.11937/36939 . S2CID :  148538216. Consultado el 17 de agosto de 2022 .
  33. ^ abc Andreas Kleinert (2007). «Extensiones GIF de 24 bits (color verdadero)». Archivado desde el original el 16 de marzo de 2012. Consultado el 23 de marzo de 2012 .
  34. ^ de Philip Howard. "Ejemplo de GIF en color verdadero". Archivado desde el original el 22 de febrero de 2015. Consultado el 23 de marzo de 2012 .
  35. ^ "Nullsleep - Jeremiah Johnson - Estudio de compatibilidad de navegadores con retraso mínimo de cuadros por segundo para GIF animados". Archivado desde el original el 10 de octubre de 2014 . Consultado el 26 de mayo de 2015 .
  36. ^ "¡Son diferentes! Cómo hacer coincidir la velocidad de animación de los archivos gif en los distintos navegadores". Blog del desarrollador . 14 de febrero de 2012. Archivado desde el original el 1 de febrero de 2017. Consultado el 15 de junio de 2017 .
  37. ^ Royal Frazier. «Todo sobre GIF89a». Archivado desde el original el 18 de abril de 1999. Consultado el 7 de enero de 2013 .
  38. ^ Scott Walter (1996). Armas secretas de la programación web . Que Publishing . ISBN 0-7897-0947-3.
  39. ^ "XMP Specification Part 3: Storage in Files" (PDF) . Adobe. 2016. págs. 11-12. Archivado (PDF) desde el original el 25 de febrero de 2018 . Consultado el 16 de agosto de 2018 .
  40. ^ abcdefg Greg Roelofs. «Historia del formato Portable Network Graphics (PNG)». Archivado desde el original el 7 de marzo de 2012. Consultado el 23 de marzo de 2012 .
  41. ^ abc Stuart Caie. "Día triste... la patente de GIF murió a los 20 años". Archivado desde el original el 10 de febrero de 2012 . Consultado el 23 de marzo de 2012 .
  42. ^ US 4558302, Welch, Terry A. , publicada el 10 de diciembre de 1985, asignada a Sperry Corp. 
  43. ^ Patente JP S5719857A, Kanatsu, Jiyun, "Dispositivo de almacenamiento de compresión de datos", publicada el 2 de febrero de 1982, asignada a Nippon Electric Corp. 
  44. ^ Patente JP S57101937A, Kanatsu, Jiyun, "Dispositivo de almacenamiento de datos", publicada el 24 de febrero de 1986, asignada a Nippon Electric Corp. 
  45. ^ Patente DE 3118676, Eckhart, Heinz Karl, "Verfahren zur Kompression redundanter Folgen serieller Datenelemente [Método para comprimir secuencias redundantes de elementos de datos en serie]", publicado el 2 de diciembre de 1982 
  46. ^ Patente estadounidense 4.558.302
  47. ^ ab "La controversia GIF: la perspectiva de un desarrollador de software". 27 de enero de 1995. Archivado desde el original el 23 de agosto de 2016 . Consultado el 26 de mayo de 2015 .
  48. ^ ab "Unisys aclara la política sobre el uso de patentes en la oferta de servicios en línea". Archivado desde el original el 7 de febrero de 2007.– archivado por la Liga para la Libertad de Programación
  49. ^ "Libungif". Archivado desde el original el 13 de abril de 2015 . Consultado el 26 de mayo de 2015 .
  50. ^ Cargill, Tom (1 de octubre de 2001). «Reemplazar un diccionario por una raíz cuadrada». Diario del Dr. Dobb . Archivado desde el original el 28 de junio de 2017. Consultado el 20 de enero de 2017 .
  51. ^ "Información sobre software y patentes de LZW". Archivado desde el original el 8 de junio de 2009. Consultado el 31 de enero de 2007 .– aclaración de 2 de septiembre de 1999
  52. ^ Unisys no demanda a (la mayoría de) los webmasters por usar GIF Archivado el 10 de mayo de 2017 en Wayback Machine – Investigación de Slashdot sobre la controversia
  53. ^ "Día de quemar todos los GIF". Archivado desde el original el 13 de octubre de 1999.
  54. ^ Grabar todos los GIF Archivado el 3 de febrero de 2007 en Wayback Machine – Un proyecto de la Liga para la Libertad de Programación (última versión)
  55. ^ abc "Información sobre licencias de GIF y otras tecnologías basadas en LZW". Archivado desde el original el 2 de junio de 2009. Consultado el 26 de abril de 2005 .
  56. ^ "Por qué no hay archivos GIF en las páginas web de GNU". Free Software Foundation. Archivado desde el original el 19 de mayo de 2012. Consultado el 19 de mayo de 2012 .
  57. ^ "Compresión PNG versus compresión GIF". 31 de marzo de 2007. Archivado desde el original el 15 de julio de 2009. Consultado el 8 de junio de 2009 .
  58. ^ "Filtro AlphaImageLoader". Microsoft. 4 de septiembre de 2012. Archivado desde el original el 3 de octubre de 2014. Consultado el 26 de mayo de 2015 .
  59. ^ "Novedades de Internet Explorer 7". MSDN . Archivado desde el original el 1 de marzo de 2009 . Consultado el 6 de marzo de 2009 .
  60. ^ "Formato de archivo de imagen PNG". Archivado desde el original el 14 de junio de 2009. Consultado el 8 de junio de 2009 .
  61. ^ "¿Puedo usar... Tablas de soporte para HTML5, CSS3, etc." caniuse.com . Archivado desde el original el 19 de febrero de 2018 . Consultado el 10 de abril de 2020 .
  62. ^ "VOTACIÓN FALLIDA: APNG 20070405a". Lista de correo de SourceForge . 20 de abril de 2007. Archivado desde el original el 13 de febrero de 2013. Consultado el 14 de julio de 2013 .
  63. ^ "Discusión sobre un formato PNG "animado" simple". Archivado desde el original el 26 de febrero de 2009. Consultado el 12 de julio de 2011 .
  64. ^ "Especificación APNG". Archivado desde el original el 5 de julio de 2010. Consultado el 26 de mayo de 2015 .
  65. ^ "Mozilla Labs » Blog Archive » Mejores animaciones en Firefox 3". 13 de agosto de 2007. Archivado desde el original el 7 de marzo de 2016 . Consultado el 3 de febrero de 2016 .
  66. ^ "195280 – Eliminación del soporte de MNG/JNG". Archivado desde el original el 25 de febrero de 2021 . Consultado el 26 de mayo de 2015 .
  67. ^ «18574 – (mng) Restablecer compatibilidad con el formato de animación MNG y el formato de imagen JNG». Archivado desde el original el 17 de marzo de 2021 . Consultado el 26 de mayo de 2015 .
  68. ^ "Blog de Chromium: Chrome 32 Beta: Imágenes WebP animadas y entrada táctil más rápida en Chrome para Android". Blog.chromium.org. 21 de noviembre de 2013. Archivado desde el original el 17 de julio de 2018. Consultado el 1 de febrero de 2014 .
  69. ^ Calou, Juan. "Animación SVG: una guía". Toptal . Consultado el 15 de marzo de 2024 .
  70. ^ "Presentación de GIFV - Blog de Imgur". imgur.com. 9 de octubre de 2014. Archivado desde el original el 14 de diciembre de 2014 . Consultado el 14 de diciembre de 2014 .
  71. ^ Thomson, Gavin; Shah, Athar (2017). "Introducción a HEIF y HEVC" (PDF) . Apple Inc. Archivado (PDF) del original el 19 de enero de 2020 . Consultado el 5 de agosto de 2019 .
  72. ^ "Comparación HEIF: formato de archivo de imagen de alta eficiencia". Nokia Technologies . Archivado desde el original el 25 de julio de 2019 . Consultado el 5 de agosto de 2019 .
  73. ^ "#3271 (Permitir el uso de formatos de píxeles adicionales con libvpx-vp9) – FFmpeg". trac.ffmpeg.org . Archivado desde el original el 16 de junio de 2020 . Consultado el 10 de abril de 2020 .
  74. ^ Dewey, Caitlin. «Conozca la tecnología que podría dejar obsoletos los GIF». The Washington Post . Archivado desde el original el 11 de mayo de 2015. Consultado el 4 de febrero de 2015 .
  75. ^ "Soporte de WebM en 4chan". Blog de 4chan . Archivado desde el original el 6 de abril de 2014. Consultado el 4 de febrero de 2015 .
  76. ^ "Presentación de GIFV". Imgur. 9 de agosto de 2014. Archivado desde el original el 5 de mayo de 2020. Consultado el 21 de julio de 2016 .
  77. ^ Allan, Patrick (9 de octubre de 2014). "Imgur renueva los GIF para lograr velocidades más rápidas y una mayor calidad con GIFV". Lifehacker . Archivado desde el original el 3 de febrero de 2015 . Consultado el 4 de febrero de 2015 .
  78. ^ "Revolución GIF". Blog oficial de Telegram . 4 de enero de 2016. Archivado desde el original el 10 de enero de 2016. Consultado el 4 de enero de 2016 .
  • El proyecto GIFLIB
  • spec-gif89a.txt Especificación GIF 89a en w3.org
  • Especificación GIF 89a reformateada en HTML
  • Explicación de LZW y GIF
  • GIF animados: un documental de seis minutos producido por Off Book (serie web)
  • GifCities (el motor de búsqueda de GIF animados de GeoCities)
Obtenido de "https://es.wikipedia.org/w/index.php?title=GIF&oldid=1251958406"