在javascript中绘制文本字段实现

时间:2013-02-28 15:06:34

标签: javascript text annotations html5-canvas mouseevent

是否可以在画布上的javascript中实现绘图文本功能?

一个文本按钮说“A”,点击这个就像在画中一个应该能够在画布上画一个文本框,无论用户点击鼠标。还应该能够键入文本init.Also应该能够移动这个文本框在画布的任何地方。

任何建议/解决方案都很明显。

感谢。

1 个答案:

答案 0 :(得分:2)

这个基本框架应该让你入门。

此代码允许用户输入文本。

然后他们点击画布,他们的文字在鼠标位置绘制。

当然,您需要从这里开始设计它以满足您的需求。

这是代码和小提琴:http://jsfiddle.net/m1erickson/7GHvj/

<!doctype html>
<html>
<head>
<link rel="stylesheet" type="text/css" media="all" href="css/reset.css" /> <!-- reset css -->
<script type="text/javascript" src="http://code.jquery.com/jquery.min.js"></script>
<!--[if lt IE 9]><script type="text/javascript" src="../excanvas.js"></script><![endif]-->

<style>
    body{ background-color: ivory; }
    canvas{border:1px solid red;}
</style>

<script>
$(function(){

    var canvas=document.getElementById("canvas");
    var ctx=canvas.getContext("2d");
    var lastX;
    var lastY;
    var strokeColor="red";
    var strokeWidth=2;
    var canMouseX;
    var canMouseY;
    var canvasOffset=$("#canvas").offset();
    var offsetX=canvasOffset.left;
    var offsetY=canvasOffset.top;


    function handleMouseDown(e){
      canMouseX=parseInt(e.clientX-offsetX);
      canMouseY=parseInt(e.clientY-offsetY);
      $("#downlog").html("Down: "+ canMouseX + " / " + canMouseY);

      // Put your mousedown stuff here
      var text=document.getElementById("text").value;
      ctx.font = 'italic 20px sans-serif';
      ctx.fillText(text,canMouseX,canMouseY);
    }

    $("#canvas").mousedown(function(e){handleMouseDown(e);});

}); // end $(function(){});
</script>

</head>

<body>


    <p>Enter the text here first</p> 
    <input id="text" type="text" name="text" value="My Text."><br>
    <p>Then click on the canvas to draw the text.</p>
    <canvas id="canvas" width=576 height=307></canvas>

</body>
</html>