PIXI 下落文字消除(3)
图片示例,简陋的图,记录下落过程,
1、创建应用实例并添加到DOM元素上。
(会看到一个黑色画布,没有任何元素,接下来会在画布上创建文字)
2、创建 TextStyle 用来设置要显示字体样式
3、随机产生字母(code,x, y,speed,isHas) 创建坐标及是否要创建该对象 (Text)
4、把字母渲染到画布上,从上到下运行
5、监听keyup事件,消除相应的数组
1、创建应用添加DOM
let app = new PIXI.Application({
width: 526,
height: 526
})
document.body.appendChild(app.view);
2、创建字体样式(我抄官网的)
// 字体样式
let style = new PIXI.TextStyle({
fontFamily: "Arial",
fontSize: 36,
fill: "white",
stroke: '#ff3300',
strokeThickness: 4,
dropShadow: true,
dropShadowColor: "#000000",
dropShadowBlur: 4,
dropShadowAngle: Math.PI / 6,
dropShadowDistance: 6,
});
3、创建随机文字对象并添加数组中,文字移动是对数组操作
var getRandom = function () {
var charCode = 97 + Math.floor(Math.random() * 26);
var speed = Math.ceil(Math.random() * 4);
return {
code: String.fromCharCode(charCode),
speed: speed,
y: 0,
x: Math.floor(Math.random() * app.view.width),
isHas: false //标记改对象是否需要创建,创建后true,不需要每次都创建
}
};
4、数组变量
var showArr = []; //每次随机创建文字位置
var txtoObjArr = []; // 在下边用来存储,Text对象,,下边看
随机产生文字 放到showArr数组中:
showArr.push(
getRandom()
);
// {x: 100, y:0, code: 'b' ,isHas: false}
txtoObjArr 里边存放的 new PIXI.Text();每次都会产生新的对象。判断该对象是否已创建 isHas,存在直接使用,否则创建
5、添加舞台
app.stage.addChild(txtoObjArr[j]);
6、让 txtoObjArr 里边的每个对象动起来(txtoObjArr 里边存放的是new PIXI.Text), 到画布底边销毁对象
for(var k = 0; k < txtoObjArr.length; k ++){
console.log(txtoObjArr)
// app.stage.addChild(txtoObjArr[k]);
txtoObjArr[k].x = showArr[k].x;
txtoObjArr[k].y = showArr[k].y;
txtoObjArr[k].text = showArr[k].code; // 销毁对象
if(txtoObjArr[k].y >= app.view.height){
txtoObjArr[k].destroy();
txtoObjArr.splice(k,1);
showArr.splice(k, 1); // 移除数组中元素
}
}
7、键盘按下去舞台元素消失(数组移除操作)
function keyEvent(ev){
for(var i= 0; i < showArr.length; i++){
if(showArr[i].code ==ev.key || String.fromCharCode(ev.keyCode).toLowerCase() == showArr[i].code){
showArr[i].text ='';
txtoObjArr[i].text='';
showArr.splice(i,1);
txtoObjArr.splice(i,1); }
}
}
本示例
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>test2</title>
<script src="pixi.min.js"></script>
</head>
<body> <script> let app = new PIXI.Application({
width: 526,
height: 526
})
document.body.appendChild(app.view); // 字体样式
let style = new PIXI.TextStyle({
fontFamily: "Arial",
fontSize: 36,
fill: "white",
stroke: '#ff3300',
strokeThickness: 4,
dropShadow: true,
dropShadowColor: "#000000",
dropShadowBlur: 4,
dropShadowAngle: Math.PI / 6,
dropShadowDistance: 6,
}); // 创建随机字母对象
var getRandom = function () {
var charCode = 97 + Math.floor(Math.random() * 26);
var speed = Math.ceil(Math.random() * 4);
return {
code: String.fromCharCode(charCode),
speed: speed,
y: 0,
x: Math.floor(Math.random() * app.view.width),
isHas: false
}
}; // 字母数组
var showArr = []; setInterval("createArry()", 100);
// createArry(); var txtoObjArr = [];
function createArry(){
if(Math.random() > 0.9){
showArr.push(getRandom());
// console.log(showArr);
}
// 元素运动
for(var i = 0; i< showArr.length; i++){
showArr[i].y += 1;
}
// 创建元素 for(var i = 0 ;i < showArr.length; i++){
if(showArr[i].isHas == false){ // 创建文字对象
var txtObj = new PIXI.Text("Hello Pixi!", style);
showArr[i].isHas = true;
// app.stage.addChild(txtObj);
// txtObj.x = showArr[i].x;
// txtObj.y = showArr[i].y;
// txtObj.text = showArr[i].code;
txtoObjArr.push(txtObj);
for(var j =0 ;j <txtoObjArr.length; j++){
app.stage.addChild(txtoObjArr[j]);
}
}
}
// 执行对象数组
for(var k = 0; k < txtoObjArr.length; k ++){
console.log(txtoObjArr)
// app.stage.addChild(txtoObjArr[k]);
txtoObjArr[k].x = showArr[k].x;
txtoObjArr[k].y = showArr[k].y;
txtoObjArr[k].text = showArr[k].code; // 销毁对象
if(txtoObjArr[k].y >= app.view.height){
txtoObjArr[k].destroy();
txtoObjArr.splice(k,1);
showArr.splice(k, 1); // 移除数组中元素
}
}
} function keyEvent(ev){
for(var i= 0; i < showArr.length; i++){
if(showArr[i].code ==ev.key || String.fromCharCode(ev.keyCode).toLowerCase() == showArr[i].code){
showArr[i].text ='';
txtoObjArr[i].text='';
showArr.splice(i,1);
txtoObjArr.splice(i,1); }
}
}
window.addEventListener("keyup", keyEvent);
// app.ticker.add(function (delta) {
// createArry();
// }); </script>
</body>
</html>
PIXI 下落文字消除(3)的更多相关文章
- 趣味python编程之经典俄罗斯方块
国庆期间闲不住,用python把经典俄罗斯方块实现了一遍,找到了些儿时的乐趣.因此突发奇想,打算用python写点经典又确实有趣的小程序形成系列.正统编程之余也给自己找点儿乐趣,换个角度写程序. 原计 ...
- pnd3
这两天重写了,消除后本身的下落计算还有问题,新产生的块下落和消除已经OK了.消除算法真的很要命.最后还是回归最开始的想法,用递归的方式不断的SPREAD来得到消除的数据.快到月底了,得勤写写了,要不找 ...
- Luogu 1312 【NOIP2011】玛雅游戏 (搜索)
Luogu 1312 [NOIP2011]玛雅游戏 (搜索) Description Mayan puzzle 是最近流行起来的一个游戏.游戏界面是一个7行5列的棋盘,上面堆放着一些方块,方块不能悬空 ...
- Noip 2011 Day 1 & Day 2
Day 1 >>> T1 >> 水题一道 . 我们只需要 for 一遍 , 由于地毯是从下往上铺的 , 我们只需要记录该位置最上面的地毯的编号 , 每一次在当前地 ...
- iOS—图片编辑,文字下落动画的Demo
仿照Mac上的截图编辑功能做的一个图片编辑的Demo,功能有画矩形,圆形,箭头,手写,输入文字和分享. 做的时候看到一个大神的帖子写的一个文字动画的教程,故顺带学习做了一个类似的文字下落动画. 有兴趣 ...
- JS 黑客帝国文字下落效果
黑客帝国文字下落效果 源代码如下: <!DOCTYPE html> <html> <head> <meta charset="utf-8" ...
- 如何消除类型是submit类型的按钮的默认文字 ‘确认提交’
只需要加上value="" 即可.默认的文字就可以去掉了.
- js实现黑客帝国文字下落效果
突然想到这个效果便想实现以下. 当然免不了要百度一下,于是查找到 http://www.cnblogs.com/myvin/p/4775152.html这篇文章, 效果可以查看博文中的给出的效果图.那 ...
- JS+CSS+HTML实现“代码雨”类似黑客帝国文字下落效果
HTML代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <l ...
随机推荐
- 解析json的方法
解析json的两种方法:JS中的eval().JSON.parse eval不仅解析内容还会解析其中的方法,JSON.parse解析更安全.JSONLint可校验json的错误.
- Chrome浏览器控件安装方法
说明:只需要安装up6.exe即可,up6.exe为插件集成安装包. 1.以管理员身份运行up6.exe.up6.exe中已经集成Chrome插件.
- cmake的一些词的解释
cmake中一些预定义变量 PROJECT_SOURCE_DIR 工程的根目录 PROJECT_BINARY_DIR 运行cmake命令的目录,通常是${PROJECT_SOURCE_DIR} ...
- 软件工程:Java实现WC.exe基本功能
项目相关要求 GitHub地址:https://github.com/3216004716/WC 实现一个统计程序,它能正确统计程序文件中的字符数.单词数.行数,以及还具备其他扩展功能,并能够快速地处 ...
- Js 正则获取Html元素
var html = $("#summaryTemplate").html(); var imageMath = /<img [^<,>]*(?=target-t ...
- [database] postgresql 外网访问
配置 环境 ubuntu 14.04 LTS 版本 postgresql version 9.3 修改监听地址 编辑 /etc/postgresql/9.3/main/postgresql.conf ...
- IIS部署SSL,.crt .key 的证书,怎么部署到IIS
SSL连接作用不说,百度很多.因为最近想考虑重构一些功能,在登录这块有打算弄成HTTPS的,然后百度了,弄成了,就记录一下,以便以后万一部署的时候忘记掉. 做实验的时候,拿的我个人申请的已经备案的域名 ...
- Kylin存储和查询的分片问题
本文来自网易云社区 作者:汪胜 相关概念介绍 为了了解Kylin存储和查询的分片问题,需要先介绍两个重要概念:segment和cuboid.相信大数据行业的相关同学都不陌生.Kylin每次提交一个新的 ...
- Linux下抓包命令tcpdump
本文内容来源于网络 PS:tcpdump是一个用于截取网络分组,并输出分组内容的工具,简单说就是数据包抓包工具.tcpdump凭借强大的功能和灵活的截取策略,使其成为Linux系统下用于网络分析和问题 ...
- java 中 ==
@Test public void fuu2(){ String a = new String("aw"); String b = new String("aw" ...