欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript圖像處理—為矩陣添加常用方法

 更新時間:2012年12月27日 09:32:25   作者:  
上一篇文章,我們定義了矩陣,這篇文章我們來給矩陣添加一些常用方法比如:toString方法、clone方法等,需要了解的朋友可以詳細參考下
前言
上一篇文章,我們定義了矩陣,這篇文章我們來給矩陣添加一些常用方法。

toString方法
toString方法通常用作將對象轉(zhuǎn)成字符串描述,所以我們將這一方法定義為輸出矩陣元素。
復(fù)制代碼 代碼如下:

Mat.prototype.toString = function(){
var tempData = this.data,
text = "Mat("+ this.type +") = {\n",
num = this.col * this.channel;
for(var i = 0; i < this.row; i++){
text += "["
for(var j = 0; j < num; j++){
text += (tempData[i * num + j] + ",");
}
text += "]\n";
}
text += "}";
return text;
};

這樣,我們就可以通過:
復(fù)制代碼 代碼如下:

console.log(mat);

來輸出矩陣了。

clone方法
實際上,我們可以通過構(gòu)造函數(shù)進行克隆操作,不過依然提供一個方法來方便記憶、使用。
復(fù)制代碼 代碼如下:

Mat.prototype.clone = function(){
return new Mat(this.row, this.col, this.data);
};

獲取指定元素
我們有兩種方法獲取矩陣元素。

數(shù)組方法
由于實際上Mat是以數(shù)組形式保存數(shù)據(jù)的,而數(shù)據(jù)看起來是這樣的:
R00 G00 B00 A00 R01 G01 B01 A01 …… R0n G0n B0n A0n
R10 G10 B10 A10 R11 G11 B11 A11 …… R1n G1n B1n A1n
……
Rm0 Gm0 Bm0 Am0 Rm1 Gm1 Bm1 Am1 …… Rmn Gmn Bmn Amn
其中大寫R、G、B、A分別代表各通道的數(shù)值,而下標(biāo)第一個表示行號,第二個表示列號。即第k行,第j列的G通道數(shù)值就是Gkj。
我們很容易得到對于一個Mat類型的mat來說,第k行,第j列像素的每個元素分別是:
Rkj = mat.data[(k * mat.col + j) * 4 + 0]
Gkj = mat.data[(k * mat.col + j) * 4 + 1]
Bkj = mat.data[(k * mat.col + j) * 4 + 2]
Akj = mat.data[(k * mat.col + j) * 4 + 3]

Buffer部分引用方法
通過Buffer的部分引用,我們可以得到矩陣的部分引用,比如我們可以利用這個來獲取一個像素點的數(shù)據(jù)數(shù)組,而改變這個數(shù)組中的值,相應(yīng)的矩陣數(shù)據(jù)也會改變;再比如我們可以以其他數(shù)據(jù)類型的方式讀取數(shù)據(jù)。而這些對于普通Array是不能實現(xiàn)的。下面我們來看一下at方法的實現(xiàn):
復(fù)制代碼 代碼如下:

Mat.prototype.at = function(__type, __x, __y){
var type = __type,
x = __x || 0,
y = __y || 0,
rowLen = this.col * this.channel * this.bytes,
len = 1;
if(type.indexOf("Vec") > -1){
var temp = __type.match(/Vec(\d+)([a-z])/);
len = parseInt(temp[1]);
switch(temp[2]){
case "b":
type = "uchar";
break;
case "s":
type = "short";
break;
case "i":
type = "int";
break;
case "f":
type = "float";
break;
case "d":
type = "double";
break;
}
}
switch(type){
case "uchar":
return new Uint8Array(this.buffer, (y * rowLen + x), len);
break;
case "short":
return new Int16Array(this.buffer, (y * rowLen + x * 2), len);
break;
case "int":
return new Int32Array(this.buffer, (y * rowLen + x * 4), len);
break;
case "float":
return new Float32Array(this.buffer, (y * rowLen + x * 4), len);
break;
case "doulble":
return new Float64Array(this.buffer, (y * rowLen + x * 8), len);
break;
default:
console.error("不支持數(shù)據(jù)類型");
}
};

如果你對ArrayBuffer和TypedArray還不太清楚,可以參考:HTML5 中的新數(shù)組。
String type - 需要返回的數(shù)據(jù)類型。支持:
uchar 無符號8位整數(shù)
short 有符號16位整數(shù)
int 有符號32位整數(shù)
float 有符號32位浮點數(shù)
double 有符號64位浮點數(shù)

Vec 向量形式
向量形式字符串拼寫是:Vec + (類型)+ (個數(shù)),例如Vecb4就是4個無符號8位整數(shù),這是常見的得到一個像素點數(shù)據(jù)的方法,例如為了得到mat第j行,第k列的像素數(shù)據(jù),可以使用:
復(fù)制代碼 代碼如下:

mat.at("Vecb4", j, k);

int x - 要獲取的元素在矩陣的行數(shù)。
int y - 要獲取的元素在矩陣的列數(shù)。

getRow方法和getCol方法
類似于at的實現(xiàn)方法,我們可以很容易寫出獲取某一行或者某一列的方法:
復(fù)制代碼 代碼如下:

Mat.prototype.getRow = function(__i){
var len = this.col * this.channel,
rowLen = len * this.bytes,
i = __i || 0;
return new this.data.constructor(this.buffer, i * rowLen, len);
};

復(fù)制代碼 代碼如下:

Mat.prototype.getCol = function(__i){
var len = this.col * this.channel,
rowLen = len * this.bytes,
array = [],
i = __i || 0;
function getAllElement(__constructor){
var row = this.row,
channel = this.channel;
for(var j = 0; j < row; j++){
array.push(new __constructor(this.buffer, j * rowLen + i, 1 * channel));
}
}
getAllElement(this.data.constructor);
return array;
};

rowRange和colRange方法
類似的,我們也可以得到指定行和指定列的方法:
復(fù)制代碼 代碼如下:

Mat.prototype.rowRange = function(__i, __j){
var len = this.col * this.channel,
rowLen = len * this.bytes,
array = [],
i = __i || 0,
j = __j || this.row;
function getAllElement(__constructor){
var row = this.row;
for(var k = i; k <= j; k++){
array.push(new __constructor(this.buffer, k * rowLen, len));
}
}
getAllElement(this.data.constructor);
return array;
};

復(fù)制代碼 代碼如下:

Mat.prototype.colRange = function(__i, __j){
var len = this.col * this.channel,
rowLen = len * this.bytes,
array = [],
i = __i || 0,
j = __j || this.col;
function getAllElement(__constructor){
var row = this.row
channel = this.channel;
for(var k = 0; k < row; k++){
array.push(new __constructor(this.buffer, k * rowLen + __i, (__j - __i + 1) * channel));
}
}
getAllElement(Float64Array);
return array;
};

這四種方法返回的都是一種Array<TypedArray>的數(shù)組。如果要獲取這個數(shù)組rect第j行,第k列的元素,則可用:
rect[j][k]

相關(guān)文章

  • JavaScript函數(shù)中關(guān)于valueOf和toString的理解

    JavaScript函數(shù)中關(guān)于valueOf和toString的理解

    本文給大家介紹JavaScript函數(shù)中關(guān)于valueOf和toString的理解,簡單的說就是需要轉(zhuǎn)換為字符串時,會調(diào)用toString,需要轉(zhuǎn)換為數(shù)字時需要調(diào)用valueOf。對js valueof tostring知識感興趣的朋友一起學(xué)習(xí)吧
    2016-06-06
  • js實現(xiàn)簡單的打印表格

    js實現(xiàn)簡單的打印表格

    這篇文章主要為大家詳細介紹了js實現(xiàn)簡單的打印表格,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-01-01
  • 避免 showModalDialog 彈出新窗體的原因分析

    避免 showModalDialog 彈出新窗體的原因分析

    避免 showModalDialog 彈出新窗體的原因分析,一般情況下需要返回值用window.open.
    2010-05-05
  • js實現(xiàn)分頁功能

    js實現(xiàn)分頁功能

    這篇文章主要為大家詳細介紹了js實現(xiàn)分頁功能,頁面查詢實現(xiàn)分頁功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • javascript動態(tài)的改變IFrame的高度實現(xiàn)自動伸展

    javascript動態(tài)的改變IFrame的高度實現(xiàn)自動伸展

    動態(tài)的改變IFrame的高度,實現(xiàn)IFrame自動伸展,父頁面也自動神縮,實現(xiàn)原理很簡單就是在IFrame子頁面一加載的時候,調(diào)用父IFrame對象,改變其高度,感興趣的朋友可以了解下
    2013-10-10
  • JS與jQuery實現(xiàn)子窗口獲取父窗口元素值的方法

    JS與jQuery實現(xiàn)子窗口獲取父窗口元素值的方法

    這篇文章主要介紹了JS與jQuery實現(xiàn)子窗口獲取父窗口元素值的方法,涉及javascript與jQuery操作窗口元素的相關(guān)技巧,需要的朋友可以參考下
    2017-04-04
  • layui動態(tài)設(shè)置單選按鈕選中效果實例

    layui動態(tài)設(shè)置單選按鈕選中效果實例

    最近在使用layui前端框架,在使用單選按鈕、下拉菜單select、checkbox等控件的時候,往往遇到一些初始化的東西,下面這篇文章主要給大家介紹了關(guān)于layui動態(tài)設(shè)置單選按鈕選中效果的相關(guān)資料,需要的朋友可以參考下
    2023-06-06
  • JS實現(xiàn)關(guān)閉小廣告特效

    JS實現(xiàn)關(guān)閉小廣告特效

    這篇文章主要為大家詳細介紹了JS實現(xiàn)關(guān)閉小廣告特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • ES6學(xué)習(xí)筆記之Set和Map數(shù)據(jù)結(jié)構(gòu)詳解

    ES6學(xué)習(xí)筆記之Set和Map數(shù)據(jù)結(jié)構(gòu)詳解

    這篇文章主要介紹了ES6學(xué)習(xí)筆記之Set和Map數(shù)據(jù)結(jié)構(gòu),結(jié)合實例形式詳細分析了ECMAScript中基本數(shù)據(jù)結(jié)構(gòu)Set和Map的常用屬性與方法的功能、用法及相關(guān)注意事項,需要的朋友可以參考下
    2017-04-04
  • 一個JavaScript函數(shù)把URL參數(shù)解析成Json對象

    一個JavaScript函數(shù)把URL參數(shù)解析成Json對象

    一個JavaScript函數(shù)parseQueryString,它的用途是把URL參數(shù)解析為一個對象,很實用,大家可以看看
    2014-09-09

最新評論