La especificación oficial y el estado actual de desarrollo del módulo Text en CSS 3 puede consultarse en http://www.w3.org/TR/css3-text/.
CSS 3 ha añadido nuevas funcionalidades relacionadas con el texto, realizando un importante avance en este sentido y facilitando la creación de efecto de texto, sin necesidad de recurrir a complejas soluciones.
Finalmente se ha añadido la posibilidad de crear sombras en los textos del documentos, eliminando la necesidad de crear estos textos en una herramienta externa (como Photoshop o Gimp), he incluyendolos posteriormente como una imagen en el documento, lo que perjudicaba directamente el contenido.
Propiedad | text-shadow |
---|---|
Valores | none | [ <length>{2,3} && <color>? ]# |
Se aplica a | Todos los elementos. |
Valor inicial | none |
Descripción | Especifica una sombra para el texto. |
Esta propiedad acepta una lista de valores separados por comas que serán aplicados al texto. Las diferentes sombras son aplicadas de arriba hacia debajo, es decir, la primera sombra de la lista está sobre las demás.
Los valores de la sombra son interpretados de la siguiente manera:
0
(no se aceptan valores negativos) la sombra será muy nítida. Para valores mayores que 0
, la sombra se va difuminando.Algunos ejemplos:
h3 {color: white; text-shadow: 0.1em 0.1em 0.2em black; }
h3 {text-shadow: 0.2em 0.5em 0.1em #600, -0.3em 0.1em 0.1em #060, 0.4em -0.3em 0.1em #006}
h3 {text-shadow: -1px -1px white, 1px 1px #333} h3 {text-shadow: 1px 1px white, -1px -1px #444}
Hasta la introducción de esta nueva característica en CSS 3, a la hora de escoger una fuente para ser utilizada en un documento HTML, nos encontrábamos con la limitación de que el usuario tuviera ese tipo de letra instalada en su ordenador, porque de no ser así, los textos se mostrarían con otras tipografías, distintas a las que habíamos elegido (las definidas como fallback
o la fuente por defecto del navegador). Es por ello que el abanico de fuentes que podíamos utilizar, estaba reducido a las típicas Arial, Verdana, Times New Roman o Sans.
La regla @font-face
permite enlazar fuentes en línea que van a ser utilizadas en páginas web. La descripción de la fuente, define la localización física de la fuente (local o externa), así como las características de dicha fuente. Es posible declarar tantas reglas @font-face
como fuentes sean necesarias utilizar.
Su sintaxis es la siguiente:
@font-face { [font-family: <family-name>;]? [src: [ <uri> [format(<string>#)]? | <font-face-name> ]#;]? [unicode-range: <urange>#;]? [font-variant: <font-variant>;]? [font-feature-settings: normal|<feature-tag-value>#;]? [font-stretch: <font-stretch>;]? [font-weight: <weight>]; [font-style: <style>]; }
Donde:
<family-name>
: especifica el nombre de la fuente que se utilizará.<uri>
: URL para de la ubicación remota de la fuente, o nombre de la fuente en el ordenador del autor ("FontName")<font-variant>
: variante de una fuente anterior.<font-stretch>
: especifica la anchura de la fuente.<weight>
: especifica el peso de la fuente (light
, normal
, bold
...)<style>
: especifica el estilo de la fuente (normal
, italic
o oblique
)Un ejemplo sencillo:
Los usuarios que accedan con un navegador que cumpla con el estándar, verán este texto con la fuente Delicious, y esta parte con Delicious Bold.
Dependiendo del tipo de navegador con el que se acceda a nuestra web, éste acepta un tipo concreto de fuente. Los tipos existentes son los siquientes:
String | Formato de fuente | Extensión |
---|---|---|
"woff" | WOFF (Web Open Font Format) | .woff |
"truetype" | TrueType | .ttf |
"opentype" | OpenType | .ttf, .otf |
"embedded-opentype" | Embedded OpenType | .eot |
"svg" | SVG Font | .svg |
Un ejemplo de utilización de varios orígenes de fuentes es el siguiente:
@font-face { font-family: 'ITCAvantGardeStd-Bk'; src: url('fonts/ITCAvantGardeStd-Bold.eot') format('eot'), url('fonts/ITCAvantGardeStd-Bold.woff') format('woff'), url('fonts/ITCAvantGardeStd-Bold.ttf') format('truetype'), url('fonts/ITCAvantGardeStd-Bold.svg') format('svg'); font-weight: bold; font-style: normal; }
Ejercicio 5