SVG

format_list_bulleted Contenido keyboard_arrow_down
ImprimirCitar
estándar abierto para gráficos vectoriales bidimensionales

Gráficos vectoriales escalables (SVG) es un formato de imagen vectorial basado en XML para definir gráficos bidimensionales, con soporte para interactividad y animación. La especificación SVG es un estándar abierto desarrollado por el World Wide Web Consortium desde 1999.

Las imágenes SVG se definen en un formato de gráficos vectoriales y se almacenan en archivos de texto XML. Por lo tanto, las imágenes SVG se pueden escalar en tamaño sin pérdida de calidad, y los archivos SVG se pueden buscar, indexar, codificar y comprimir. Los archivos de texto XML pueden crearse y editarse con editores de texto o editores de gráficos vectoriales, y son renderizados por los navegadores web más utilizados.

Resumen

Esta imagen ilustra la diferencia entre bitmap y imágenes vectoriales. La imagen bitmap se compone de un conjunto fijo de píxeles, mientras que la imagen vectorial se compone de un conjunto fijo de formas. En la imagen, escalar el bitmap revela los píxeles mientras escala la imagen vectorial preserva las formas.

SVG ha estado en desarrollo dentro del World Wide Web Consortium (W3C) desde 1999 después de que seis propuestas competitivas para lenguajes de gráficos vectoriales se presentaran al consorcio durante 1998 (ver más abajo).

El primer grupo de trabajo de SVG decidió no desarrollar ninguno de los envíos comerciales, sino crear un nuevo lenguaje de marcado que se basara en ninguno de ellos, pero que no se basara realmente en ellos.

SVG permite tres tipos de objetos gráficos: formas de gráficos vectoriales (como rutas que consisten en líneas rectas y curvas), imágenes de mapa de bits y texto. Los objetos gráficos se pueden agrupar, diseñar, transformar y componer en objetos previamente renderizados. El conjunto de funciones incluye transformaciones anidadas, trazados de recorte, máscaras alfa, efectos de filtro y objetos de plantilla. Los dibujos SVG pueden ser interactivos y pueden incluir animación, definida en los elementos SVG XML o mediante secuencias de comandos que acceden al Modelo de Objetos de Documento (DOM) SVG. SVG usa CSS para diseñar y JavaScript para secuencias de comandos. El texto, incluidas la internacionalización y la localización, que aparece en texto sin formato dentro del SVG DOM, mejora la accesibilidad de los gráficos SVG.

La especificación SVG se actualizó a la versión 1.1 en 2011. Hay dos 'Perfiles SVG móviles' SVG Tiny y SVG Basic, destinados a dispositivos móviles con capacidades computacionales y de visualización reducidas. Scalable Vector Graphics 2 se convirtió en una recomendación candidata del W3C el 15 de septiembre de 2016. SVG 2 incorpora varias características nuevas además de las de SVG 1.1 y SVG Tiny 1.2.

Impresión

Aunque la especificación SVG se centra principalmente en el lenguaje de marcado de gráficos vectoriales, su diseño incluye las funciones básicas de un lenguaje de descripción de páginas como el PDF de Adobe. Contiene disposiciones para gráficos enriquecidos y es compatible con CSS para fines de diseño. SVG tiene la información necesaria para colocar cada glifo e imagen en una ubicación elegida en una página impresa.

Guión y animación

Los dibujos SVG pueden ser dinámicos e interactivos. Las modificaciones de los elementos basadas en el tiempo se pueden describir en SMIL o se pueden programar en un lenguaje de secuencias de comandos (por ejemplo, JavaScript). El W3C recomienda explícitamente SMIL como estándar para la animación en SVG.

Se puede asignar un amplio conjunto de controladores de eventos como "onmouseover" y "onclick" a cualquier objeto gráfico SVG para aplicar acciones y eventos.

Compresión

Las imágenes SVG, al ser XML, contienen muchos fragmentos de texto repetidos, por lo que son adecuadas para los algoritmos de compresión de datos sin pérdidas. Cuando una imagen SVG se comprimió con el algoritmo gzip, se denomina "SVGZ" imagen y usa la extensión de nombre de archivo .svgz correspondiente. Los visores que cumplan con SVG 1.1 mostrarán imágenes comprimidas. Un archivo SVGZ suele tener entre un 20 y un 50 por ciento del tamaño original. W3C proporciona archivos SVGZ para probar la conformidad.

Historial de desarrollo

SVG fue desarrollado por el W3C SVG Working Group a partir de 1998, después de que se recibieron seis presentaciones de gráficos vectoriales de la competencia ese año:

  • Web Schematics, from CCLRC
  • PGML, de Adobe Systems, IBM, Netscape y Sun Microsystems
  • VML, por Autodesk, Hewlett-Packard, Macromedia, Microsoft y Vision
  • Hiper Graphics Markup Language (HGML), por Orange UK y PRP
  • WebCGM, de Boeing, InterCAP Graphics Systems, Inso Corporation, CCLRC y Xerox
  • DrawML, de Excosoft AB

El grupo de trabajo estaba presidido en ese momento por Chris Lilley del W3C.

Versión 1.x

  • SVG 1.0 se convirtió en una recomendación W3C el 4 de septiembre de 2001.
  • SVG 1.1 se convirtió en una recomendación W3C el 14 de enero de 2003. La especificación SVG 1.1 se modulariza para permitir que los subconjuntos se definan como perfiles. Aparte de esto, hay muy poca diferencia entre SVG 1.1 y SVG 1.0.
    • SVG Tiny and SVG Basic (the Mobile SVG Profiles) became W3C Recommendations on 14 January 2003. Se describen como perfiles de SVG 1.1.
  • SVG Tiny 1.2 se convirtió en una recomendación W3C el 22 de diciembre de 2008. Inicialmente fue redactado como un perfil del SVG Full 1.2 (que desde entonces ha sido retirado a favor de SVG 2), pero fue posteriormente refactorizado como una especificación independiente. Por lo general, es mal apoyado.
  • SVG 1.1 Second Edition, which includes all the errata and clarifications, but no new features to the original SVG 1.1 was released on 16 August 2011.
  • SVG Tiny 1.2 Portable/Secure, Un subconjunto más seguro del perfil SVG Tiny 1.2 presentado como un proyecto de norma IETF el 29 de julio de 2020. También conocido como SVG Tiny P/S. SVG Tiny 1.2 Portable/Secure es un requisito del proyecto de estándar BIMI.

Versión 2

SVG 2 elimina o descarta algunas funciones de SVG 1.1 e incorpora nuevas funciones de HTML5 y Web Open Font Format:

  • Por ejemplo, SVG 2 elimina varios elementos de fuentes como glyph y altGlyph (sustituida por el formato de fuente WOFF).
  • El xml:space atributo es deprecado a favor de CSS.
  • Características HTML5 tales como translate y data-* atributos se han añadido.
  • Las características de manejo de texto de SVG Tiny 1.2 están anotadas en cuanto a ser incluidas, pero aún no formalizadas en texto. Algunas otras 1.2 características son la cereza seleccionada, pero SVG 2 no es un superset de SVG pequeña 1.2 en general.

SVG 2 alcanzó la etapa de Candidato a recomendación el 15 de septiembre de 2016, y las versiones revisadas se publicaron el 7 de agosto de 2018 y el 4 de octubre de 2018. El último borrador se publicó el 21 de marzo de 2022.

Perfiles móviles

Debido a la demanda de la industria, se introdujeron dos perfiles móviles con SVG 1.1: SVG Tiny (SVGT) y SVG Basic (SVGB).

Estos son subconjuntos del estándar SVG completo, destinados principalmente a agentes de usuario con capacidades limitadas. En particular, SVG Tiny se definió para dispositivos móviles altamente restringidos, como teléfonos celulares; no admite estilos ni secuencias de comandos. SVG Basic se definió para dispositivos móviles de nivel superior, como los teléfonos inteligentes.

En 2003, 3GPP, un grupo internacional de estándares de telecomunicaciones, adoptó SVG Tiny como el formato multimedia de gráficos vectoriales obligatorio para los teléfonos de próxima generación. SVGT es el formato de gráficos vectoriales requerido y la compatibilidad con SVGB es opcional para el servicio de mensajería multimedia (MMS) y el servicio de transmisión por paquetes conmutados. Más tarde se agregó como formato requerido para gráficos vectoriales en 3GPP IP Multimedia Subsystem (IMS).

Diferencias con SVG no móvil

Ninguno de los perfiles móviles incluye soporte para el modelo de objeto de documento (DOM) completo, mientras que solo SVG básico tiene soporte opcional para secuencias de comandos, pero debido a que son subconjuntos totalmente compatibles del estándar completo, la mayoría de los gráficos SVG todavía pueden ser renderizados por dispositivos que solo es compatible con los perfiles móviles.

SVGT 1.2 agrega un microDOM (μDOM), estilo y secuencias de comandos.

Trabajo relacionado

El estándar MPEG-4 Parte 20 - Representación de escena de aplicación ligera (LASeR) y formato de agregación simple (SAF) se basa en SVG Tiny. Fue desarrollado por MPEG (ISO/IEC JTC 1/SC29/WG11) y publicado como ISO/IEC 14496-20:2006. Las capacidades de SVG se mejoran en MPEG-4 Parte 20 con características clave para servicios móviles, como actualizaciones dinámicas, codificación binaria, representación de fuentes de última generación. SVG también se acomodó en MPEG-4 Parte 11, en el formato Extensible MPEG-4 Textual (XMT), una representación textual del contenido multimedia MPEG-4 usando XML.

Funcionalidad

La especificación SVG 1.1 define 14 áreas funcionales o conjuntos de características:

Senderos
Los contornos de forma simples o compuestos se dibujan con líneas curvas o rectas que se pueden rellenar, esbozar o usar como una ruta de recorte. Los caminos tienen una codificación compacta.
Por ejemplo, M (para "move to") precede la numérica inicial x y Sí. coordenadas, y L (para "línea a") precede un punto al que debe dibujarse una línea. Otras cartas de mando (C, S, Q, T, y A) precede datos que se utilizan para dibujar varias curvas Bézier y elípticas. Z se utiliza para cerrar un camino.
En todos los casos, las coordenadas absolutas siguen los comandos mayúsculas y las coordenadas relativas se utilizan después de las letras mayúsculas equivalentes.
Formas básicas
Se pueden dibujar caminos y caminos rectos formados por una serie de segmentos conectados de línea recta (polylines), así como polígonos cerrados, círculos y elipses. Los rectángulos y rectángulos redondeados también son elementos estándar.
Texto
El texto de caracteres Unicode incluido en un archivo SVG se expresa como datos de caracteres XML. Muchos efectos visuales son posibles, y la especificación SVG maneja automáticamente texto bidireccional (para componer una combinación de texto inglés y árabe, por ejemplo), texto vertical (como se puede escribir chino o japonés) y caracteres a lo largo de un camino curvado (como el texto alrededor del borde del Gran Sello de los Estados Unidos).
Pintura
Las formas SVG se pueden rellenar y esbozar (pintado con un color, un gradiente o un patrón). Los rellenos pueden ser opacos o tener cualquier grado de transparencia.
"Marcadores" son características de línea de extremo, tales como puntas de flecha, o símbolos que pueden aparecer en los vértices de un polígono.
Color
Los colores se pueden aplicar a todos los elementos visibles SVG, ya sea directamente o vía fill, stroke, y otras propiedades. Los colores se especifican de la misma manera que en CSS2, es decir, usando nombres como black o blue, en hexadecimal como #2f0 o #22ff00, en decimal como rgb(255,255,127), o como porcentajes de la forma rgb(100%,100%,50%).
Gradientes y patrones
Las formas SVG se pueden rellenar o esbozar con colores sólidos como arriba, o con gradientes de color o con patrones de repetición. Los gradientes de color pueden ser lineales o radiales (circulares), y pueden implicar cualquier número de colores así como repeticiones. También se pueden especificar los gradientes de opacidad. Los patrones se basan en objetos gráficos vectoriales predefinidos, que pueden repetirse en x y y direcciones. Los ingredientes y patrones pueden ser animados y scripted.
Desde 2008, se ha discutido entre los usuarios profesionales de SVG que las mallas gradientes o las curvas de difusión preferentemente podrían ser útiles para la especificación SVG. Se dice que una "representación simple [utilizando curvas de difusión] es capaz de representar incluso efectos de afeitado muy sutiles" y que "las imágenes curvas de difusión son comparables tanto en la calidad como en la eficiencia de codificación con mallas gradientes, pero son más simples de crear (según varios artistas que han utilizado ambas herramientas), y pueden ser capturados de bitmaps completamente automáticamente". El actual borrador de SVG 2 incluye mallas gradientes.
Clipping, masking and compositing
Los elementos gráficos, incluyendo texto, caminos, formas básicas y combinaciones de estos, se pueden utilizar como esquemas para definir ambos dentro y afuera regiones que se pueden pintar (con colores, gradientes y patrones) independientemente. Totalmente opaco Recorridos de caminos y semitransparente máscaras son composited juntos para calcular el color y la opacidad de cada pixel de la imagen final, utilizando mezcla alfa.
Efectos de filtro
Un efecto filtrante consiste en una serie de operaciones gráficas que se aplican a un gráfico vectorial de origen dado para producir un resultado bitmapped modificado.
Interactividad
Las imágenes SVG pueden interactuar con los usuarios de muchas maneras. Además de hipervínculos como se menciona a continuación, cualquier parte de una imagen SVG puede ser receptiva a eventos de interfaz de usuario como cambios en el enfoque, clics del ratón, desplazamiento o zoom de la imagen y otros eventos de puntero, teclado y documento. Los manipuladores de eventos pueden iniciar, detener o alterar las animaciones, así como los scripts de activación en respuesta a tales eventos.
Enlace
Las imágenes SVG pueden contener hipervínculos a otros documentos, utilizando XLink. Mediante el uso del elemento o un identificador de fragmentos, URLs pueden conectarse a archivos SVG que cambian el área visible del documento. Esto permite crear estados de vista específicos que se utilizan para ampliar / fuera de un área específica o para limitar la vista a un elemento específico. Esto es útil al crear sprites. Soporte XLink en combinación con el El elemento también permite vincular y reutilizar elementos internos y externos. Esto permite que los codificadores hagan más con menos marcado y hace que el código más limpio.
Scripting
Todos los aspectos de un documento SVG se pueden acceder y manipular usando scripts de forma similar al HTML. El lenguaje de scripting predeterminado es JavaScript y hay objetos definidos Modelo de Objetos de Documentos (DOM) para cada elemento y atributo SVG. Los scripts están encerrados elementos. Pueden correr en respuesta a eventos punteros, eventos de teclado y eventos de documentos según sea necesario.
Animación
El contenido de SVG se puede animar utilizando elementos de animación incorporados como , y . El contenido se puede animar manipulando el DOM usando ECMAScript y los temporizadores incorporados del lenguaje de scripting. La animación SVG ha sido diseñada para ser compatible con versiones actuales y futuras de Synchronized Multimedia Integration Language (SMIL). Las animaciones pueden ser continuas, pueden buclear y repetir, y pueden responder a los eventos de usuario, como se mencionó anteriormente.
Fuentes
Como con HTML y CSS, el texto en SVG puede hacer referencia a archivos de fuentes externos, como fuentes de sistema. Si los archivos de fuentes requeridos no existen en la máquina donde se renderiza el archivo SVG, el texto puede no aparecer como se desee. Para superar esta limitación, el texto se puede mostrar en un Fuente SVG, donde los glifos requeridos se definen en SVG como una fuente que luego se hace referencia a elemento.
Metadatos
De acuerdo con la iniciativa Semántica Web de W3C, SVG permite a los autores proporcionar metadatos sobre contenido SVG. La instalación principal es la elemento, donde se puede describir el documento utilizando propiedades de metadatos básicos de Dublín (por ejemplo, título, creador/autor, tema, descripción, etc.). También se pueden utilizar otros esquemas de metadatos. Además, SVG define </code> y <code></code> elementos donde los autores también pueden proporcionar material descriptivo de texto claro dentro de una imagen SVG para ayudar a indexar, buscar y recuperar por varios medios.</dd></dl><p>Un documento SVG puede definir componentes, incluidas formas, degradados, etc., y usarlos repetidamente. Las imágenes SVG también pueden contener gráficos rasterizados, como imágenes PNG y JPEG, y otras imágenes SVG. </p><h3>Ejemplo</h3><p><a class="image" href="https://en.wikipedia.org/wiki/File:SVG_example_markup_grid.svg"><img alt="SVG example markup grid.svg" data-file-height="391" data-file-width="391" height="391" src="https://upload.wikimedia.org/wikipedia/commons/thumb/1/1a/SVG_example_markup_grid.svg/391px-SVG_example_markup_grid.svg.png" width="391" /></a></p><p>Este código producirá las formas de colores que se muestran en la imagen, excluyendo la cuadrícula y las etiquetas: </p><div class="mw-highlight mw-highlight-lang-xml mw-content-ltr" dir="ltr"><pre><span></span><span class="cp">¿No?</span><span class="cp">¡Atención! DOCTYPE svg PUBLIC "-/W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"</span><span class="nt">Identificado</span> <span class="na">ancho=</span><span class="s">"391"</span> <span class="na">altura=</span><span class="s">"391"</span> <span class="na">viewBox=</span><span class="s">"-70.5 -70.5 391 391"</span> <span class="na">xmlns=</span><span class="s">"http://www.w3.org/2000/svg"</span> <span class="na">xmlns:xlink=</span><span class="s">"http://www.w3.org/1999/xlink"</span><span class="nt">■</span><span class="nt">.</span> <span class="na">relleno</span><span class="s">"#fff"</span> <span class="na">derrame cerebral</span><span class="s">"#000"</span> <span class="na">x=</span><span class="s">"-70"</span> <span class="na">Y=</span><span class="s">"-70"</span> <span class="na">ancho=</span><span class="s">"390"</span> <span class="na">altura=</span><span class="s">"390"</span><span class="nt">/</span><span class="nt">c)</span> <span class="na">opacidad=</span><span class="s">"0.8"</span><span class="nt">■</span><span class="nt">.</span> <span class="na">x=</span><span class="s">"25"</span> <span class="na">Y=</span><span class="s">"25"</span> <span class="na">ancho=</span><span class="s">"200"</span> <span class="na">altura=</span><span class="s">"200"</span> <span class="na">relleno</span><span class="s">"lime"</span> <span class="na">derrame cerebral=</span><span class="s">"4"</span> <span class="na">derrame cerebral</span><span class="s">"pink"</span> <span class="nt">/</span><span class="nt">.</span> <span class="na">cx=</span><span class="s">"125"</span> <span class="na">cy=</span><span class="s">"125"</span> <span class="na">r=</span><span class="s">"75"</span> <span class="na">relleno</span><span class="s">"orange"</span> <span class="nt">/</span><span class="nt">Identificada</span> <span class="na">puntos=</span><span class="s">"50,150 50.200 200.200 200.100"</span> <span class="na">derrame cerebral</span><span class="s">"rojo"</span> <span class="na">derrame cerebral=</span><span class="s">"4"</span> <span class="na">relleno</span><span class="s">"ninguno"</span> <span class="nt">/</span><span class="nt">Identificada</span> <span class="na">x1=</span><span class="s">"50"</span> <span class="na">Y1=</span><span class="s">"50"</span> <span class="na">x2=</span><span class="s">"200"</span> <span class="na">Y2=</span><span class="s">"200"</span> <span class="na">derrame cerebral</span><span class="s">"azul"</span> <span class="na">derrame cerebral=</span><span class="s">"4"</span> <span class="nt">/</span><span class="nt">■/g</span><span class="nt">▪/svg</span></pre></div><h2>SVG en la web</h2><p>El uso de SVG en la web estaba limitado por la falta de soporte en versiones anteriores de Internet Explorer (IE). Muchos sitios web que sirven imágenes SVG también proporcionan las imágenes en formato de trama, ya sea automáticamente mediante negociación de contenido HTTP o permitiendo que el usuario elija directamente el archivo. </p><p>Google anunció el 31 de agosto de 2010 que había comenzado a indexar contenido SVG en la web, ya sea en archivos independientes o incrustados en HTML, y que los usuarios comenzarían a ver dicho contenido en sus resultados de búsqueda. El 8 de diciembre de 2010 se anunció que Google Image Search también comenzaría a indexar archivos SVG. El sitio anunció una opción para restringir las búsquedas de imágenes a archivos SVG el 11 de febrero de 2011. </p><h3>Soporte de navegador nativo</h3><p>Konqueror fue el primer navegador compatible con SVG en la versión 3.2 de febrero de 2004. A partir de 2011, todos los principales navegadores de escritorio, y muchos menores, cuentan con algún nivel de compatibilidad con SVG. Otros navegadores' las implementaciones aún no están completas; consulte la comparación de motores de diseño para obtener más detalles. </p><p>Algunas versiones anteriores de Firefox (por ejemplo, las versiones entre 1.5 y 3.6), así como algunos otros navegadores web obsoletos capaces de mostrar gráficos SVG, los necesitaban incrustados en <code><object></code> o elementos <code><iframe></code> para mostrarlos integrados como partes de una página web HTML en lugar de usar la forma estándar de integrar imágenes con <code><img></code>. Sin embargo, las imágenes SVG pueden incluirse en páginas XHTML utilizando espacios de nombres XML. </p><p>Tim Berners-Lee, el inventor de la World Wide Web, criticó las primeras versiones de Internet Explorer por no admitir SVG. </p><ul><li>Opera (desde 8.0) tiene soporte para la especificación SVG 1.1 Tiny, mientras que la Opera 9 incluye SVG 1.1 Soporte básico y algunos de SVG 1.1 Full. Opera 9.5 tiene soporte parcial SVG Tiny 1.2. También soporta SVGZ (SVG comprimido).</li><li>Los navegadores basados en el motor de diseño Gecko (como Firefox, Flock, Camino y SeaMonkey) han tenido soporte incompleto para el SVG 1.1 Especificación completa desde 2005. El sitio Mozilla tiene una visión general de los módulos que son compatibles en Firefox y de los módulos que están en desarrollo. Gecko 1.9, incluido en Firefox 3.0, añade soporte para más de la especificación SVG (incluyendo filtros).</li><li>Pale Moon, que utiliza el motor de diseño Goanna (un tenedor del motor Gecko), soporta SVG.</li><li>Los navegadores basados en WebKit (como el Safari de Apple, Google Chrome y el OmniWeb del Grupo Omni) han tenido un apoyo incompleto para el SVG 1.1 Especificación completa desde 2006.</li><li>Amaya tiene apoyo parcial SVG.</li><li>Internet Explorer 8 y versiones anteriores no admiten SVG. IE9 (publicado el 14 de marzo de 2011) apoya el conjunto básico de características SVG. IE10 extendió soporte SVG añadiendo filtros SVG 1.1.</li><li>Microsoft Edge Legacy admite SVG 1.1.</li><li>El navegador Maxthon Cloud también admite SVG.</li></ul><p>El soporte nativo y completo tiene varias ventajas: no se necesitan complementos, SVG se puede mezclar libremente con otro contenido en un solo documento, y la representación y las secuencias de comandos se vuelven considerablemente más confiables. </p><h3>Soporte móvil</h3><p>SVG Tiny (SVGT) 1.1 y 1.2 son perfiles móviles para SVG. SVGT 1.2 incluye algunas características que no se encuentran en SVG 1.1, incluidos los trazos sin escala, que son compatibles con algunas implementaciones de SVG 1.1, como Opera, Firefox y WebKit. A medida que aumentaron las bases de código compartidas entre los navegadores de escritorio y móviles, también aumentó el uso de SVG 1.1 sobre SVGT 1.2. </p><p>La compatibilidad con SVG puede estar limitada a SVGT en teléfonos inteligentes más antiguos o más limitados o puede estar limitada principalmente por su respectivo sistema operativo. Adobe Flash Lite ha admitido opcionalmente SVG Tiny desde la versión 1.1. En la conferencia SVG Open 2005, Sun demostró una implementación móvil de SVG Tiny 1.1 para la plataforma Connected Limited Device Configuration (CLDC). </p><p>Los dispositivos móviles que usan Opera Mobile, así como el navegador integrado del iPhone, también incluyen compatibilidad con SVG. Sin embargo, aunque usaba el motor WebKit, el navegador integrado de Android no era compatible con SVG antes de v3.0 (Honeycomb). Antes de la versión 3.0, Firefox Mobile 4.0b2 (beta) para Android fue el primer navegador que se ejecutaba en Android compatible con SVG de forma predeterminada. </p><p>El nivel de compatibilidad con SVG Tiny disponible varía de un dispositivo móvil a otro, según el motor SVG instalado. Muchos productos móviles más nuevos admiten funciones adicionales más allá de SVG Tiny 1.1, como degradado y opacidad; esto a veces se denomina "SVGT 1.1+", aunque no existe tal estándar. </p><p>El BlackBerry de RIM tiene compatibilidad integrada con SVG Tiny 1.1 desde la versión 5.0. El soporte continúa para el navegador BlackBerry Torch basado en WebKit en OS 6 y 7. </p><p>La plataforma S60 de Nokia tiene soporte integrado para SVG. Por ejemplo, los íconos generalmente se representan usando el motor SVG de la plataforma. Nokia también ha liderado el grupo de expertos JSR 226: Scalable 2D Vector Graphics API que define la API Java ME para la presentación y manipulación de SVG. Esta API se implementó en S60 Platform 3rd Edition Feature Pack 1 y en adelante. Algunos teléfonos de la Serie 40 también son compatibles con SVG (como Nokia 6280). </p><p>La mayoría de los teléfonos Sony Ericsson que comienzan con K700 (por fecha de lanzamiento) son compatibles con SVG Tiny 1.1. Los teléfonos que comienzan con K750 también admiten funciones como opacidad y degradados. Los teléfonos con Sony Ericsson Java Platform-8 son compatibles con JSR 226. </p><p>Windows Phone es compatible con SVG desde la versión 7.5. </p><p>SVG también es compatible con varios dispositivos móviles de Motorola, Samsung, LG y Siemens mobile/BenQ-Siemens. eSVG, una biblioteca de renderizado SVG escrita principalmente para dispositivos integrados, está disponible en algunas plataformas móviles. </p><h2>Soporte de aplicaciones</h2><p>Las imágenes SVG se pueden producir mediante el uso de un editor de gráficos vectoriales, como Inkscape, Adobe Illustrator, Adobe Flash Professional o CorelDRAW, y se pueden representar en formatos de imagen rasterizados comunes, como PNG, utilizando el mismo software. Además, los editores como Inkscape y Boxy SVG brindan herramientas para rastrear imágenes ráster a curvas Bézier, por lo general, utilizando back-ends de rastreo de imágenes como potrace, autotrace e imagetracerjs. </p><p>El software se puede programar para representar imágenes SVG mediante el uso de una biblioteca como librsvg utilizada por GNOME desde 2000, Batik y ThorVG desde 2020 para sistemas ligeros. Las imágenes SVG también se pueden representar en cualquier formato de imagen popular deseado mediante ImageMagick, una utilidad de línea de comandos gratuita (que también usa librsvg en el fondo). </p><p>Para las aplicaciones basadas en web, el modo de uso denominado SVG en línea permite que el contenido SVG se incruste en un documento HTML mediante una etiqueta <code><svg></code>. Sus capacidades gráficas se pueden emplear para crear interfaces de usuario sofisticadas, ya que SVG y HTML comparten contexto, manejo de eventos y CSS. </p><p>Otros usos de SVG incluyen la incrustación para su uso en el procesamiento de textos (p. ej., con LibreOffice) y la autoedición (p. ej., Scribus), el trazado de gráficos (p. ej., gnuplot) y la importación de rutas (p. ej., para su uso en GIMP o Blender). Los servicios de aplicaciones Microsoft 365 y Microsoft Office 2019 ofrecen soporte para exportar, importar y editar imágenes SVG. El identificador de tipo uniforme para SVG utilizado por Apple es <code>public.svg-image</code> y se ajusta a <code>public.image</code> y <code>public.xml</code>. </p><h2>Seguridad</h2><p>Es común ver que SVG se describe como un formato de imagen, pero en realidad es un formato de documento, similar a los documentos HTML, por lo que puede albergar secuencias de comandos o CSS. Los principales problemas de seguridad ocurren si los archivos SVG se tratan ingenuamente como archivos de imagen porque pueden albergar contenido malicioso. Por ejemplo, si se implementan como una imagen de fondo CSS, o un logotipo en algún sitio web, o en alguna galería de imágenes, dicho contenido podría activarse. Como mínimo, esto podría bloquear el navegador (el ataque del Billón de risas), pero también podría dar lugar a ataques de inyección de HTML y secuencias de comandos entre sitios. Por lo tanto, el W3C estipula ciertos requisitos cuando SVG se usa simplemente para imágenes: Seguridad SVG. </p><p>Sin embargo, el SVG en línea se considera un riesgo de seguridad menor porque el contenido es parte de un documento mayor, por lo que las secuencias de comandos y CSS no serían inesperados. </p></div><!--[--><h2 class="rel-heading">Contenido relacionado</h2><!--[--><a class="related-item" href="/enciclopedia/telecomunicaciones-en-la-republica-checa/"><p>Telecomunicaciones en la República Checa</p><span class="related-desc">Código de país:...</span></a><a class="related-item" href="/enciclopedia/telecomunicaciones-en-botsuana/"><p>Telecomunicaciones en Botsuana</p><span class="related-desc">Las telecomunicaciones en Botswana incluyen periódicos, radio, televisión, teléfonos fijos y móviles e...</span></a><a class="related-item" href="/enciclopedia/codigo-de-tiempo-grabado/"><p>Código de tiempo grabado</p><span class="related-desc">Código de tiempo grabado es una versión en pantalla legible por humanos de la información del código de tiempo para una pieza de material superpuesto en...</span></a><!--]--><div class="more-results"> Más resultados... </div><!--]--><div class="related-video-wrapper" data-nosnippet><div class="matched-video"><span>Te puede interesar</span><iframe width="560" height="315" src="https://www.youtube.com/embed/lTQ1KU6NDrU" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe></div></div></main><!--]--><footer id="piedepaginar" class="piedepagina"><link href="https://fonts.googleapis.com/css2?family=Lato:wght@900&display=swap" rel="stylesheet"><div class="footerContainer"><div class="headerWrapper"><header class="footerLogo"><span class="metamainlogo"><img src="" alt="Academia Lab logo" class="logo-footer"><a href=" https://academia-lab.com/ "> AcademiaLab </a></span></header></div><div class="infoWrapper"><div><span></span><span>YouTube: <a href="https://www.youtube.com/@academialab">@academialab</a></span><span>TikTok: <a href="https://www.tiktok.com/@academialab">@academialab</a></span><span>LinkedIn: <a href="https://www.linkedin.com/company/academialab/">@academialab</a></span><span class="non">Facebook: <a href="https://www.facebook.com/academialabf">@academialabf</a></span><span class="non">Instagram: <a href="https://www.instagram.com/academialabf/">@academialabf</a></span><span class="non">X: <a href="https://x.com/academialabf">@academialabf</a></span></div><div class="to-remove"><span><a href="#">Tema</a></span><span><a href="#">Categorías</a></span><span><a href="#">Libros</a></span></div><div><span>Site design / logo ©</span><span>2024 AcademiaLab</span><span><a href="https://creativecommons.org/licenses/by-nc-nd/4.0/deed.es">CC BY-NC-ND</a></span><span><a href="mailto:info@academia-lab.com">info@academia-lab.com</a></span></div></div></div></footer><span></span><dialog id="adjustDlg"><div class="adjustDlgWrapper"><div class="adjustDlgItem"><div class="adjustDlgItemDesc">Tamaño del texto:</div><div class="adjustDlgItemSett"><div class="adjustDlgRadioWrapper"><div class="adjustDlgRadioOpt"><input type="radio" value="14" id="sText" name="loptions" checked><label class="adjustDlgRadioOptLabel" for="sText">Pequeño</label></div><div class="adjustDlgRadioOpt"><input type="radio" value="16" name="loptions" id="mText"><label class="adjustDlgRadioOptLabel" for="mText">Mediano</label></div><div class="adjustDlgRadioOpt"><input type="radio" value="20" name="loptions" id="bText"><label class="adjustDlgRadioOptLabel" for="bText">Grande</label></div></div></div></div></div></dialog><dialog id="ctx-menu" class="context-menu"><div id="ctx-menu-copy">Copiar</div></dialog><!--]--></div><div id="teleports"></div><script type="application/json" data-nuxt-data="nuxt-app" data-ssr="true" id="__NUXT_DATA__">[["ShallowReactive",1],{"data":2,"state":34,"once":36,"_errors":37,"serverRendered":40,"path":41},["ShallowReactive",3],{"content":4,"related":16},{"status":5,"payload":7},{"code":6},200,{"id":8,"slug":9,"datePublished":10,"dateModified":11,"author":12,"status":13,"title":14,"content":15},556895,"svg","2023-01-16T08:16:33Z","2024-02-01T10:53:08Z","AcademiaLab Editors","publish","SVG","\u003Cdiv class=\"shortdescription nomobile noexcerpt noprint searchaux\">estándar abierto para gráficos vectoriales bidimensionales\u003C/div>\u003Cp>\u003Cb>Gráficos vectoriales escalables\u003C/b> (\u003Cb>SVG\u003C/b>) es un formato de imagen vectorial basado en XML para definir gráficos bidimensionales, con soporte para interactividad y animación. La especificación SVG es un estándar abierto desarrollado por el World Wide Web Consortium desde 1999.\n\u003C/p>\u003Cp>Las imágenes SVG se definen en un formato de gráficos vectoriales y se almacenan en archivos de texto XML. Por lo tanto, las imágenes SVG se pueden escalar en tamaño sin pérdida de calidad, y los archivos SVG se pueden buscar, indexar, codificar y comprimir. Los archivos de texto XML pueden crearse y editarse con editores de texto o editores de gráficos vectoriales, y son renderizados por los navegadores web más utilizados.\n\u003C/p>\u003Ch2>Resumen\u003C/h2>\u003Cdiv class=\"thumb tright\">\u003Cdiv class=\"thumbinner\" style=\"width:302px\">\u003Ca class=\"image\" href=\"https://en.wikipedia.org/wiki/File:Bitmap_VS_SVG.svg\">\u003Cimg alt=\"\" class=\"thumbimage\" data-file-height=\"327\" data-file-width=\"512\" height=\"192\" src=\"https://upload.wikimedia.org/wikipedia/commons/thumb/6/6b/Bitmap_VS_SVG.svg/300px-Bitmap_VS_SVG.svg.png\" width=\"300\" />\u003C/a> \u003Cdiv class=\"thumbcaption\">\u003Cdiv class=\"magnify\">\u003C/div>Esta imagen ilustra la diferencia entre bitmap y imágenes vectoriales. La imagen bitmap se compone de un conjunto fijo de píxeles, mientras que la imagen vectorial se compone de un conjunto fijo de formas. En la imagen, escalar el bitmap revela los píxeles mientras escala la imagen vectorial preserva las formas.\u003C/div>\u003C/div>\u003C/div>\u003Cp>SVG ha estado en desarrollo dentro del World Wide Web Consortium (W3C) desde 1999 después de que seis propuestas competitivas para lenguajes de gráficos vectoriales se presentaran al consorcio durante 1998 (ver más abajo).\n\u003C/p>\u003Cp>El primer grupo de trabajo de SVG decidió no desarrollar ninguno de los envíos comerciales, sino crear un nuevo lenguaje de marcado que se basara en ninguno de ellos, pero que no se basara realmente en ellos.\n\u003C/p>\u003Cp>SVG permite tres tipos de objetos gráficos: formas de gráficos vectoriales (como rutas que consisten en líneas rectas y curvas), imágenes de mapa de bits y texto. Los objetos gráficos se pueden agrupar, diseñar, transformar y componer en objetos previamente renderizados. El conjunto de funciones incluye transformaciones anidadas, trazados de recorte, máscaras alfa, efectos de filtro y objetos de plantilla. Los dibujos SVG pueden ser interactivos y pueden incluir animación, definida en los elementos SVG XML o mediante secuencias de comandos que acceden al Modelo de Objetos de Documento (DOM) SVG. SVG usa CSS para diseñar y JavaScript para secuencias de comandos. El texto, incluidas la internacionalización y la localización, que aparece en texto sin formato dentro del SVG DOM, mejora la accesibilidad de los gráficos SVG.\n\u003C/p>\u003Cp>La especificación SVG se actualizó a la versión 1.1 en 2011. Hay dos 'Perfiles SVG móviles' SVG Tiny y SVG Basic, destinados a dispositivos móviles con capacidades computacionales y de visualización reducidas. Scalable Vector Graphics 2 se convirtió en una recomendación candidata del W3C el 15 de septiembre de 2016. SVG 2 incorpora varias características nuevas además de las de SVG 1.1 y SVG Tiny 1.2.\n\u003C/p>\u003Ch3>Impresión\u003C/h3>\u003Cp>Aunque la especificación SVG se centra principalmente en el lenguaje de marcado de gráficos vectoriales, su diseño incluye las funciones básicas de un lenguaje de descripción de páginas como el PDF de Adobe. Contiene disposiciones para gráficos enriquecidos y es compatible con CSS para fines de diseño. SVG tiene la información necesaria para colocar cada glifo e imagen en una ubicación elegida en una página impresa.\n\u003C/p>\u003Ch3>Guión y animación\u003C/h3>\u003Cp>Los dibujos SVG pueden ser dinámicos e interactivos. Las modificaciones de los elementos basadas en el tiempo se pueden describir en SMIL o se pueden programar en un lenguaje de secuencias de comandos (por ejemplo, JavaScript). El W3C recomienda explícitamente SMIL como estándar para la animación en SVG.\n\u003C/p>\u003Cp>Se puede asignar un amplio conjunto de controladores de eventos como "\u003Ci>onmouseover"\u003C/i> y "\u003Ci>onclick"\u003C/i> a cualquier objeto gráfico SVG para aplicar acciones y eventos.\n\u003C/p>\u003Ch3>Compresión\u003C/h3>\u003Cp>Las imágenes SVG, al ser XML, contienen muchos fragmentos de texto repetidos, por lo que son adecuadas para los algoritmos de compresión de datos sin pérdidas. Cuando una imagen SVG se comprimió con el algoritmo gzip, se denomina "SVGZ" imagen y usa la extensión de nombre de archivo \u003Ccode>.svgz\u003C/code> correspondiente. Los visores que cumplan con SVG 1.1 mostrarán imágenes comprimidas. Un archivo SVGZ suele tener entre un 20 y un 50 por ciento del tamaño original. W3C proporciona archivos SVGZ para probar la conformidad.\n\u003C/p>\u003Ch2>Historial de desarrollo\u003C/h2>\u003Cp>SVG fue desarrollado por el W3C SVG Working Group a partir de 1998, después de que se recibieron seis presentaciones de gráficos vectoriales de la competencia ese año:\n\u003C/p>\u003Cul>\u003Cli>Web Schematics, from CCLRC\u003C/li>\u003Cli>PGML, de Adobe Systems, IBM, Netscape y Sun Microsystems\u003C/li>\u003Cli>VML, por Autodesk, Hewlett-Packard, Macromedia, Microsoft y Vision\u003C/li>\u003Cli>Hiper Graphics Markup Language (HGML), por Orange UK y PRP\u003C/li>\u003Cli>WebCGM, de Boeing, InterCAP Graphics Systems, Inso Corporation, CCLRC y Xerox\u003C/li>\u003Cli>DrawML, de Excosoft AB\u003C/li>\u003C/ul>\u003Cp>El grupo de trabajo estaba presidido en ese momento por Chris Lilley del W3C.\n\u003C/p>\u003Ch3>Versión 1.x\u003C/h3>\u003Cul>\u003Cli>SVG 1.0 se convirtió en una recomendación W3C el 4 de septiembre de 2001.\u003C/li>\u003Cli>SVG 1.1 se convirtió en una recomendación W3C el 14 de enero de 2003. La especificación SVG 1.1 se modulariza para permitir que los subconjuntos se definan como perfiles. Aparte de esto, hay muy poca diferencia entre SVG 1.1 y SVG 1.0.\n\u003Cul>\u003Cli>SVG Tiny and SVG Basic (the Mobile SVG Profiles) became W3C Recommendations on 14 January 2003. Se describen como perfiles de SVG 1.1.\u003C/li>\u003C/ul>\u003C/li>\u003Cli>SVG Tiny 1.2 se convirtió en una recomendación W3C el 22 de diciembre de 2008. Inicialmente fue redactado como un perfil del SVG Full 1.2 (que desde entonces ha sido retirado a favor de SVG 2), pero fue posteriormente refactorizado como una especificación independiente. Por lo general, es mal apoyado.\u003C/li>\u003Cli>SVG 1.1 Second Edition, which includes all the errata and clarifications, but no new features to the original SVG 1.1 was released on 16 August 2011.\u003C/li>\u003Cli>SVG Tiny 1.2 Portable/Secure, Un subconjunto más seguro del perfil SVG Tiny 1.2 presentado como un proyecto de norma IETF el 29 de julio de 2020. También conocido como SVG Tiny P/S. SVG Tiny 1.2 Portable/Secure es un requisito del proyecto de estándar BIMI.\u003C/li>\u003C/ul>\u003Ch3>Versión 2\u003C/h3>\u003Cp>SVG 2 elimina o descarta algunas funciones de SVG 1.1 e incorpora nuevas funciones de HTML5 y Web Open Font Format:\n\u003C/p>\u003Cul>\u003Cli>Por ejemplo, SVG 2 elimina varios elementos de fuentes como \u003Ccode>glyph\u003C/code> y \u003Ccode>altGlyph\u003C/code> (sustituida por el formato de fuente WOFF).\u003C/li>\u003Cli>El \u003Ccode>xml:space\u003C/code> atributo es deprecado a favor de CSS.\u003C/li>\u003Cli>Características HTML5 tales como \u003Ccode>translate\u003C/code> y \u003Ccode>data-*\u003C/code> atributos se han añadido.\u003C/li>\u003Cli>Las características de manejo de texto de SVG Tiny 1.2 están anotadas en cuanto a ser incluidas, pero aún no formalizadas en texto. Algunas otras 1.2 características son la cereza seleccionada, pero SVG 2 no es un superset de SVG pequeña 1.2 en general.\u003C/li>\u003C/ul>\u003Cp>SVG 2 alcanzó la etapa de Candidato a recomendación el 15 de septiembre de 2016, y las versiones revisadas se publicaron el 7 de agosto de 2018 y el 4 de octubre de 2018. El último borrador se publicó el 21 de marzo de 2022.\n\u003C/p>\u003Ch3>Perfiles móviles\u003C/h3>\u003Cp>Debido a la demanda de la industria, se introdujeron dos perfiles móviles con SVG 1.1: \u003Ci>SVG Tiny\u003C/i> (SVGT) y \u003Ci>SVG Basic\u003C/i> (SVGB).\n\u003C/p>\u003Cp>Estos son subconjuntos del estándar SVG completo, destinados principalmente a agentes de usuario con capacidades limitadas. En particular, SVG Tiny se definió para dispositivos móviles altamente restringidos, como teléfonos celulares; no admite estilos ni secuencias de comandos. SVG Basic se definió para dispositivos móviles de nivel superior, como los teléfonos inteligentes.\n\u003C/p>\u003Cp>En 2003, 3GPP, un grupo internacional de estándares de telecomunicaciones, adoptó SVG Tiny como el formato multimedia de gráficos vectoriales obligatorio para los teléfonos de próxima generación. SVGT es el formato de gráficos vectoriales requerido y la compatibilidad con SVGB es opcional para el servicio de mensajería multimedia (MMS) y el servicio de transmisión por paquetes conmutados. Más tarde se agregó como formato requerido para gráficos vectoriales en 3GPP IP Multimedia Subsystem (IMS).\n\u003C/p>\u003Ch4>Diferencias con SVG no móvil\u003C/h4>\u003Cp>Ninguno de los perfiles móviles incluye soporte para el modelo de objeto de documento (DOM) completo, mientras que solo SVG básico tiene soporte opcional para secuencias de comandos, pero debido a que son subconjuntos totalmente compatibles del estándar completo, la mayoría de los gráficos SVG todavía pueden ser renderizados por dispositivos que solo es compatible con los perfiles móviles.\n\u003C/p>\u003Cp>SVGT 1.2 agrega un microDOM (μDOM), estilo y secuencias de comandos.\n\u003C/p>\u003Ch3>Trabajo relacionado\u003C/h3>\u003Cp>El estándar MPEG-4 Parte 20 - \u003Ci>Representación de escena de aplicación ligera (LASeR) y formato de agregación simple (SAF)\u003C/i> se basa en SVG Tiny. Fue desarrollado por MPEG (ISO/IEC JTC 1/SC29/WG11) y publicado como ISO/IEC 14496-20:2006. Las capacidades de SVG se mejoran en MPEG-4 Parte 20 con características clave para servicios móviles, como actualizaciones dinámicas, codificación binaria, representación de fuentes de última generación. SVG también se acomodó en MPEG-4 Parte 11, en el formato Extensible MPEG-4 Textual (XMT), una representación textual del contenido multimedia MPEG-4 usando XML.\n\u003C/p>\u003Ch2>Funcionalidad\u003C/h2>\u003Cp>La especificación SVG 1.1 define 14 áreas funcionales o conjuntos de características:\n\u003C/p>\u003Cdl>\u003Cdt>Senderos\u003C/dt>\u003Cdd>Los contornos de forma simples o compuestos se dibujan con líneas curvas o rectas que se pueden rellenar, esbozar o usar como una ruta de recorte. Los caminos tienen una codificación compacta.\u003C/dd>\u003Cdd>Por ejemplo, \u003Cdfn>\u003Ccode>M\u003C/code>\u003C/dfn> (para \"move to\") precede la numérica inicial \u003Cvar>x\u003C/var> y \u003Cvar>Sí.\u003C/var> coordenadas, y \u003Cdfn>\u003Ccode>L\u003C/code>\u003C/dfn> (para \"línea a\") precede un punto al que debe dibujarse una línea. Otras cartas de mando (\u003Ccode>C\u003C/code>, \u003Ccode>S\u003C/code>, \u003Ccode>Q\u003C/code>, \u003Ccode>T\u003C/code>, y \u003Ccode>A\u003C/code>) precede datos que se utilizan para dibujar varias curvas Bézier y elípticas. \u003Ccode>Z\u003C/code> se utiliza para cerrar un camino.\u003C/dd>\u003Cdd>En todos los casos, las coordenadas absolutas siguen los comandos mayúsculas y las coordenadas relativas se utilizan después de las letras mayúsculas equivalentes.\u003C/dd>\u003Cdt>Formas básicas\u003C/dt>\u003Cdd>Se pueden dibujar caminos y caminos rectos formados por una serie de segmentos conectados de línea recta (polylines), así como polígonos cerrados, círculos y elipses. Los rectángulos y rectángulos redondeados también son elementos estándar.\u003C/dd>\u003Cdt>Texto\u003C/dt>\u003Cdd>El texto de caracteres Unicode incluido en un archivo SVG se expresa como datos de caracteres XML. Muchos efectos visuales son posibles, y la especificación SVG maneja automáticamente texto bidireccional (para componer una combinación de texto inglés y árabe, por ejemplo), texto vertical (como se puede escribir chino o japonés) y caracteres a lo largo de un camino curvado (como el texto alrededor del borde del Gran Sello de los Estados Unidos).\u003C/dd>\u003Cdt>Pintura\u003C/dt>\u003Cdd>Las formas SVG se pueden rellenar y esbozar (pintado con un color, un gradiente o un patrón). Los rellenos pueden ser opacos o tener cualquier grado de transparencia.\u003C/dd>\u003Cdd>\"Marcadores\" son características de línea de extremo, tales como puntas de flecha, o símbolos que pueden aparecer en los vértices de un polígono.\u003C/dd>\u003Cdt>Color\u003C/dt>\u003Cdd>Los colores se pueden aplicar a todos los elementos visibles SVG, ya sea directamente o vía \u003Ccode>fill\u003C/code>, \u003Ccode>stroke\u003C/code>, y otras propiedades. Los colores se especifican de la misma manera que en CSS2, es decir, usando nombres como \u003Ccode>black\u003C/code> o \u003Ccode>blue\u003C/code>, en hexadecimal como \u003Ccode>#2f0\u003C/code> o \u003Ccode>#22ff00\u003C/code>, en decimal como \u003Ccode>rgb(255,255,127)\u003C/code>, o como porcentajes de la forma \u003Ccode>rgb(100%,100%,50%)\u003C/code>.\u003C/dd>\u003Cdt>Gradientes y patrones\u003C/dt>\u003Cdd>Las formas SVG se pueden rellenar o esbozar con colores sólidos como arriba, o con gradientes de color o con patrones de repetición. Los gradientes de color pueden ser lineales o radiales (circulares), y pueden implicar cualquier número de colores así como repeticiones. También se pueden especificar los gradientes de opacidad. Los patrones se basan en objetos gráficos vectoriales predefinidos, que pueden repetirse en \u003Ccode>x\u003C/code> y \u003Ccode>y\u003C/code> direcciones. Los ingredientes y patrones pueden ser animados y scripted.\u003C/dd>\u003Cdd>Desde 2008, se ha discutido entre los usuarios profesionales de SVG que las mallas gradientes o las curvas de difusión preferentemente podrían ser útiles para la especificación SVG. Se dice que una \"representación simple [utilizando curvas de difusión] es capaz de representar incluso efectos de afeitado muy sutiles\" y que \"las imágenes curvas de difusión son comparables tanto en la calidad como en la eficiencia de codificación con mallas gradientes, pero son más simples de crear (según varios artistas que han utilizado ambas herramientas), y pueden ser capturados de bitmaps completamente automáticamente\". El actual borrador de SVG 2 incluye mallas gradientes.\u003C/dd>\u003Cdt>Clipping, masking and compositing\u003C/dt>\u003Cdd>Los elementos gráficos, incluyendo texto, caminos, formas básicas y combinaciones de estos, se pueden utilizar como esquemas para definir ambos \u003Ci>dentro\u003C/i> y \u003Ci>afuera\u003C/i> regiones que se pueden pintar (con colores, gradientes y patrones) independientemente. Totalmente opaco \u003Ci>Recorridos de caminos\u003C/i> y semitransparente \u003Ci>máscaras\u003C/i> son \u003Ci>composited\u003C/i> juntos para calcular el color y la opacidad de cada pixel de la imagen final, utilizando mezcla alfa.\u003C/dd>\u003Cdt>Efectos de filtro\u003C/dt>\u003Cdd>\u003C/dd>\u003Cdd>Un efecto filtrante consiste en una serie de operaciones gráficas que se aplican a un gráfico vectorial de origen dado para producir un resultado bitmapped modificado.\u003C/dd>\u003Cdt>Interactividad\u003C/dt>\u003Cdd>Las imágenes SVG pueden interactuar con los usuarios de muchas maneras. Además de hipervínculos como se menciona a continuación, cualquier parte de una imagen SVG puede ser receptiva a eventos de interfaz de usuario como cambios en el enfoque, clics del ratón, desplazamiento o zoom de la imagen y otros eventos de puntero, teclado y documento. Los manipuladores de eventos pueden iniciar, detener o alterar las animaciones, así como los scripts de activación en respuesta a tales eventos.\u003C/dd>\u003Cdt>Enlace\u003C/dt>\u003Cdd>Las imágenes SVG pueden contener hipervínculos a otros documentos, utilizando XLink. Mediante el uso del \u003Ccode>\u003C/code> elemento o un identificador de fragmentos, URLs pueden conectarse a archivos SVG que cambian el área visible del documento. Esto permite crear estados de vista específicos que se utilizan para ampliar / fuera de un área específica o para limitar la vista a un elemento específico. Esto es útil al crear sprites. Soporte XLink en combinación con el \u003Ccode>\u003C/code> El elemento también permite vincular y reutilizar elementos internos y externos. Esto permite que los codificadores hagan más con menos marcado y hace que el código más limpio.\u003C/dd>\u003Cdt>Scripting\u003C/dt>\u003Cdd>Todos los aspectos de un documento SVG se pueden acceder y manipular usando scripts de forma similar al HTML. El lenguaje de scripting predeterminado es JavaScript y hay objetos definidos Modelo de Objetos de Documentos (DOM) para cada elemento y atributo SVG. Los scripts están encerrados \u003Ccode>\u003C/code> elementos. Pueden correr en respuesta a eventos punteros, eventos de teclado y eventos de documentos según sea necesario.\u003C/dd>\u003Cdt>Animación\u003C/dt>\u003Cdd>\u003C/dd>\u003Cdd>El contenido de SVG se puede animar utilizando elementos de animación incorporados como \u003Ccode>\u003C/code>, \u003Ccode>\u003C/code> y \u003Ccode>\u003C/code>. El contenido se puede animar manipulando el DOM usando ECMAScript y los temporizadores incorporados del lenguaje de scripting. La animación SVG ha sido diseñada para ser compatible con versiones actuales y futuras de Synchronized Multimedia Integration Language (SMIL). Las animaciones pueden ser continuas, pueden buclear y repetir, y pueden responder a los eventos de usuario, como se mencionó anteriormente.\u003C/dd>\u003Cdt>Fuentes\u003C/dt>\u003Cdd>Como con HTML y CSS, el texto en SVG puede hacer referencia a archivos de fuentes externos, como fuentes de sistema. Si los archivos de fuentes requeridos no existen en la máquina donde se renderiza el archivo SVG, el texto puede no aparecer como se desee. Para superar esta limitación, el texto se puede mostrar en un \u003Ci>Fuente SVG\u003C/i>, donde los glifos requeridos se definen en SVG como una fuente que luego se hace referencia a \u003Ccode>\u003C/code> elemento.\u003C/dd>\u003Cdt>Metadatos\u003C/dt>\u003Cdd>De acuerdo con la iniciativa Semántica Web de W3C, SVG permite a los autores proporcionar metadatos sobre contenido SVG. La instalación principal es la \u003Ccode>\u003C/code> elemento, donde se puede describir el documento utilizando propiedades de metadatos básicos de Dublín (por ejemplo, título, creador/autor, tema, descripción, etc.). También se pueden utilizar otros esquemas de metadatos. Además, SVG define \u003Ccode>\u003Ctitle>\u003C/code> y \u003Ccode>\u003C/code> elementos donde los autores también pueden proporcionar material descriptivo de texto claro dentro de una imagen SVG para ayudar a indexar, buscar y recuperar por varios medios.\u003C/dd>\u003C/dl>\u003Cp>Un documento SVG puede definir componentes, incluidas formas, degradados, etc., y usarlos repetidamente. Las imágenes SVG también pueden contener gráficos rasterizados, como imágenes PNG y JPEG, y otras imágenes SVG.\n\u003C/p>\u003Ch3>Ejemplo\u003C/h3>\u003Cp>\u003Ca class=\"image\" href=\"https://en.wikipedia.org/wiki/File:SVG_example_markup_grid.svg\">\u003Cimg alt=\"SVG example markup grid.svg\" data-file-height=\"391\" data-file-width=\"391\" height=\"391\" src=\"https://upload.wikimedia.org/wikipedia/commons/thumb/1/1a/SVG_example_markup_grid.svg/391px-SVG_example_markup_grid.svg.png\" width=\"391\" />\u003C/a>\u003C/p>\u003Cp>Este código producirá las formas de colores que se muestran en la imagen, excluyendo la cuadrícula y las etiquetas:\n\u003C/p>\u003Cdiv class=\"mw-highlight mw-highlight-lang-xml mw-content-ltr\" dir=\"ltr\">\u003Cpre>\u003Cspan>\u003C/span>\u003Cspan class=\"cp\">¿No?\u003C/span>\u003Cspan class=\"cp\">¡Atención! DOCTYPE svg PUBLIC \"-/W3C//DTD SVG 1.1//EN\" \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\"\u003C/span>\u003Cspan class=\"nt\">Identificado\u003C/span> \u003Cspan class=\"na\">ancho=\u003C/span>\u003Cspan class=\"s\">\"391\"\u003C/span> \u003Cspan class=\"na\">altura=\u003C/span>\u003Cspan class=\"s\">\"391\"\u003C/span> \u003Cspan class=\"na\">viewBox=\u003C/span>\u003Cspan class=\"s\">\"-70.5 -70.5 391 391\"\u003C/span> \u003Cspan class=\"na\">xmlns=\u003C/span>\u003Cspan class=\"s\">\"http://www.w3.org/2000/svg\"\u003C/span> \u003Cspan class=\"na\">xmlns:xlink=\u003C/span>\u003Cspan class=\"s\">\"http://www.w3.org/1999/xlink\"\u003C/span>\u003Cspan class=\"nt\">■\u003C/span>\u003Cspan class=\"nt\">.\u003C/span> \u003Cspan class=\"na\">relleno\u003C/span>\u003Cspan class=\"s\">\"#fff\"\u003C/span> \u003Cspan class=\"na\">derrame cerebral\u003C/span>\u003Cspan class=\"s\">\"#000\"\u003C/span> \u003Cspan class=\"na\">x=\u003C/span>\u003Cspan class=\"s\">\"-70\"\u003C/span> \u003Cspan class=\"na\">Y=\u003C/span>\u003Cspan class=\"s\">\"-70\"\u003C/span> \u003Cspan class=\"na\">ancho=\u003C/span>\u003Cspan class=\"s\">\"390\"\u003C/span> \u003Cspan class=\"na\">altura=\u003C/span>\u003Cspan class=\"s\">\"390\"\u003C/span>\u003Cspan class=\"nt\">/\u003C/span>\u003Cspan class=\"nt\">c)\u003C/span> \u003Cspan class=\"na\">opacidad=\u003C/span>\u003Cspan class=\"s\">\"0.8\"\u003C/span>\u003Cspan class=\"nt\">■\u003C/span>\u003Cspan class=\"nt\">.\u003C/span> \u003Cspan class=\"na\">x=\u003C/span>\u003Cspan class=\"s\">\"25\"\u003C/span> \u003Cspan class=\"na\">Y=\u003C/span>\u003Cspan class=\"s\">\"25\"\u003C/span> \u003Cspan class=\"na\">ancho=\u003C/span>\u003Cspan class=\"s\">\"200\"\u003C/span> \u003Cspan class=\"na\">altura=\u003C/span>\u003Cspan class=\"s\">\"200\"\u003C/span> \u003Cspan class=\"na\">relleno\u003C/span>\u003Cspan class=\"s\">\"lime\"\u003C/span> \u003Cspan class=\"na\">derrame cerebral=\u003C/span>\u003Cspan class=\"s\">\"4\"\u003C/span> \u003Cspan class=\"na\">derrame cerebral\u003C/span>\u003Cspan class=\"s\">\"pink\"\u003C/span> \u003Cspan class=\"nt\">/\u003C/span>\u003Cspan class=\"nt\">.\u003C/span> \u003Cspan class=\"na\">cx=\u003C/span>\u003Cspan class=\"s\">\"125\"\u003C/span> \u003Cspan class=\"na\">cy=\u003C/span>\u003Cspan class=\"s\">\"125\"\u003C/span> \u003Cspan class=\"na\">r=\u003C/span>\u003Cspan class=\"s\">\"75\"\u003C/span> \u003Cspan class=\"na\">relleno\u003C/span>\u003Cspan class=\"s\">\"orange\"\u003C/span> \u003Cspan class=\"nt\">/\u003C/span>\u003Cspan class=\"nt\">Identificada\u003C/span> \u003Cspan class=\"na\">puntos=\u003C/span>\u003Cspan class=\"s\">\"50,150 50.200 200.200 200.100\"\u003C/span> \u003Cspan class=\"na\">derrame cerebral\u003C/span>\u003Cspan class=\"s\">\"rojo\"\u003C/span> \u003Cspan class=\"na\">derrame cerebral=\u003C/span>\u003Cspan class=\"s\">\"4\"\u003C/span> \u003Cspan class=\"na\">relleno\u003C/span>\u003Cspan class=\"s\">\"ninguno\"\u003C/span> \u003Cspan class=\"nt\">/\u003C/span>\u003Cspan class=\"nt\">Identificada\u003C/span> \u003Cspan class=\"na\">x1=\u003C/span>\u003Cspan class=\"s\">\"50\"\u003C/span> \u003Cspan class=\"na\">Y1=\u003C/span>\u003Cspan class=\"s\">\"50\"\u003C/span> \u003Cspan class=\"na\">x2=\u003C/span>\u003Cspan class=\"s\">\"200\"\u003C/span> \u003Cspan class=\"na\">Y2=\u003C/span>\u003Cspan class=\"s\">\"200\"\u003C/span> \u003Cspan class=\"na\">derrame cerebral\u003C/span>\u003Cspan class=\"s\">\"azul\"\u003C/span> \u003Cspan class=\"na\">derrame cerebral=\u003C/span>\u003Cspan class=\"s\">\"4\"\u003C/span> \u003Cspan class=\"nt\">/\u003C/span>\u003Cspan class=\"nt\">■/g\u003C/span>\u003Cspan class=\"nt\">▪/svg\u003C/span>\u003C/pre>\u003C/div>\u003Ch2>SVG en la web\u003C/h2>\u003Cp>El uso de SVG en la web estaba limitado por la falta de soporte en versiones anteriores de Internet Explorer (IE). Muchos sitios web que sirven imágenes SVG también proporcionan las imágenes en formato de trama, ya sea automáticamente mediante negociación de contenido HTTP o permitiendo que el usuario elija directamente el archivo.\n\u003C/p>\u003Cp>Google anunció el 31 de agosto de 2010 que había comenzado a indexar contenido SVG en la web, ya sea en archivos independientes o incrustados en HTML, y que los usuarios comenzarían a ver dicho contenido en sus resultados de búsqueda.\nEl 8 de diciembre de 2010 se anunció que Google Image Search también comenzaría a indexar archivos SVG. El sitio anunció una opción para restringir las búsquedas de imágenes a archivos SVG el 11 de febrero de 2011.\n\u003C/p>\u003Ch3>Soporte de navegador nativo\u003C/h3>\u003Cp>Konqueror fue el primer navegador compatible con SVG en la versión 3.2 de febrero de 2004. A partir de 2011, todos los principales navegadores de escritorio, y muchos menores, cuentan con algún nivel de compatibilidad con SVG. Otros navegadores' las implementaciones aún no están completas; consulte la comparación de motores de diseño para obtener más detalles.\n\u003C/p>\u003Cp>Algunas versiones anteriores de Firefox (por ejemplo, las versiones entre 1.5 y 3.6), así como algunos otros navegadores web obsoletos capaces de mostrar gráficos SVG, los necesitaban incrustados en \u003Ccode><object>\u003C/code> o elementos \u003Ccode><iframe>\u003C/code> para mostrarlos integrados como partes de una página web HTML en lugar de usar la forma estándar de integrar imágenes con \u003Ccode><img>\u003C/code>. Sin embargo, las imágenes SVG pueden incluirse en páginas XHTML utilizando espacios de nombres XML.\n\u003C/p>\u003Cp>Tim Berners-Lee, el inventor de la World Wide Web, criticó las primeras versiones de Internet Explorer por no admitir SVG.\n\u003C/p>\u003Cul>\u003Cli>Opera (desde 8.0) tiene soporte para la especificación SVG 1.1 Tiny, mientras que la Opera 9 incluye SVG 1.1 Soporte básico y algunos de SVG 1.1 Full. Opera 9.5 tiene soporte parcial SVG Tiny 1.2. También soporta SVGZ (SVG comprimido).\u003C/li>\u003Cli>Los navegadores basados en el motor de diseño Gecko (como Firefox, Flock, Camino y SeaMonkey) han tenido soporte incompleto para el SVG 1.1 Especificación completa desde 2005. El sitio Mozilla tiene una visión general de los módulos que son compatibles en Firefox y de los módulos que están en desarrollo. Gecko 1.9, incluido en Firefox 3.0, añade soporte para más de la especificación SVG (incluyendo filtros).\u003C/li>\u003Cli>Pale Moon, que utiliza el motor de diseño Goanna (un tenedor del motor Gecko), soporta SVG.\u003C/li>\u003Cli>Los navegadores basados en WebKit (como el Safari de Apple, Google Chrome y el OmniWeb del Grupo Omni) han tenido un apoyo incompleto para el SVG 1.1 Especificación completa desde 2006.\u003C/li>\u003Cli>Amaya tiene apoyo parcial SVG.\u003C/li>\u003Cli>Internet Explorer 8 y versiones anteriores no admiten SVG. IE9 (publicado el 14 de marzo de 2011) apoya el conjunto básico de características SVG. IE10 extendió soporte SVG añadiendo filtros SVG 1.1.\u003C/li>\u003Cli>Microsoft Edge Legacy admite SVG 1.1.\u003C/li>\u003Cli>El navegador Maxthon Cloud también admite SVG.\u003C/li>\u003C/ul>\u003Cp>El soporte nativo y completo tiene varias ventajas: no se necesitan complementos, SVG se puede mezclar libremente con otro contenido en un solo documento, y la representación y las secuencias de comandos se vuelven considerablemente más confiables.\n\u003C/p>\u003Ch3>Soporte móvil\u003C/h3>\u003Cp>SVG Tiny (SVGT) 1.1 y 1.2 son perfiles móviles para SVG. SVGT 1.2 incluye algunas características que no se encuentran en SVG 1.1, incluidos los trazos sin escala, que son compatibles con algunas implementaciones de SVG 1.1, como Opera, Firefox y WebKit. A medida que aumentaron las bases de código compartidas entre los navegadores de escritorio y móviles, también aumentó el uso de SVG 1.1 sobre SVGT 1.2.\n\u003C/p>\u003Cp>La compatibilidad con SVG puede estar limitada a SVGT en teléfonos inteligentes más antiguos o más limitados o puede estar limitada principalmente por su respectivo sistema operativo. Adobe Flash Lite ha admitido opcionalmente SVG Tiny desde la versión 1.1. En la conferencia SVG Open 2005, Sun demostró una implementación móvil de SVG Tiny 1.1 para la plataforma Connected Limited Device Configuration (CLDC).\n\u003C/p>\u003Cp>Los dispositivos móviles que usan Opera Mobile, así como el navegador integrado del iPhone, también incluyen compatibilidad con SVG. Sin embargo, aunque usaba el motor WebKit, el navegador integrado de Android no era compatible con SVG antes de v3.0 (Honeycomb). Antes de la versión 3.0, Firefox Mobile 4.0b2 (beta) para Android fue el primer navegador que se ejecutaba en Android compatible con SVG de forma predeterminada.\n\u003C/p>\u003Cp>El nivel de compatibilidad con SVG Tiny disponible varía de un dispositivo móvil a otro, según el motor SVG instalado. Muchos productos móviles más nuevos admiten funciones adicionales más allá de SVG Tiny 1.1, como degradado y opacidad; esto a veces se denomina "SVGT 1.1+", aunque no existe tal estándar.\n\u003C/p>\u003Cp>El BlackBerry de RIM tiene compatibilidad integrada con SVG Tiny 1.1 desde la versión 5.0. El soporte continúa para el navegador BlackBerry Torch basado en WebKit en OS 6 y 7.\n\u003C/p>\u003Cp>La plataforma S60 de Nokia tiene soporte integrado para SVG. Por ejemplo, los íconos generalmente se representan usando el motor SVG de la plataforma. Nokia también ha liderado el grupo de expertos JSR 226: Scalable 2D Vector Graphics API que define la API Java ME para la presentación y manipulación de SVG. Esta API se implementó en S60 Platform 3rd Edition Feature Pack 1 y en adelante. Algunos teléfonos de la Serie 40 también son compatibles con SVG (como Nokia 6280).\n\u003C/p>\u003Cp>La mayoría de los teléfonos Sony Ericsson que comienzan con K700 (por fecha de lanzamiento) son compatibles con SVG Tiny 1.1. Los teléfonos que comienzan con K750 también admiten funciones como opacidad y degradados. Los teléfonos con Sony Ericsson Java Platform-8 son compatibles con JSR 226.\n\u003C/p>\u003Cp>Windows Phone es compatible con SVG desde la versión 7.5.\n\u003C/p>\u003Cp>SVG también es compatible con varios dispositivos móviles de Motorola, Samsung, LG y Siemens mobile/BenQ-Siemens. eSVG, una biblioteca de renderizado SVG escrita principalmente para dispositivos integrados, está disponible en algunas plataformas móviles.\n\u003C/p>\u003Ch2>Soporte de aplicaciones\u003C/h2>\u003Cp>Las imágenes SVG se pueden producir mediante el uso de un editor de gráficos vectoriales, como Inkscape, Adobe Illustrator, Adobe Flash Professional o CorelDRAW, y se pueden representar en formatos de imagen rasterizados comunes, como PNG, utilizando el mismo software. Además, los editores como Inkscape y Boxy SVG brindan herramientas para rastrear imágenes ráster a curvas Bézier, por lo general, utilizando back-ends de rastreo de imágenes como potrace, autotrace e imagetracerjs.\n\u003C/p>\u003Cp>El software se puede programar para representar imágenes SVG mediante el uso de una biblioteca como librsvg utilizada por GNOME desde 2000, Batik y ThorVG desde 2020 para sistemas ligeros. Las imágenes SVG también se pueden representar en cualquier formato de imagen popular deseado mediante ImageMagick, una utilidad de línea de comandos gratuita (que también usa librsvg en el fondo).\n\u003C/p>\u003Cp>Para las aplicaciones basadas en web, el modo de uso denominado SVG en línea permite que el contenido SVG se incruste en un documento HTML mediante una etiqueta \u003Ccode><svg>\u003C/code>. Sus capacidades gráficas se pueden emplear para crear interfaces de usuario sofisticadas, ya que SVG y HTML comparten contexto, manejo de eventos y CSS.\n\u003C/p>\u003Cp>Otros usos de SVG incluyen la incrustación para su uso en el procesamiento de textos (p. ej., con LibreOffice) y la autoedición (p. ej., Scribus), el trazado de gráficos (p. ej., gnuplot) y la importación de rutas (p. ej., para su uso en GIMP o Blender). Los servicios de aplicaciones Microsoft 365 y Microsoft Office 2019 ofrecen soporte para exportar, importar y editar imágenes SVG. El identificador de tipo uniforme para SVG utilizado por Apple es \u003Ccode>public.svg-image\u003C/code> y se ajusta a \u003Ccode>public.image\u003C/code> y \u003Ccode>public.xml\u003C/code>.\n\u003C/p>\u003Ch2>Seguridad\u003C/h2>\u003Cp>Es común ver que SVG se describe como un formato de imagen, pero en realidad es un formato de documento, similar a los documentos HTML, por lo que puede albergar secuencias de comandos o CSS. Los principales problemas de seguridad ocurren si los archivos SVG se tratan ingenuamente como archivos de imagen porque pueden albergar contenido malicioso. Por ejemplo, si se implementan como una imagen de fondo CSS, o un logotipo en algún sitio web, o en alguna galería de imágenes, dicho contenido podría activarse. Como mínimo, esto podría bloquear el navegador (el ataque del Billón de risas), pero también podría dar lugar a ataques de inyección de HTML y secuencias de comandos entre sitios. Por lo tanto, el W3C estipula ciertos requisitos cuando SVG se usa simplemente para imágenes: Seguridad SVG.\n\u003C/p>\u003Cp>Sin embargo, el SVG en línea se considera un riesgo de seguridad menor porque el contenido es parte de un documento mayor, por lo que las secuencias de comandos y CSS no serían inesperados.\n\u003C/p>",{"status":17,"payload":18},{"code":6},{"id":19,"slug":9,"recordsID":8,"lastUpdate":20,"relatedContent":21},191503,"2024-06-10T23:52:38.817502Z",[22,26,30],{"title":23,"desc":24,"url":25},"Telecomunicaciones en la República Checa","Código de país:...","/enciclopedia/telecomunicaciones-en-la-republica-checa/",{"title":27,"desc":28,"url":29},"Telecomunicaciones en Botsuana","Las telecomunicaciones en Botswana incluyen periódicos, radio, televisión, teléfonos fijos y móviles e...","/enciclopedia/telecomunicaciones-en-botsuana/",{"title":31,"desc":32,"url":33},"Código de tiempo grabado","Código de tiempo grabado es una versión en pantalla legible por humanos de la información del código de tiempo para una pieza de material superpuesto en...","/enciclopedia/codigo-de-tiempo-grabado/",["Reactive",35],{},["Set"],["ShallowReactive",38],{"content":39,"related":39},null,true,"/enciclopedia/svg"]</script> <script>window.__NUXT__={};window.__NUXT__.config={public:{},app:{baseURL:"/",buildId:"e13700f9-a8ec-44fd-9e24-529a02dd1f9e",buildAssetsDir:"/_nuxt/",cdnURL:""}}</script> <script defer src="https://www.googletagmanager.com/gtag/js?id=G-3NVN9267P3"></script> <script>(async(e,t,a)=>{e[t]=async function(){(e[a]=e[a]||[]).push(arguments),e.dispatchEvent(new CustomEvent("layerUpdated",{detail:arguments}))},e[t]("js",new Date),e[t]("config","G-3NVN9267P3",{transport_type:"beacon"}),e.addEventListener("error",(a=>{e[t]("error",a),a.preventDefault()}))})(window,"gtag","dataLayer")</script></body></html>