Canvas背景绘制-24

本节会详细介绍下,如何绘制面板的背景。

概述

常用的技术称为图块复制(blitting),即从离屏缓冲区中将内容发生变化的那部分背景图像复制到屏幕上,还有其它两种方法是将所有内容擦除并重新绘制&仅重绘内容发生变化的那部分区域。一般是用clip()方法来实现的.如果背景比较简单采用将所有内容擦除再重新绘制可能性能更好。

代码示例

基本上下文设置

/*
【1】、用这些技术不用担心闪屏的问题,因为浏览器在实现时都采用了双缓冲技术。即把修改后的图像放在离屏文件中,然后一次性复制到显示区域内。**不需要个人实现**   
*///整个绘制的技术
context.save();
context.clearRect(0, 0, canvas.width, canvas.height);
drawBackground();
context.restore();//利用剪辑区域技术来恢复上一帧动画所占背景图像的执行步骤,这种技术只能操作简单的图像,如果canvas上对象比较多也会比较吃力,最好的方法还是blitting。
context.save();//保存屏幕canvas的状态
context.beginPath();//开始一段新的路径
context.arc();//设置路径
context.clip();//设置剪辑区
eraseBackground();//擦除上一帧物体的图像
drawBackground();//绘制整个背景,因为设置了剪辑区所以只会绘制那一部分
context.restore();//恢复canvas状态/*blitting技术,将整个背景一次性绘制到离屏canvas中,稍后从离屏canvas中只将修复动画背景所需的那一块图像复制到屏幕上,它比其它技术要快,缺点是离屏文件占用了部分内存*/
context.save();
context.beginPath();
context.arc();
context.clip();
context.clearRect(0, 0, canvas.width, canvas.height);
context.drawImage(offscreenCanvas, ......);//从离屏文件中复制那一小布内容到显示区域上
context.restore();

背景滚动技术

背景滚动技术,当有多个物体时,场景会有远近,所以背景滚动时,后面的要移动的慢,前面的要快些,这样造成了视觉我看着

//....................背景滚动技术......................................
var lastTime = 0,
fps = 0,
skyOffset = 0,
SKY_VELOCITY = 300; // 30 pixels/second,预先设定的速度,这个值设定好是有原因的,因为像汽车这样的游戏,速度多少是要根据实际情况换算出来的
function draw() {context.save();skyOffset = skyOffset < canvas.width ?skyOffset + SKY_VELOCITY/fps : 0;context.save();context.translate(-skyOffset, 0);context.drawImage(sky, 0, 0);context.drawImage(sky, sky.width-2, 0);//绘制两次是为了做个简单的循环context.restore();
}
//计算出帧数,这是由requestAnimationFrame()方法间隔来计算的
function calculateFps(now) {var fps = 1000 / (now - lastTime);lastTime = now;return fps; 
}/*这种技术主要是SKY_VELOCITY的不同值来实现的,需要注意的是为了循环的首尾相接,所以每个图像都要复制两份,并注意save()和restore()的使用*/var TREE_VELOCITY = 20,FAST_TREE_VELOCITY = 40,SKY_VELOCITY = 8,GRASS_VELOCITY = 75;function draw() {context.save();//计算不同的速度skyOffset = skyOffset < canvas.width ?skyOffset + SKY_VELOCITY/fps : 0;grassOffset = grassOffset < canvas.width ?grassOffset +  GRASS_VELOCITY/fps : 0;treeOffset = treeOffset < canvas.width ?treeOffset + TREE_VELOCITY/fps : 0;nearTreeOffset = nearTreeOffset < canvas.width ?nearTreeOffset + FAST_TREE_VELOCITY/fps : 0;//每个都要复制两次*************context.save();context.translate(-skyOffset, 0);context.drawImage(sky, 0, 0);context.drawImage(sky, sky.width-2, 0);context.restore();context.save();context.translate(-treeOffset, 0);context.drawImage(tree, 100, 240);context.drawImage(tree, 1100, 240);context.drawImage(tree, 400, 240);context.drawImage(tree, 1400, 240);context.drawImage(tree, 700, 240);context.drawImage(tree, 1700, 240);context.restore();context.save();context.translate(-nearTreeOffset, 0);context.drawImage(nearTree, 250, 220);context.drawImage(nearTree, 1250, 220);context.drawImage(nearTree, 800, 220);context.drawImage(nearTree, 1800, 220);context.restore();context.save();context.translate(-grassOffset, 0);context.drawImage(grass, 0, canvas.height-grass.height);context.drawImage(grass, grass.width-5, canvas.height-grass.height);context.drawImage(grass2, 0, canvas.height-grass2.height);context.drawImage(grass2, grass2.width,canvas.height-grass2.height);context.restore();}
//在这里插入HTML代码片断

大体效果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/792048.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

网络:HTTP协议

目录 序列化与反序列化 守护进程 网络计算器的实现 HTTP协议 http的代码演示 HTTPS 初步理解三次握手&#xff0c;四次挥手 ①tcp是面向连接的通信协议&#xff0c;在通信之前&#xff0c;需要进行3次握手&#xff0c;来进行连接的建立(谁connect谁握手) ②当tcp在断开…

稀碎从零算法笔记Day35-LeetCode:字典序的第K小数字

要考虑完结《稀碎从零》系列了哈哈哈 这道题和【LC.42 接雨水】&#xff0c;我愿称之为【笔试界的颜良&文丑】 题型&#xff1a;字典树、前缀获取、数组、树的先序遍历 链接&#xff1a;440. 字典序的第K小数字 - 力扣&#xff08;LeetCode&#xff09; 来源&#xff1…

Linux是怎么发送一个网络包的?

目录 摘要 1 从 send 开始 2 传输层 3 网络层 4 网络接口层 4.1 邻居子系统 4.2 网络设备子系统 4.3 软中断发送剩余的 skb 4.4 硬中断又触发软中断 总结 摘要 一个网络包的发送&#xff0c;始于应用层&#xff0c;经层层协议栈的封装&#xff0c;终于网卡。今天来循…

ubuntu18.04图形界面卡死,鼠标键盘失灵, 通过MAC共享网络给Ubuntu解决!

ubuntu18.04图形界面卡死&#xff0c;鼠标键盘失灵&#xff0c; 通过MAC共享网络给Ubuntu解决&#xff01; 1. 尝试从卡死的图形界面切换到命令行界面2. 进入bios和grub页面3. 更改Grub中的设置&#xff0c;以进入命令行4. 在命令行页面解决图形界面卡死的问题5. Mac共享WI-FI网…

【MySQL】数据库的基本操作

目录 一、数据库的库操作 二、数据库的表操作 一、数据库的库操作 数据库的创建 create database (if not exists) 库名 这里的if not exists 是一个判断用的&#xff0c;如果数据库存在&#xff0c;就不执行语句&#xff0c;如果数据库不存在&#xff0c;则执行该语句。 创建…

vulhub中Apache Solr Velocity 注入远程命令执行漏洞复现 (CVE-2019-17558)

Apache Solr 是一个开源的搜索服务器。 在其 5.0.0 到 8.3.1版本中&#xff0c;用户可以注入自定义模板&#xff0c;通过Velocity模板语言执行任意命令。 访问http://your-ip:8983即可查看到一个无需权限的Apache Solr服务。 1.默认情况下params.resource.loader.enabled配置…

C++实现vector

目录 前言 1.成员变量 2.成员函数 2.1构造函数 2.2析构函数 2.3begin,end 2.4获取size和capacity 2.5函数重载【】 2.6扩容reserve 2.7resize 2.8insert 2.9删除 2.10尾插、尾删 3.0拷贝构造函数 3.1赋值运算符重载 前言 自主实现C中vector大部分的功能可以使我们更好的理解并使…

红黑树介绍与模拟实现(insert+颜色调整精美图示超详解哦)

红黑树 引言红黑树的介绍实现结点类insert搜索插入位置插入调整当parent为gparent的左子结点当parent为gparent的右子结点 参考源码测试红黑树是否合格总结 引言 在上一篇文章中我们认识了高度平衡的平衡二叉树AVL树&#xff1a;戳我看AVL树详解哦 &#xff08;关于旋转调整的…

Java 7、Java 8常用新特性

目录 Java 8 常用新特性1、Lambda 表达式2、方法引用2.1 静态方法引用2.2 特定对象的实例方法引用2.3 特定类型的任意对象的实例方法引用2.4 构造器引用 3、接口中的默认方法4、函数式接口4.1 自定义函数式接口4.2 内置函数式接口 5、Date/Time API6、Optional 容器类型7、Stre…

(四) 序列化器类使用整理

从一、序列化器类中&#xff0c;或 视图集源码 中&#xff0c; 可以得知&#xff1a; 序列化器类可以接收一个instance &#xff0c;和一个data serializer_obj XxxxSerializer(instance,datarequest.data) &#xff08;更新时&#xff0c;instance相当于原…

云原生技术精选:探索腾讯云容器与函数计算的最佳实践

文章目录 写在前面《2023腾讯云容器和函数计算技术实践精选集》深度解读案例集特色&#xff1a;腾讯云的创新实践与技术突破精选案例分析——Stable Diffusion云原生部署的最佳实践精选集实用建议分享总结 写在前面 在数字化转型的浪潮下&#xff0c;云计算技术已成为企业运营…

Kafka入门到实战-第五弹

Kafka入门到实战 Kafka常见操作官网地址Kafka概述Kafka的基础操作更新计划 Kafka常见操作 官网地址 声明: 由于操作系统, 版本更新等原因, 文章所列内容不一定100%复现, 还要以官方信息为准 https://kafka.apache.org/Kafka概述 Apache Kafka 是一个开源的分布式事件流平台&…

基于springboot+vue实现的酒店客房管理系统

作者主页&#xff1a;Java码库 主营内容&#xff1a;SpringBoot、Vue、SSM、HLMT、Jsp、PHP、Nodejs、Python、爬虫、数据可视化、小程序、安卓app等设计与开发。 收藏点赞不迷路 关注作者有好处 文末获取源码 技术选型 【后端】&#xff1a;Java 【框架】&#xff1a;spring…

昇腾训练执行与推理部署系列 入门: 1.开启异腾AI之旅

一、1认识CANN 1、昇腾AI基础软硬件平台介绍2、CANN逻辑架构介绍 1、昇腾AI基础软硬件平台介绍 2、CANN逻辑架构介绍

普联一面4.2面试记录

普联一面4.2面试记录 文章目录 普联一面4.2面试记录1.jdk和jre的区别2.java的容器有哪些3.list set map的区别4.get和post的区别5.哪个更安全6.java哪些集合类是线程安全的7.创建线程有哪几种方式8.线程的状态有哪几种9.线程的run和start的区别10.什么是java序列化11.redis的优…

商品购买过程中,库存的抵扣过程是怎样的?如何防止超卖?

在商品购买的过程中&#xff0c;库存的抵扣过程&#xff0c;一般操作如下&#xff1a; 1、select根据商品id查询商品的库存。 2、根据下单的数量&#xff0c;计算库存是否足够&#xff0c;如果存库不足则抛出库存不足的异常&#xff0c;如果库存足够&#xff0c;则减去扣除的…

mysql+keepalive+lvs搭建的数据库集群实验

前提条件&#xff1a;准备5台计算机&#xff0c;且网络互通 1、客户端 yum groups -y install mariadb-client ip 192.168.0.5 2、lvs1 yum-y install ipvsadm keepalived ip 192.168.0.1 keepalivedvip 192.168.0.215 /etc/hosts 解析192.168.0.1 主机名 3、lvs2 yum-y i…

前视声呐目标识别定位(五)-代码解析之修改声呐参数

前视声呐目标识别定位&#xff08;一&#xff09;-基础知识 前视声呐目标识别定位&#xff08;二&#xff09;-目标识别定位模块 前视声呐目标识别定位&#xff08;三&#xff09;-部署至机器人 前视声呐目标识别定位&#xff08;四&#xff09;-代码解析之启动识别模块 …

DHT11温湿度传感器使用视频教程分享

下载地址&#xff1a; 温湿度计(STCDHT11): https://url83.ctfile.com/d/45573183-60623983-9b7f6c?p7526 (访问密码: 7526)

Java常用类和基础API

文章目录 1. 字符串相关类之不可变字符序列&#xff1a;String1.1 String的特性1.2 String的内存结构1.2.1 概述1.2.2 练习类型1&#xff1a;拼接1.2.3 练习类型2&#xff1a;new1.2.4 练习类型3&#xff1a;intern() 1.3 String的常用API-11.3.1 构造器1.3.2 字符串对象的比较…