--- title: Dibujar texto usando canvas slug: Dibujar_texto_usando_canvas tags: - 'HTML:Canvas' translation_of: Web/API/Canvas_API/Tutorial/Drawing_text ---
{{ Gecko_minversion_header(1.9) }}
{{ Fx_minversion_header(3) }}
El elemento <canvas>
permite dibujar texto en él a través de una API experimental de Mozilla.
attribute DOMString mozTextStyle; void mozDrawText(in DOMString textToDraw); float mozMeasureText(in DOMString textToMeasure); void mozPathText(in DOMString textToPath); void mozTextAlongPath(in DOMString textToDraw, in boolean stroke);
Mira algunos ejemplos aquí, aquí, y aquí.
El atributo mozTextStyle
contiene el estilo de texto actual. Usa la misma sintaxis que el especificado para las tipografías CSS.
Ej:
ctx.mozTextStyle = "20pt Arial"
Dibujar es muy sencillo. mozDrawText
usa el estilo de texto actual, cualquiera que sea éste. Se usa el color de relleno del contexto como color del texto.
ctx.translate(10, 50); ctx.fillStyle = "Red"; ctx.mozDrawText("Sample String");
A veces es útil saber qué tan ancho es un trozo de texto en particular (para centrarlo en una ventana, por ejemplo).
var text = "Sample String"; var width = ctx.canvas.width; var len = ctx.mozMeasureText(text); ctx.translate(len/2, 0); ctx.mozDrawText(text);
Si quieres tachar un texto, mozDrawText
no te lo permite. En cambio, mozPathText
agrega el tachado de texto al trazo actual.
ctx.fillStyle = "green"; ctx.strokeStyle = "black"; ctx.mozPathText("Sample String"); ctx.fill() ctx.stroke()
Supongamos ahora que quieres agregar un texto que se acomode a un trazo que dibujaste (una línea curva o algo parecido) es donde aparece mozTextAlongPath
. Al contrario de otras funciones de texto, mozTextAlongPath
necesita dos argumentos: el texto y qué se quiere hacer con él. mozTextAlongPath
aproxima el trazo actual como una serie de segmentos de línea y ubica cada carácter encima de ese trazo. Los caracteres no son cambiados de tamaño o transformados de acuerdo a la curvatura de la base; toman la orientación del trazo a la mitad del carácter.
Una vez que mozTextAlongPath
sabe dónde está el carácter, busca el segundo parámetro para decidir qué hacer con él. Si el segundo parámetro es false
, entonces dibuja el carácter como lo haría mozDrawText
. Si es true
, agrega el carácter al trazo actual, como lo hace mozPathText
. Esto puede usarse para crear efectos únicos.