es6之数组操作

1.计算机存储数据是二进制的,每位只能存0或1

2.每种语言的数字的存储都有不同位的, 常见的有每8,16,32位代表一个数字.

   n bit, 即n位数,存一个数字的范围是: 无符号:0  到   2的n次方-1;  有符号位是 -2的n/2次方  到  2的n/2-1次方; 

3 js里, 所有的数字, 都默认是32位的.

    比如var a = 0;  这个0在内存中占了32位空间, 虽然只要1位就可以表示. 究其原因, 就是为了内存更加模块化管理.

4  js中intArray数组中可以对数字进行不同位数的设置.  分为8/ 16/ 32三个大小的空间等级. 

ArrayBuffer 对象用来表示通用的、固定长度的原始二进制数据缓冲区; 它通常由intArray来操作.

 

例子: 将图片变成黑白

一个图片是由多个像素点组成的, 每个像素点都由四个数字组成,分别是rgba

如果将彩色照片所有像素点的rgb 三个值都设置为 各像素点rgb三者平均值, 那么图片就变成了黑白色了.

 

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4   <meta charset="UTF-8">
 5   <meta name="viewport" content="width=device-width, initial-scale=1.0">
 6   <meta http-equiv="X-UA-Compatible" content="ie=edge">
 7   <title>Document</title>
 8   <style>
 9   .wrap, .wrap>* {
10     /* height: 150px; */
11   }
12   .button{
13     word-wrap: break-word;
14     writing-mode: vertical-lr;
15     writing-mode: tb-lr;
16     background: #ccc;
17     display: inline-block;
18   }
19   </style>
20 </head>
21 <body>
22   <div class="wrap">
23       <img  src="./img/a.png" alt="">
24       <div class="button">转换成黑白图片</div>
25       <div class="canvas">
26         <canvas width="300" height="300"></canvas>
27       </div>
28   </div>
29 
30       
31   <script>
32     var btn = document.getElementsByClassName("button")[0];
33     btn.onclick = function(){
34       var canvas = document.getElementsByTagName("canvas")[0];
35       var ctx = canvas.getContext("2d");
36       var img = document.getElementsByTagName("img")[0];
37       ctx.drawImage(img,0,0);
38       var data = ctx.getImageData(0,0,img.width,img.height).data; //获取像素数据信息
39       console.log(data);
40       for(var i = 0; i < data.length; i+=4){
41         var avg = (data[i] + data[i+1] +data[i + 2])/3 ;
42         data[i] = data[i+1] = data[i+1]= avg; 
43        
44       }
45       
46       ctx.putImageData(new ImageData(data, img.width,Image.height),0,0);//重绘canvas
47     }
48    
49   </script>
50 </body>
51 </html>

 

posted @ 2021-02-07 16:26  当当和瓶瓶  阅读(221)  评论(0编辑  收藏  举报