306 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			306 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { Jimp, mkJGD } from '@jimp/test-utils';
 | |
| import configure from '@jimp/custom';
 | |
| 
 | |
| import mask from '../src';
 | |
| 
 | |
| const jimp = configure({ plugins: [mask] }, Jimp);
 | |
| 
 | |
| describe('Mask', () => {
 | |
|   let imgSrcOpaq;
 | |
|   let imgSrcAlpa;
 | |
|   let maskGrayBig;
 | |
|   let maskGraySmall;
 | |
|   let maskColor;
 | |
| 
 | |
|   before(done => {
 | |
|     Promise.all([
 | |
|       jimp.read(mkJGD('▴□▾□■□', '■▴■▾■□', '■□▴□▾□', '■□■▴■▾')),
 | |
|       jimp.read(mkJGD('▴▵▾▿', '▴▵▾▿', '▴▵▾▿')),
 | |
|       jimp.read(mkJGD('048840', '8CFFC8', '8CFFC8', '048840')),
 | |
|       jimp.read(mkJGD('0369', '369C', '69CF')),
 | |
|       jimp.read(mkJGD('▴▴▾▾', '▪▪▰▰', '□□□□'))
 | |
|     ])
 | |
|       .then(imgs => {
 | |
|         imgSrcOpaq = imgs[0];
 | |
|         imgSrcAlpa = imgs[1];
 | |
|         maskGrayBig = imgs[2];
 | |
|         maskGraySmall = imgs[3];
 | |
|         maskColor = imgs[4];
 | |
|         done();
 | |
|       })
 | |
|       .catch(done);
 | |
|   });
 | |
| 
 | |
|   it('Affect opaque image with a gray mask with the same size', () => {
 | |
|     imgSrcOpaq
 | |
|       .clone()
 | |
|       .mask(maskGrayBig)
 | |
|       .getJGDSync()
 | |
|       .should.be.sameJGD({
 | |
|         width: 6,
 | |
|         height: 4,
 | |
|         data: [
 | |
|           0xff000000,
 | |
|           0xffffff44,
 | |
|           0x0000ff88,
 | |
|           0xffffff88,
 | |
|           0x00000044,
 | |
|           0xffffff00,
 | |
|           0x00000088,
 | |
|           0xff0000cc,
 | |
|           0x000000ff,
 | |
|           0x0000ffff,
 | |
|           0x000000cc,
 | |
|           0xffffff88,
 | |
|           0x00000088,
 | |
|           0xffffffcc,
 | |
|           0xff0000ff,
 | |
|           0xffffffff,
 | |
|           0x0000ffcc,
 | |
|           0xffffff88,
 | |
|           0x00000000,
 | |
|           0xffffff44,
 | |
|           0x00000088,
 | |
|           0xff000088,
 | |
|           0x00000044,
 | |
|           0x0000ff00
 | |
|         ]
 | |
|       });
 | |
|   });
 | |
| 
 | |
|   it('Affect opaque image with a gray mask with the same size, blited', () => {
 | |
|     imgSrcOpaq
 | |
|       .clone()
 | |
|       .mask(maskGrayBig, 1, 1)
 | |
|       .getJGDSync()
 | |
|       .should.be.sameJGD({
 | |
|         width: 6,
 | |
|         height: 4,
 | |
|         data: [
 | |
|           0xff0000ff,
 | |
|           0xffffffff,
 | |
|           0x0000ffff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xff000000,
 | |
|           0x00000044,
 | |
|           0x0000ff88,
 | |
|           0x00000088,
 | |
|           0xffffff44,
 | |
|           0x000000ff,
 | |
|           0xffffff88,
 | |
|           0xff0000cc,
 | |
|           0xffffffff,
 | |
|           0x0000ffff,
 | |
|           0xffffffcc,
 | |
|           0x000000ff,
 | |
|           0xffffff88,
 | |
|           0x000000cc,
 | |
|           0xff0000ff,
 | |
|           0x000000ff,
 | |
|           0x0000ffcc
 | |
|         ]
 | |
|       });
 | |
|   });
 | |
| 
 | |
|   it('Affect opaque image with a gray mask with the same size, blited negative', () => {
 | |
|     imgSrcOpaq
 | |
|       .clone()
 | |
|       .mask(maskGrayBig, -1, -1)
 | |
|       .getJGDSync()
 | |
|       .should.be.sameJGD({
 | |
|         width: 6,
 | |
|         height: 4,
 | |
|         data: [
 | |
|           0xff0000cc,
 | |
|           0xffffffff,
 | |
|           0x0000ffff,
 | |
|           0xffffffcc,
 | |
|           0x00000088,
 | |
|           0xffffffff,
 | |
|           0x000000cc,
 | |
|           0xff0000ff,
 | |
|           0x000000ff,
 | |
|           0x0000ffcc,
 | |
|           0x00000088,
 | |
|           0xffffffff,
 | |
|           0x00000044,
 | |
|           0xffffff88,
 | |
|           0xff000088,
 | |
|           0xffffff44,
 | |
|           0x0000ff00,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xff0000ff,
 | |
|           0x000000ff,
 | |
|           0x0000ffff
 | |
|         ]
 | |
|       });
 | |
|   });
 | |
| 
 | |
|   it('Affect opaque image with a smaller gray mask', () => {
 | |
|     imgSrcOpaq
 | |
|       .clone()
 | |
|       .mask(maskGraySmall)
 | |
|       .getJGDSync()
 | |
|       .should.be.sameJGD({
 | |
|         width: 6,
 | |
|         height: 4,
 | |
|         data: [
 | |
|           0xff000000,
 | |
|           0xffffff33,
 | |
|           0x0000ff66,
 | |
|           0xffffff99,
 | |
|           0x000000ff,
 | |
|           0xffffffff,
 | |
|           0x00000033,
 | |
|           0xff000066,
 | |
|           0x00000099,
 | |
|           0x0000ffcc,
 | |
|           0x000000ff,
 | |
|           0xffffffff,
 | |
|           0x00000066,
 | |
|           0xffffff99,
 | |
|           0xff0000cc,
 | |
|           0xffffffff,
 | |
|           0x0000ffff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xff0000ff,
 | |
|           0x000000ff,
 | |
|           0x0000ffff
 | |
|         ]
 | |
|       });
 | |
|   });
 | |
| 
 | |
|   it('Affect opaque image with a smaller gray mask, blited', () => {
 | |
|     imgSrcOpaq
 | |
|       .clone()
 | |
|       .mask(maskGraySmall, 1, 1)
 | |
|       .getJGDSync()
 | |
|       .should.be.sameJGD({
 | |
|         width: 6,
 | |
|         height: 4,
 | |
|         data: [
 | |
|           0xff0000ff,
 | |
|           0xffffffff,
 | |
|           0x0000ffff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xff000000,
 | |
|           0x00000033,
 | |
|           0x0000ff66,
 | |
|           0x00000099,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xffffff33,
 | |
|           0xff000066,
 | |
|           0xffffff99,
 | |
|           0x0000ffcc,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xffffff66,
 | |
|           0x00000099,
 | |
|           0xff0000cc,
 | |
|           0x000000ff,
 | |
|           0x0000ffff
 | |
|         ]
 | |
|       });
 | |
|   });
 | |
| 
 | |
|   it('Affect alpha image with a bigger gray mask', () => {
 | |
|     imgSrcAlpa
 | |
|       .clone()
 | |
|       .mask(maskGrayBig)
 | |
|       .getJGDSync()
 | |
|       .should.be.sameJGD({
 | |
|         width: 4,
 | |
|         height: 3,
 | |
|         data: [
 | |
|           0xff000000,
 | |
|           0xff000021,
 | |
|           0x0000ff88,
 | |
|           0x0000ff43,
 | |
|           0xff000088,
 | |
|           0xff000065,
 | |
|           0x0000ffff,
 | |
|           0x0000ff7f,
 | |
|           0xff000088,
 | |
|           0xff000065,
 | |
|           0x0000ffff,
 | |
|           0x0000ff7f
 | |
|         ]
 | |
|       });
 | |
|   });
 | |
| 
 | |
|   it('Affect alpha image with a bigger gray mask, blited', () => {
 | |
|     imgSrcAlpa
 | |
|       .clone()
 | |
|       .mask(maskGrayBig, -1, -1)
 | |
|       .getJGDSync()
 | |
|       .should.be.sameJGD({
 | |
|         width: 4,
 | |
|         height: 3,
 | |
|         data: [
 | |
|           0xff0000cc,
 | |
|           0xff00007f,
 | |
|           0x0000ffff,
 | |
|           0x0000ff65,
 | |
|           0xff0000cc,
 | |
|           0xff00007f,
 | |
|           0x0000ffff,
 | |
|           0x0000ff65,
 | |
|           0xff000044,
 | |
|           0xff000043,
 | |
|           0x0000ff88,
 | |
|           0x0000ff21
 | |
|         ]
 | |
|       });
 | |
|   });
 | |
| 
 | |
|   it('Affect opaque image with a colored mask', () => {
 | |
|     imgSrcOpaq
 | |
|       .clone()
 | |
|       .mask(maskColor, 1, 1)
 | |
|       .getJGDSync()
 | |
|       .should.be.sameJGD({
 | |
|         width: 6,
 | |
|         height: 4,
 | |
|         data: [
 | |
|           0xff0000ff,
 | |
|           0xffffffff,
 | |
|           0x0000ffff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xff000055,
 | |
|           0x00000055,
 | |
|           0x0000ff55,
 | |
|           0x00000055,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xffffffaa,
 | |
|           0xff0000aa,
 | |
|           0xffffffaa,
 | |
|           0x0000ffaa,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xffffffff,
 | |
|           0x000000ff,
 | |
|           0xff0000ff,
 | |
|           0x000000ff,
 | |
|           0x0000ffff
 | |
|         ]
 | |
|       });
 | |
|   });
 | |
| });
 |