Files
config-pacs-docker/nv/html/dwv/tests/image/view.test.js
2025-02-26 14:49:25 +07:00

210 lines
6.9 KiB
JavaScript

/**
* Tests for the 'image/view.js' file.
*/
// Do not warn if these variables were not defined before.
/* global QUnit */
QUnit.module("view");
/**
* Tests for {@link dwv.image.View} listeners.
* @function module:tests/image~listeners
*/
QUnit.test("Test listeners.", function (assert) {
// create an image
var size0 = 4;
var imgSize0 = new dwv.image.Size(size0, size0, 1);
var imgSpacing0 = new dwv.image.Spacing(1, 1, 1);
var imgOrigin0 = new dwv.math.Point3D(0,0,0);
var imgGeometry0 = new dwv.image.Geometry(imgOrigin0, imgSize0, imgSpacing0);
var buffer0 = [];
for(var i=0; i<size0*size0; ++i) {
buffer0[i] = i;
}
var image0 = new dwv.image.Image(imgGeometry0, [buffer0]);
image0.setMeta( { BitsStored: 8 } );
// create a view
var view0 = new dwv.image.View(image0);
// listeners
var listener1 = function(event){
assert.equal( event.wc, 0, "Expected call to listener1.");
};
var listener2 = function(event){
assert.equal( event.ww, 1, "Expected call to listener2.");
};
// with two listeners
view0.addEventListener("wl-center-change", listener1 );
view0.addEventListener("wl-center-change", listener2 );
view0.setWindowLevel(0,1);
// without listener2
view0.removeEventListener("wl-center-change", listener2 );
view0.setWindowLevel(0,2);
// without listener1
view0.removeEventListener("wl-center-change", listener1 );
view0.setWindowLevel(1,1);
});
/**
* Tests for {@link dwv.image.View} generateImageData MONO.
* @function module:tests/image~generateImageDataMONO
*/
QUnit.test("Test generate data MONO.", function (assert) {
// create an image
var size0 = 2;
var imgSize0 = new dwv.image.Size(size0, size0, 1);
var imgSpacing0 = new dwv.image.Spacing(1, 1, 1);
var imgOrigin0 = new dwv.math.Point3D(0,0,0);
var imgGeometry0 = new dwv.image.Geometry(imgOrigin0, imgSize0, imgSpacing0);
var buffer0 = [];
for ( var i = 0; i < size0 * size0; ++i ) {
buffer0[i] = i;
}
var image0 = new dwv.image.Image(imgGeometry0, [buffer0]);
image0.setMeta( { 'BitsStored': 8 } );
// create a view
var view0 = new dwv.image.View(image0);
// create the image data
var imageData = {'width': size0, 'height': size0, 'data': new Uint8ClampedArray(size0*size0*4) };
// default window level
view0.setWindowLevelMinMax();
// call generate data
view0.generateImageData(imageData);
// TODO proper data?
var theoData0 = [ 0, 0, 0, 255, 127, 127, 127, 255,
255, 255, 255, 255, 255, 255, 255, 255 ];
var testContent0 = true;
for ( i = 0; i < size0*size0*4; ++i) {
if ( theoData0[i] !== imageData.data[i] ) {
testContent0 = false;
break;
}
}
assert.equal( testContent0, true, "check image data" );
});
/**
* Tests for {@link dwv.image.View} generateImageData RGB.
* @function module:tests/image~generateImageDataRGB
*/
QUnit.test("Test generate data RGB.", function (assert) {
// create an image
var size0 = 2;
var imgSize0 = new dwv.image.Size(size0, size0, 1);
var imgSpacing0 = new dwv.image.Spacing(1, 1, 1);
var imgOrigin0 = new dwv.math.Point3D(0,0,0);
var imgGeometry0 = new dwv.image.Geometry(imgOrigin0, imgSize0, imgSpacing0);
var buffer0 = [];
var index = 0;
var value = 0;
// 0, 85, 170, 255
for ( var i = 0; i < size0 * size0; ++i ) {
value = i * 255 / ((size0 * size0) - 1);
buffer0[index] = value;
buffer0[index+1] = value;
buffer0[index+2] = value;
index += 3;
}
var image0 = new dwv.image.Image(imgGeometry0, [buffer0]);
image0.setPhotometricInterpretation('RGB');
image0.setMeta( { 'BitsStored': 8 } );
// create a view
var view0 = new dwv.image.View(image0);
// create the image data
var imageData = {'width': size0, 'height': size0, 'data': new Uint8ClampedArray(size0*size0*4) };
// default window level
view0.setWindowLevel(127, 255);
// call generate data
view0.generateImageData(imageData);
// check data content
var theoData0 = [ 0, 0, 0, 255, 85, 85, 85, 255,
171, 171, 171, 255, 255, 255, 255, 255 ];
var testContent0 = true;
for ( i = 0; i < size0*size0*4; ++i) {
if ( theoData0[i] !== imageData.data[i] ) {
testContent0 = false;
break;
}
}
assert.equal( testContent0, true, "check image data non planar" );
var buffer1 = [];
index = 0;
// 0, 85, 170, 255
for ( i = 0; i < size0 * size0; ++i ) {
buffer1[index] = 0;
buffer1[index+1] = 85;
buffer1[index+2] = 170;
buffer1[index+3] = 255;
index += 4;
}
var image1 = new dwv.image.Image(imgGeometry0, [buffer1]);
image1.setPhotometricInterpretation('RGB');
image1.setPlanarConfiguration(1);
image1.setMeta( { 'BitsStored': 8 } );
// create a view
var view1 = new dwv.image.View(image1);
// default window level
view1.setWindowLevel(127, 255);
// call generate data
view1.generateImageData(imageData);
// check data content
var testContent1 = true;
for ( i = 0; i < size0*size0*4; ++i) {
if ( theoData0[i] !== imageData.data[i] ) {
testContent1 = false;
break;
}
}
assert.equal( testContent1, true, "check image data planar" );
});
/**
* Tests for {@link dwv.image.View} generateImageData timing.
* @function module:tests/image~generateImageDataTiming
*/
QUnit.test("Test generate data timing.", function (assert) {
// create an image
var size0 = 128;
var imgSize0 = new dwv.image.Size(size0, size0, 1);
var imgSpacing0 = new dwv.image.Spacing(1, 1, 1);
var imgOrigin0 = new dwv.math.Point3D(0,0,0);
var imgGeometry0 = new dwv.image.Geometry(imgOrigin0, imgSize0, imgSpacing0);
var buffer0 = [];
for(var i=0; i<size0*size0; ++i) {
buffer0[i] = i;
}
var image0 = new dwv.image.Image(imgGeometry0, [buffer0]);
image0.setMeta( { BitsStored: 8 } );
// create a view
var view0 = new dwv.image.View(image0);
// create the image data
var imageData = {"width": size0, "height": size0, "data": new Uint8Array(size0*size0*4) };
// default window level
view0.setWindowLevelMinMax();
// start time
var start0 = new Date();
// call generate data
view0.generateImageData(imageData);
// time taken
var time0 = (new Date()) - start0;
// check time taken
assert.ok( time0 < 90, "First generateImageData: "+time0+"ms.");
// Change the window level
view0.setWindowLevel(4000, 200);
// start time
var start1 = (new Date()).getMilliseconds();
// call generate data
view0.generateImageData(imageData);
// time taken
var time1 = (new Date()).getMilliseconds() - start1;
// check time taken
assert.ok( time1 < 90, "Second generateImageData: "+time1+"ms.");
});