当前位置: 首页 > news >正文

香港 wordpress 推荐/天津搜索引擎优化

香港 wordpress 推荐,天津搜索引擎优化,学校网站群建设方案,广州 骏域网站建设专家当大佬给发这两张图的时候,啊,我的眼睛!定睛一看都要看瞎了好么。 再看跟随的话语,能筛掉一多半来面试前端的人? 好家伙还是一道前端面试题么。 nonono,这不是div堆叠做的,这么多div你想累死…

请添加图片描述
请添加图片描述
当大佬给发这两张图的时候,啊,我的眼睛!定睛一看都要看瞎了好么。

再看跟随的话语,能筛掉一多半来面试前端的人?

好家伙还是一道前端面试题么。

nonono,这不是div堆叠做的,这么多div你想累死浏览器啊。

这个显然是用canvas api画出来的

贴一下canvas中文文档地址

我们都知道,图片绚丽,颜色各不相同,但是实际上,对计算机来说,只是一堆数据罢了。都是一个一个字节,一个一个bit。

计算机可能也能感受到这些数据的美,这谁能知道呢。

图片,不是位图的话,都是一个一个像素点。位图就是类似svg这种,不会因为缩放而失真的图片。

一个像素点由4个字节,分别表示R,G,B,A,各个字节所代表的的意思,如下图。

在这里插入图片描述
虽然是一堆字节,但是也是有排列顺序的。

按照从上到下行的顺序,行内是从左到右的列的顺序。

这样排布下来的,这就是图片在计算机里的真相。

所以,我们就去造出这个真相不就能造出一副图片来了么?

<!DOCTYPE HTML>
<html>
<body>
<canvas id="canvas" height=256 width=256></canvas>
<script>
// 绘制在Canvas上
var context = canvas.getContext('2d');
var imagedata = context.createImageData(256, 256);
// 给对应坐标位置的数据设置色值黑色
for (var x = 0; x < 256; x+=4) {for (var y = 0; y <= 256; y+= 4) {var index = 4 * (y*256 + x);var index1 = 4 * ((y+1)*256 + x);var index2 = 4 * (y*256 + (x+1));var index3 = 4 * ((y+1)*256 + (x+1));// 变为黑色,色值依次是0, 0, 0, 256imagedata.data[index] = 0;imagedata.data[index + 1] = 0;imagedata.data[index + 2] = 0;imagedata.data[index + 3] = 255;imagedata.data[index1] = 0;imagedata.data[index1 + 1] = 0;imagedata.data[index1 + 2] = 0;imagedata.data[index1 + 3] = 255;imagedata.data[index2] = 0;imagedata.data[index2 + 1] = 0;imagedata.data[index2 + 2] = 0;imagedata.data[index2 + 3] = 255;imagedata.data[index3] = 0;imagedata.data[index3 + 1] = 0;imagedata.data[index3 + 2] = 0;imagedata.data[index3 + 3] = 255;}
}
// 再重绘
context.putImageData(imagedata, 0, 0);
</script></body>
</html>

在这里插入图片描述
上述代码,画的是要求里的第三幅图片,也是 最基本的一张图片,因为黑色像素块的边长如果只为1的大小的话,也太小了,所以设置了2为边长,跳跃就是2*2=4

context.createImageData(256, 256);

这个就是canvas api造出的真相,也是原始的图片字节数组。

我们只要修改这个字节数组为我们想要的值,就能造出一幅图。

默认的真相,是白纸一张,并且是透明的,因为数组默认值都为0。

<!DOCTYPE HTML>
<html>
<body>
<canvas id="canvas" height=256 width=256></canvas>
<script>
// 绘制在Canvas上
var context = canvas.getContext('2d');
var imagedata = context.createImageData(256, 256);
// 给对应坐标位置的数据设置色值黑色
for (var x = 0; x < 256; x+=1) {for (var y = 0; y <= 256; y+= 1) {if(x<=y){var index = 4 * (y*256 + x);// 变为黑色,色值依次是0, 0, 0, 256imagedata.data[index] = 0;imagedata.data[index + 1] = 0;imagedata.data[index + 2] = 0;imagedata.data[index + 3] = 255;}}
}
// 再重绘
context.putImageData(imagedata, 0, 0);
</script></body>
</html>

在这里插入图片描述
这个对应要求的第二张图咯。

<!DOCTYPE HTML>
<html>
<body>
<canvas id="canvas" height=256 width=256></canvas>
<script>
// 绘制在Canvas上
var context = canvas.getContext('2d');
var imagedata = context.createImageData(256, 256);
// 给对应坐标位置的数据设置色值黑色
for (var x = 0; x < 256; x+=4) {for (var y = 0; y <= 256; y+= 4) {var index = 4 * (y*256 + x);var index1 = 4 * ((y+1)*256 + x);var index2 = 4 * ((y+1)*256 + x);var index3 = 4 * (y*256 + (x+1));// 变为黑色,色值依次是0, 0, 0, 256imagedata.data[index] = 0;imagedata.data[index + 1] = 0;imagedata.data[index + 2] = 0;imagedata.data[index + 3] = 255;imagedata.data[index1] = 0;imagedata.data[index1 + 1] = 0;imagedata.data[index1 + 2] = 0;imagedata.data[index1 + 3] = 255;imagedata.data[index2] = 0;imagedata.data[index2 + 1] = 0;imagedata.data[index2 + 2] = 0;imagedata.data[index2 + 3] = 255;imagedata.data[index3] = 0;imagedata.data[index3 + 1] = 0;imagedata.data[index3 + 2] = 0;imagedata.data[index3+ 3] = 255;var index4 = 4 * ((y+2)*256 + (x+2));var index5 = 4 * ((y+3)*256 + (x+2));var index6 = 4 * ((y+3)*256 + (x+2));var index7 = 4 * ((y+2)*256 + (x+3));imagedata.data[index4] = 0;imagedata.data[index4 + 1] = 0;imagedata.data[index4 + 2] = 0;imagedata.data[index4 + 3] = 255;imagedata.data[index5] = 0;imagedata.data[index5 + 1] = 0;imagedata.data[index5 + 2] = 0;imagedata.data[index5 + 3] = 255;imagedata.data[index6] = 0;imagedata.data[index6 + 1] = 0;imagedata.data[index6 + 2] = 0;imagedata.data[index6 + 3] = 255;imagedata.data[index7] = 0;imagedata.data[index7 + 1] = 0;imagedata.data[index7 + 2] = 0;imagedata.data[index7 + 3] = 255;}
}
// 再重绘
context.putImageData(imagedata, 0, 0);
</script></body>
</html>

在这里插入图片描述
第四张图

第一张看不清了,就酱吧。

还是蛮有意思的。

http://www.jmfq.cn/news/5240557.html

相关文章:

  • win7用本地文件做网站模板/百度客服电话号码
  • 网站建设价类型/外贸seo
  • 杭州滨江区抖音seo货真价实/成都seo达人
  • 无锡网站开发培训/合肥网络推广培训学校
  • 百度网站如何做/外贸网络营销平台
  • pc端网站建设哪里有/广告代发平台
  • 网站建设公司比较好的有哪些/百度竞价推广培训
  • 国外推广渠道平台/seo免费视频教程
  • 山东青岛网站制作公司/百度云盘网页版
  • 网站建设课程改进建议/搜索引擎优化与推广技术
  • 免费ae模板素材网站/seo的推广技巧
  • 杭州培训网站建设/什么平台可以推销自己的产品
  • ps 做网站切图/seo研究中心vip课程
  • 国外网站建设嫣语赋/温州seo品牌优化软件
  • 瓦房店 网站建设/德国搜索引擎
  • 国内网站制作特点/百度竞价排名危机事件
  • 在家里怎样做网站/广告公司推广软文
  • 淮北网站开发公司/东莞seo优化排名推广
  • 检查网站是否做301/个人网页制作
  • 网站克隆镜像做关键字seo/网页搭建
  • 给政府做采购哪个网站平台/seo是什么意思啊
  • asp图片源码网站/电商运营基础知识
  • 深圳手机网站制作公司排名/360网站推广客服电话
  • 无锡梦燕服饰网站谁做的/网络营销的工具有哪些
  • 嘉兴网站的优化/下载谷歌浏览器并安装
  • 个人备案网站类型/营销策划书范文案例
  • 学网站建设 赚钱/seo教学实体培训班
  • 做jsp网站用哪些软件下载/深圳高端seo公司助力企业
  • 网站锚文本链接怎么做/必应搜索推广
  • 视频网站做app还是h5/宁德市有几个区几个县