返回顶部
首页 > 资讯 > 前端开发 > VUE >如何使用HTML5+lufylegend实现游戏中的卷轴
  • 845
分享到

如何使用HTML5+lufylegend实现游戏中的卷轴

2024-04-02 19:04:59 845人浏览 薄情痞子
摘要

这篇文章将为大家详细讲解有关如何使用HTML5+lufylegend实现游戏中的卷轴,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 lufylegend是一个html5

这篇文章将为大家详细讲解有关如何使用HTML5+lufylegend实现游戏中的卷轴,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

lufylegend是一个html5开源引擎,它实现了利用仿ActionScript3.0的语法进行HTML5的开发, 包含了LSprite,LBitmapData,LBitmap,LLoader,LURLLoader,LTextField,LEvent等多个AS开发人员熟悉的类, 支持Google Chrome,Firefox,Opera,IE9,iOSAndroid等多种热门环境。 利用lufylegend可以轻松的使用面向对象编程,并且可以配合Box2dWEB制作物理游戏, 另外它还内置了LTweenLite缓动类等非常实用的功能, 现在开始使用它吧,它可以让你更快的进入HTML5的世界!

什么是卷轴

玩过RPG或者横版格斗的同学应该知道,人物走到屏幕中央后,由于地图过大,地图会进行移动,人物则相对静止不动。这个就是传说中的卷轴。例如下图是我的游戏“三国战线”里的卷轴:

有了以上的简介,大家应该明白了什么是卷轴。说白了就是镜头跟随主角的效果。接下来,我们就利用lufylegend.js游戏引擎来实现这个效果。

原理介绍

其实实现这个效果的关键在于如何使人物静止,何时移动地图,以及如何移动地图。在探究这个两个问题之前,我们先创建一个结构良好的舞台层(及一个LSprite对象),以便以后的操作。舞台结构如下:

+- 舞台层

|

+- 地图层

|

+- 人物层

可见舞台层就是地图层和人物层的父元素,并且人物层在地图层上方,毕竟人物是站在地图上的。我们知道,子对象的坐标是相对于父对象的,所以移动父对象,子对象会跟着移动。这点要先弄明白。

如何使人物静止呢?何时移动地图呢?如何移动地图呢?也许你会想,首先用if(xxx){...}来判断人物的坐标是否达到屏幕中央,如果是,则移动地图对象,如果不是则移动人物对象。这么做的话就麻烦了。其实有更简单的方法:

卷轴/不卷轴时,我们的人物都是在移动,但是如果人物达到屏幕中央时,要开始卷轴了,我们的舞台层就进行与人物速度方向相反、大小相同的移动,那么人物的相对于canvas画布的位移就抵消了,看上去就是静止的,而地图就跟着父类向反方向移动。这个类似于拍古装电影,拍两个人一边骑马一边谈话。如果人和马在前进,摄像机以相同的速度跟拍,那么得到的画面就是人物并没有移动,而人物背后风景是在移动的。

接下来看实现代码。

实现代码

以下是含有详细注释的代码:

LInit(30, 'mydemo', 700, 480, main);    

// 移动方向,null代表没移动    

var direction = null;    

// 小鸟,舞台层,背景对象    

var bird, stageLayer, bg;    

// 每次移动的长度    

var step = 5;    

function main () {    

// 资源列表    

var loadList = [    

{name : 'bird', path : './bird.png'},    

{name : 'bg', path : './bg.jpg'}    

];    

// 加载资源    

LLoadManage.load(loadList, null, demoInit);    

}    

function demoInit (result) {    

// 初始化舞台层    

stageLayer = new LSprite();    

addChild(stageLayer);    

// 加入背景    

bg = new LBitmap(new LBitmapData(result['bg']));    

bg.y = -100;    

stageLayer.addChild(bg);    

// 加入小鸟    

bird = new LBitmap(new LBitmapData(result['bird']));    

bird.x = 100;    

bird.y = 150;    

stageLayer.addChild(bird);    

// 添加鼠标按下事件    

stageLayer.addEventListener(LMouseEvent.MOUSE_DOWN, onDown);    

// 添加鼠标弹起事件    

stageLayer.addEventListener(LMouseEvent.MOUSE_UP, onUp);    

// 添加时间轴事件    

stageLayer.addEventListener(LEvent.ENTER_FRAME, onFrame);    

}    

function onDown (e) {    

    

if (e.offsetX > LGlobal.width / 2) {    

direction = 'right';    

} else {    

direction = 'left';    

}    

}    

function onUp () {    

// 设置方向为无方向,代表不移动    

direction = null;    

}    

function onFrame () {    

var _step, minX, maxX;    

    

if (direction == 'right') {    

_step = step;    

} else if (direction == 'left') {    

_step = -step;    

} else {    

return;    

}    

bird.x += _step;    

    

minX = 0,    

maxX = bg.getWidth() - bird.getWidth();    

if (bird.x < minX) {    

bird.x = minX;    

}else if (bird.x > maxX) {    

bird.x = maxX;    

}    

    

stageLayer.x = LGlobal.width / 2 - bird.x;    

    

minX = LGlobal.width - stageLayer.getWidth(),    

maxX = 0;    

if (stageLayer.x < minX) {    

stageLayer.x = minX;    

}else if (stageLayer.x > maxX) {    

stageLayer.x = maxX;    

}    

}    

关于“如何使用HTML5+lufylegend实现游戏中的卷轴”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: 如何使用HTML5+lufylegend实现游戏中的卷轴

本文链接: https://lsjlt.com/news/91705.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 如何使用HTML5+lufylegend实现游戏中的卷轴
    这篇文章将为大家详细讲解有关如何使用HTML5+lufylegend实现游戏中的卷轴,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 lufylegend是一个HTML5...
    99+
    2024-04-02
  • HTML5+lufylegend如何实现游戏中的卷轴
    这篇文章将为大家详细讲解有关HTML5+lufylegend如何实现游戏中的卷轴 ,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 lufyl...
    99+
    2024-04-02
  • 如何使用HTML5实现贪吃蛇游戏
    这篇文章将为大家详细讲解有关如何使用HTML5实现贪吃蛇游戏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 游戏操作说明 通过方向键控制贪吃蛇上下左右移动。贪吃蛇吃到...
    99+
    2024-04-02
  • 如何使用html5实现记忆翻牌游戏
    这篇文章主要为大家展示了“如何使用html5实现记忆翻牌游戏”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用html5实现记忆翻牌游戏”这篇文章吧。 &...
    99+
    2024-04-02
  • html5中如何使用63行代码实现贪吃蛇游戏
    这篇文章主要介绍html5中如何使用63行代码实现贪吃蛇游戏,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 代码如下:<!DOCTYPE HTML> <...
    99+
    2024-04-02
  • 如何使用原生JS实现圣旨卷轴展开效果
    这篇文章将为大家详细讲解有关如何使用原生JS实现圣旨卷轴展开效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。实现原理:(1)利用绝对定位固定好起始位置;(2)利用遮罩将...
    99+
    2024-04-02
  • 如何使用C++实现扫雷游戏
    这篇文章主要介绍了如何使用C++实现扫雷游戏,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。扫雷最原始的版本可以追溯到1973年一款名为“方块”的游戏。 不久,“方块”被改写成...
    99+
    2023-06-25
  • 如何使用Java实现经典游戏2048
    这篇文章主要介绍如何使用Java实现经典游戏2048,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!主要设计游戏面板生成显示方块设计键盘监听,方向键控制数字移动数字移动逻辑算法处理数字累加到2048,游戏胜利功能截图游...
    99+
    2023-06-29
  • 如何使用Java实现扫雷小游戏
    这篇文章主要介绍“如何使用Java实现扫雷小游戏”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“如何使用Java实现扫雷小游戏”文章能帮助大家解决问题。效果展示主类:GameWin类package&n...
    99+
    2023-06-30
  • 如何使用tkinter实现三子棋游戏
    小编给大家分享一下如何使用tkinter实现三子棋游戏,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!整体游戏很简单。下棋,判断胜利或者平局。没有加入电脑下棋的算法。游戏界面:代码:import tkinter&n...
    99+
    2023-06-06
  • 如何使用Python Pygame实现24点游戏
    这篇文章主要讲解了“如何使用Python Pygame实现24点游戏”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用Python Pygame实现24点游戏”吧!游戏介绍(1)什么是2...
    99+
    2023-07-06
  • .Net Core中如何使用SignalR实现斗地主游戏
    本篇内容主要讲解“.Net Core中如何使用SignalR实现斗地主游戏”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“.Net Core中如何使用SignalR实现斗地主游...
    99+
    2023-06-26
  • 如何使用Jquery实现时间轴
    这篇文章将为大家详细讲解有关如何使用Jquery实现时间轴,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、纵向折叠时间轴1、js文件(jQuery.js或者jQuery...
    99+
    2024-04-02
  • 如何使用JavaScript实现贪吃蛇小游戏
    这篇文章将为大家详细讲解有关如何使用JavaScript实现贪吃蛇小游戏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。JavaScript实现贪吃蛇小游戏功能概述本程序实...
    99+
    2024-04-02
  • 如何使用java实现猜数字小游戏
    这篇文章给大家分享的是有关如何使用java实现猜数字小游戏的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。题目描述:猜数字(又称 Bulls and Cows )是一种古老的的密码破译类益智类小游戏,起源于20世纪...
    99+
    2023-06-14
  • 如何使用Python实现愤怒小鸟游戏
    这篇文章给大家分享的是有关如何使用Python实现愤怒小鸟游戏的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。开发工具Python版本:3.6.4相关模块:pygame模块;以及一些python自带的模块。环境搭建...
    99+
    2023-06-15
  • 如何使用java实现马踏棋盘游戏
    小编给大家分享一下如何使用java实现马踏棋盘游戏,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体内容如下在4399小游戏中有这样一个游戏这是代码实现packa...
    99+
    2023-06-29
  • 怎么在HTML5中使用WebGL实现一个俄罗斯方块游戏
    怎么在HTML5中使用WebGL实现一个俄罗斯方块游戏?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。代码实现首先,先完成 2D 小游戏在查看官方文档的过程中,了解到 HT 的组...
    99+
    2023-06-09
  • C语言中如何使用递归实现排雷游戏
    这篇文章主要介绍了C语言中如何使用递归实现排雷游戏,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言扫雷,相信各位都不陌生,以前每台电脑上面都会自带这个小游戏。因此,它可以说...
    99+
    2023-06-25
  • Html5中Canvas实现一个“刮刮乐”游戏的方法
    小编给大家分享一下Html5中Canvas实现一个“刮刮乐”游戏的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!之前公司项目有一个刮奖小游戏的需求,因此有了本...
    99+
    2023-06-09
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作