来自用户输入的字母阴影

Letter Shadows from User Input

本文关键字:阴影 输入 用户      更新时间:2023-09-26

目标:用户在用户输入字段中键入名称,选择"动画"按钮,名称将垂直打印,每个字母都包含每个字母的阴影。Java脚本库Raphael可能是可取的。

问题:到目前为止,我的名字是并排垂直打印两次的。显然,第二列应该是作为阴影的字母,但我不知道如何更改它们的样式,使其看起来像阴影。

我的经理给了我一个提示:"我必须在文本下面创建第二行文本……我在上面使用了.blur()方法。如果我必须再给你一个提示,我会提示你到门口。"

我在这里遇到了一些真正的麻烦。如果有人有建议,解决方案,任何事情都将不胜感激。

<html> 
<head> 
<script src="raphael-min.js"></script> 
<script src="jquery-1.7.2.js"></script>  
<script type="text/javascript">   
function animate() {  
var txt = document.getElementById("words").value;
var area = txt;
var splittxt = txt.split("");
document.getElementById("letters").innerHTML = "";
document.getElementById("letters2").innerHTML = "";
var i;
for (i = 0; i < splittxt.length; i++) {
document.getElementById("letters").innerHTML = document.getElementById("letters").innerHTML + splittxt[i] + "<br>";
document.getElementById("letters2").innerHTML = document.getElementById("letters2").innerHTML + splittxt[i] + "<br>";
}
//displays how many symbols are in text box and what is in text box
document.getElementById("num").innerHTML= txt.length;          
document.getElementById("msg").innerHTML = txt;          
r.clear();      
// Make our pink rectangle 
ellipse = r.ellipse(40, 15, 30, 5).attr({"fill": "#969696", "stroke": "none"}); 
ellipse.glow({width:10});  
}      
</script>
<style type="text/css">
#letters
{
background-color:yellow;
width:25px;
float:left;
}
#letters2
{
letter-spacing:0px;
display:block;
-moz-transform: rotate(80deg);  
margin-left:90px;
margin-top:80px;
width:25px;
color:#DEDEDE;
}
</style>
</head> 
<body>  
Text: <input type="text" id="words" value="" /> 
<input type="button" value="Animate" onclick="animate()" /> 
<div id='msg'></div> 
<div id='num'></div>
<div id='letters'></div>
<div id="letters2"></div>
<div id="draw-here-raphael" style="height: 200px; width: 400px; margin-top:0px;"> 
</div> 
<div id="elps" style="margin-left:100px;"/>  
<script type="text/javascript"> //all your javascript goes here  
var r = new Raphael("draw-here-raphael");  
</script>
</body> 
</html>

长命百岁。

你真的需要拉斐尔吗?我所做的只是简单地将你的单词打印到一个元素上,并用css的文本阴影获得阴影。为了获得垂直文本,我在每个字母后面添加了一个</br>

看看小提琴:http://jsfiddle.net/joplomacedo/wVGbF/

以下是代码,以防你看不到小提琴:

HTML

Text: <input type="text" id="words" value="" /> 
      <input id="animateBtn" type="button" value="Animate" />
      <div class="print"></div>

CSS

.print {
    font: 44px/0.8em "Lobster", cursive;
    color: gold;
    text-shadow: 2px 2px 3px rgba(0, 0, 0, 0.6);
}​

JS-

var join = Array.prototype.join;
$('#animateBtn').on('click', function() {
    var txt = $('#words').val(),
        spaced_txt = join.call(txt, "</br>");
    $('.print').html(spaced_txt);
});​

这也是Raphael的文本输出函数:

function draw_text() {
  var txt = document.getElementById("words").value;
  var posy = txt.length*10;
  r.clear();
  var attr = {font: "50px Helvetica", opacity: 0.5};
  var text = r.text(40, 40+posy, txt).attr(attr).attr({fill: "#0f0"}); // underlayer or "shadow"
  text.attr({transform: "r270"}); // rotate 270 degrees
  var text2 = r.text(43, 43+posy, txt).attr(attr).attr({fill: "#aa0"}); // text above
  text2.attr({transform: "r270"}); // rotate 270 degrees
  r.safari();
}
var r = new Raphael("draw-here-raphael");

基于这个例子的完整脚本在这里。