首先说下想要实现的效果。在htmlText里有多个A标签,想要鼠标滑到不同的标签时,显示不同的颜色.很明显的使用html+css( styleSheel)比较方便。OK,既然是html+css,一开始我还觉得很是简单,因为AS3支持部分css的,但是当我真正去实现的时候才明白.好多事情并不是那么的想当然。
html+css的简单思路
我们使用html+css的思路来看这个问题,实在是超简单的,首先使用下面的html:
This is A1
This is A2
然后再配合下面的css来实现:
.a1 a:hover{ color:#FF0000; }
.a2 a:hover{ color:#00FF00; } 这样开起来很不错,但是很遗憾,AS3的 TextFiled.htmlText 不支持css的联合选择器.所以不能将class .a1与伪类 a:hover同时使用。如果自己解析html+解析css+textFormat不太现实。
变通办法
虽然AS3不支持css的联合选择器,但是对于单个选择器还是支持的。因此可以先给html文本设置默认的css样式,当鼠标移动到需要改变样式的字符上,再应用对应的样式即可。
这个思路的难点在于如何知道鼠标移动到了需要改变的字符上,其实有两种解决方法:
- 判断字符在文本中的索引,根据索引段来应用对应的样式。
- 链接文本时,根据文本的url来应用对应的样式。
这里使用第二种,因为我们有链接文本。那么配合MouseEvent.MOUSE_OVER事件+ TextFormat.url 来实现。
将上面的css拆分为2个css,并且修改html代码为:
This is A1
This is A2
这样,鼠标到不同的a标签上,使用不同的css就可以了。
演示示例
后话
其实AS3对html及css的支持很少。仅支持 CSS1 的一部分而不是全部,所以做一些简单的样式还是蛮好用的,但是复杂的就不要奢望了,而且就这篇文章里的例子,如果推广到非A标签的情况就不好解决了。当然Adobe的帮助文档也没有具体说明哪些css被支持,那么当我们想要使用时还是需要先测试下才好。
A标签有4个伪类:
:link未访问的链接(AS3不区别是否访问过):visited已访问的链接(AS3不支持):active选定的链接(在鼠标点击与释放之间发生的事件):hover鼠标移动到链接上
源代码
package {
import flash.display.Sprite;
import flash.events.MouseEvent;
import flash.text.StyleSheet;
import flash.text.TextField;
import flash.text.TextFormat;
/**
* ...
* @author lite3
*/ public class AhoverTest extends Sprite
{
private var txt:TextField;
private var style1:StyleSheet;
private var style2:StyleSheet;
public function AhoverTest()
{
var html:String = "This is A1
" +
"This is A2";
style1 = new StyleSheet();
style1.parseCSS("a:hover { color:#FF0000; }");
style2 = new StyleSheet();
style2.parseCSS("a:hover { color:#00FF00; }");
txt = new TextField();
txt.multiline = true;
txt.styleSheet = style1;
txt.htmlText = html;
addChild(txt);
txt.addEventListener(MouseEvent.MOUSE_MOVE, moveHandler);
}
private function moveHandler(e:MouseEvent):void
{
var i:int = txt.getCharIndexAtPoint(e.localX, e.localY);
if (i » 转载请注明来源:www.litefeel.com » 《AS3中实现多样化的A标签》
» 本文链接地址:https://www.litefeel.com/css-more-a-hover-in-as3/
» 订阅本站:www.litefeel.com/feed/
» Host on Linode VPS This post was last modified on 2019 年 02 月 28 日 01:23