常规处理:

    private createGameScene():void {
var shp = new egret.Shape();
shp.graphics.beginFill(0xff0000, 1);
shp.graphics.drawRect(0, 0, 480, 800);
shp.graphics.endFill();
this.addChild(shp); var label:egret.TextField = new egret.TextField();
label.text = "实例文本"; //设置文本内容
label.width = 480;
label.height = 800;
label.size = 80; //设置字号大小
label.textColor = 0x00ff00; //设置字体颜色
label.fontFamily = "KaiTi"; //设置字体样式
label.textAlign = egret.HorizontalAlign.RIGHT; //水平右对齐,相对于 textField 控件自身的 width 与 height
label.verticalAlign = egret.VerticalAlign.TOP; //垂直上对齐
label.strokeColor = 0x0000ff; //描边颜色
label.stroke = 2; //描边宽度
this.addChild(label);
}

常用字体表:

中文名称 font-family
宋体 SimSun
黑体 SimHei
微软雅黑 Microsoft YaHei
微软正黑体 Microsoft JhengHei
新宋体 NSimSun
新细明体 PMingLiU
细明体 MingLiU
标楷体 DFKai-SB
仿宋 FangSong
楷体 KaiTi
仿宋_GB2312 FangSong_GB2312
楷体_GB2312 KaiTi_GB2312

自定义字体:

  需要改成自定义的字体,需要设置对应的 default_fontFamily 的路径。路径开始不加 ‘/‘则从项目的主目录开始,加了则从系统的目录中去查找。

  由于在发布的时候 resource 文件夹下的文件名会被序列化,建议不要放到 resource 下面,单独放到一个 fonts 文件夹下面并且在发布的时候手动拷贝到 native 工程中。

  示例:

  

JSON 样式配置:

  textField.textFlow 接受 egret.ITextElement 数组

interface ITextElement
{
text:string;
style?:ITextStyle;
}
    private createGameScene():void {
var tx:egret.TextField = new egret.TextField;
tx.width = 400;
tx.x = 10;
tx.y = 10;
tx.textColor = 0;
tx.size = 50;
tx.fontFamily = "微软雅黑";
tx.textAlign = egret.HorizontalAlign.CENTER;
tx.textFlow = <Array<egret.ITextElement>>[ //转换成元素为 egret.ITextElement 的数组
{text: "妈妈再也不用担心我在", style: {"size": 12}} //ts 语法看久了容易混成 C#.. 对象怎么这样? 才想起是 ts 脚本
, {text: "Egret", style: {"textColor": 0x336699, "size": 60, "strokeColor": 0x6699cc, "stroke": 2}}
, {text: "里说一句话不能包含各种", style: {"fontFamily": "楷体"}}
, {text: "五", style: {"textColor": 0xff0000}}
, {text: "彩", style: {"textColor": 0x00ff00}}
, {text: "缤", style: {"textColor": 0xf000f0}}
, {text: "纷", style: {"textColor": 0x00ffff}}
, {text: "、\n"}
, {text: "大", style: {"size": 36}}
, {text: "小", style: {"size": 6}}
, {text: "不", style: {"size": 16}}
, {text: "一", style: {"size": 24}}
, {text: "、"}
, {text: "格", style: {"italic": true, "textColor": 0x00ff00}}
, {text: "式", style: {"size": 16, "textColor": 0xf000f0}}
, {text: "各", style: {"italic": true, "textColor": 0xf06f00}}
, {text: "样", style: {"fontFamily": "楷体"}}
, {text: ""}
, {text: "的文字了!"}
];
this.addChild( tx );
}

文本超链接:

    private createGameScene():void {
var tx:egret.TextField = new egret.TextField;
tx.textFlow = <Array<egret.ITextElement>>[
{ text:"点击响应", style:{"href":"event:has been triggered.", "size":80}}, //href 可以指定 url 或者是 event,默认为 url
{ text:"\n点击无响应", style:{"size":80}}
]; tx.touchEnabled = true;
tx.addEventListener(egret.TextEvent.LINK, (evt:egret.TextEvent) => {
console.log(evt.text);
}, this); tx.x = 10;
tx.y = 10;
this.addChild(tx);
}

文本输入:

    //白色输入框背景板
private layTxBg(tx:egret.TextField)
{
var shp:egret.Shape = new egret.Shape();
shp.graphics.beginFill(0xffffff);
shp.graphics.drawRect(tx.x, tx.y, tx.width, tx.height);
shp.graphics.endFill();
this.addChild(shp);
} /**
* 创建游戏场景
* Create a game scene
*/
private createGameScene():void
{
//绘制绿色背景板
var shp: egret.Shape = new egret.Shape();
shp.graphics.beginFill(0x00ff00);
shp.graphics.drawRect(0,0,640,960);
shp.graphics.endFill();
this.addChild(shp); //黑字输入框
var txInput:egret.TextField = new egret.TextField();
txInput.type = egret.TextFieldType.INPUT; //设置文本样式-输入框
txInput.width = 200;
txInput.height = 50;
txInput.x = 50;
txInput.y = 50;
txInput.textColor = 0x000000; this.layTxBg(txInput);
this.addChild(txInput); var button = new egret.Shape();
button.graphics.beginFill(0x00cc00);
button.graphics.drawRect(50, 200, 100, 40);
button.graphics.endFill();
button.x = 50;
button.y = 200;
button.touchEnabled = true;
button.addEventListener(egret.TouchEvent.TOUCH_BEGIN, (e) => { //第一次触摸控件时,将焦点设置在文本输入控件上
txInput.setFocus();
}, this);
this.addChild(button);
}

通过设置输入样式可以控制弹出的键盘类型:

egret.TextFieldInputType.TEXT;         //九宫格输入
egret.TextFieldInputType.PASSWORD; //英文键盘
egret.TextFieldInputType.TEL; //数字键盘

Egret 文本处理的更多相关文章

  1. Egret引擎随学随机

    1.纹理集实际上就是将一些零碎的小图放到一张大图当中.游戏中也经常使用到纹理集.使用纹理集的好处很多,我们通过将大量的图片拼合为一张图片从而减少网络请求,原先加载数次的图片资源现在加载一次即可.同时, ...

  2. 【咸鱼教程】Egret中可长按复制的文本(例如复制优惠码)

    一 实际效果二 实现原理三 源码下载 在egret中实现长按复制文本效果,一般用于复制优惠码什么的. 一 实际效果         二 实现原理 在egret的游戏元素都是绘制在canvas上的,我们 ...

  3. egret GUI 文本混排+文本链接的聊天解决方案【取巧法】

    ui方面: <e:Scroller verticalScrollPolicy="auto" width="468" height="620&qu ...

  4. EUI 自动滚动的聊天文本

    一 自动滚动的聊天文本 当文本输入改变时,将scrollV值等于maxScrollV值. private scrollLabel:eui.Label; egret.Tween.).call(()=&g ...

  5. Egret白鹭H5小游戏开发入门(三)

    前言: 在上一篇文章中着重介绍了H5小游戏开发的起步阶段,如Wing面板的使用,素材的处理,类的说明等等,那么今天主要是涉及到场景的创建,loading的修改等等的代码编写. 对于这一节,我在讲解的过 ...

  6. Html5 Egret游戏开发 成语大挑战(六)游戏界面构建和设计

    本篇将主要讲解游戏界面的构建和设计,会应用到egret.eui的自定义组件,可以很直观的构建一个游戏整体,这里我们仍然只需要使用EgretWing就可以达到目的,本篇可能是篇幅最少的一个,但是涉及自定 ...

  7. Html5 Egret游戏开发 成语大挑战(三)开始界面

    本篇需要在前面的素材准备完毕,才可以开始,使用egret的eui结合代码编辑,快速完成基本的界面搭建,这里写的可能比较细,目的是减少大家对于其中一些操作疑问,我去掉了很多无用的步骤,以最精简的流程来完 ...

  8. Egret官方案例学习笔记

    1.资源记载方式 (1)Egret引擎是2.0.5. (2)resource/resource.json文件是: { "resources": [ { "name&quo ...

  9. Egret 矢量绘图、遮罩、碰撞检测

    矢量绘图: 1. 为矢量绘图绘制外边 - graphics.lineStype() private createGameScene():void { console.log("Runtime ...

随机推荐

  1. segment

    1.segmentedControlStyle 设置segment的显示样式. typedef NS_ENUM(NSInteger, UISegmentedControlStyle) { UISegm ...

  2. ServletConfig

    ServletConfig Servlet配置 比如web程序中的某一个Servlet需要配置一些初始化信息,需要在web.xml中进行配置 <servlet> <servlet-n ...

  3. javascript变量 数组 对象

    一 变量 1.全局变量和局部变量 在JavaScript中同一个变量可以反复赋值,而且可以是不同类型的变量,但是要注意只能用var声明一次.这种变量类型不固定的语言称为动态语言,与之对应的静态语言,如 ...

  4. Git git rebase 使用

      原文:http://gitbook.liuhui998.com/4_2.html 一.基本 git rebase用于把一个分支的修改合并到当前分支. 假设你现在基于远程分支"origin ...

  5. 2016最新cocoapods版本更新,以及多个版本的问题

    先删除之前的pod 在终端中执行下面命令. 删除目录下的podrm -rf /usr/local/bin/pod 执行gem list | grep cocoapods 查看所有与cocoapods相 ...

  6. 一个IT男的创业感言

    2014年的一月 我和高中的一个同学開始人生的第一次创业.就写点第一次创业的经验吧! 创业的最初 须要心中大概有个规划 这个规划可能是非常粗糙的 但大的方向一定要有.详细就是你进入的行业 行业已经存在 ...

  7. SDK目录结构和adb工具及命令介绍

    1.SDK目录介绍: ******************************** add-ons:Android开发需要的第三方文件,附加的库,如Google APIs.GoogleMaps. ...

  8. Day2 - Python基础2 列表、字典、集合

    Python之路,Day2 - Python基础2   本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一, ...

  9. python的局部变量和全局变量

    #coding=utf-8#全局变量与局部变量 #作用域def func(): i=8#print i# print object# j=9# print j #局部变量def func(a): i= ...

  10. VBA取得EXCEL表格中的行数和列数

    VBA取得EXCEL表格中的行数和列数 初学EXCEL宏的童鞋,总是很想知道表格中含有数据的行数和列数,尤其是行数和列数不确定的情况下.这样可以避免很多的错误,并且可以提高效率.但每次用到的时候到网上 ...