tamaño manipular insertar imagen con color cambiar css svg background fill

manipular - insertar svg con css



¿Cómo cambiar el color de relleno svg cuando se utiliza como datos de imagen de fondo base-64? (3)

Estoy usando SVG para un proyecto, cargado en css como este:

background-image: url(''data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20xmlns%3Axlink%3D%22http%3A//www.w3.org/1999/xlink%22%20version%3D%221.1%22%20x%3D%220px%22%20y%3D%220px%22%20width%3D%2222px%22%20height%3D%2238px%22%20viewBox%3D%220%200%2022%2038%22%20enable-background%3D%22new%200%200%2022%2038%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%3E.style0%7Bfill%3A%09%23f47216%3B%7D%3C/style%3E%3Cpath%20d%3D%22M2.643%2038c-0.64%200-1.282-0.231-1.79-0.699c-1.074-0.988-1.143-2.661-0.154-3.735l13.13-14.258L0.664%204.4%20c-0.967-1.094-0.865-2.765%200.229-3.732s2.765-0.864%203.7%200.229L19.37%2017.592c0.898%201%200.9%202.545-0.035%203.542L4.588%2037.1%20C4.067%2037.7%203.4%2038%202.6%2038z%22%20class%3D%22style0%22/%3E%3C/svg%3E'');

Tengo algunos estados para resaltar cambiando el color de relleno de la flecha.

Por ahora, simplemente estoy aplicando los mismos datos svg con la porción de relleno (relleno% 3A% 09% 23f47216% 3B% 7D% 3C donde f47216 es el color) cambiado con el derecho / nuevo color. Funciona bastante bien Sin embargo, me gustaría saber si hay algún otro método más inteligente.


Base64 para eso sería:

url('''');

utilizando una herramienta como http://www.base64encode.org/

Esto no responde su pregunta directamente, pero nos permite hacer lo siguiente. Ahora podemos probar para ver si:

.icon:hover .style0 { fill: red; }

trabajará, o usará

.icon { background-image: url(''''); height: 40px; width: 40px; } .icon:hover { background-image: url(''''); }

lo que me parece ineficaz porque nos vemos obligados a replicar mucha de la misma información para el desplazamiento cuando todo lo que queremos cambiar es el color.

ejemplo de trabajo


O si quieres hacerlo dinámicamente prueba:

var green = ''3CB54A''; var red = ''ED1F24''; var svg = ''<svg version="1.1" id="Layer_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px" width="320px" height="100px" viewBox="0 0 320 100" enable-background="new 0 0 320 100" xml:space="preserve"> <polygon class="mystar" fill="#''+green+''" points="134.973,14.204 143.295,31.066 161.903,33.77 148.438,46.896 151.617,65.43 134.973,56.679 118.329,65.43 121.507,46.896 108.042,33.77 126.65,31.066 "/><circle class="mycircle" fill="#''+red+''" cx="202.028" cy="58.342" r="12.26"/></svg>''; var encoded = window.btoa(svg); document.body.style.background = "url(data:image/svg+xml;base64,"+encoded+")";

Violín aquí


Use la propiedad de filter de CSS. Para mí, quería cambiar el color del icono a blanco en Hover:

filter: grayscale(1) brightness(2);