paper.js/test/tests/PathStyle.js

130 lines
3.5 KiB
JavaScript
Raw Normal View History

2011-02-16 16:11:26 -05:00
module('Path Style');
test('currentStyle', function() {
var doc = new Document();
2011-02-16 16:11:26 -05:00
doc.currentStyle.fillColor = 'black';
var path = new Path();
compareRGBColors(path.fillColor, 'black');
2011-02-16 16:11:26 -05:00
// When changing the current style of the document, the style of
// paths created using document.currentStyle should not change.
doc.currentStyle.fillColor = 'red';
compareRGBColors(path.fillColor, 'black');
2011-02-16 16:11:26 -05:00
});
test('setting currentStyle to an object', function() {
var doc = new Document();
2011-02-16 16:11:26 -05:00
doc.currentStyle = {
fillColor: 'red',
strokeColor: 'green'
};
var path = new Path();
compareRGBColors(path.fillColor, 'red');
compareRGBColors(path.strokeColor, 'green');
2011-02-16 16:11:26 -05:00
});
test('setting path styles to an object', function() {
var doc = new Document();
2011-02-16 16:11:26 -05:00
var path = new Path();
path.style = {
fillColor: 'red',
strokeColor: 'green'
};
compareRGBColors(path.fillColor, 'red');
compareRGBColors(path.strokeColor, 'green');
2011-02-16 16:11:26 -05:00
});
test('setting group styles to an object', function() {
var doc = new Document();
2011-02-16 16:11:26 -05:00
var group = new Group();
var path = new Path();
group.appendTop(path);
group.style = {
fillColor: 'red',
strokeColor: 'green'
};
compareRGBColors(path.fillColor, 'red');
compareRGBColors(path.strokeColor, 'green');
2011-02-16 16:11:26 -05:00
});
test('getting group styles', function() {
var doc = new Document();
2011-02-16 16:11:26 -05:00
var group = new Group();
var path = new Path();
path.fillColor = 'red';
group.appendTop(path);
compareRGBColors(group.fillColor, 'red');
2011-02-16 16:11:26 -05:00
var secondPath = new Path();
secondPath.fillColor = 'black';
group.appendTop(secondPath);
// the group now contains two paths with different fillColors and therefore
// should return null:
equals(group.fillColor, null);
//If we remove the first path, it should now return 'black':
group.children[0].remove();
compareRGBColors(group.fillColor, 'black');
2011-02-16 16:11:26 -05:00
});
test('setting group styles', function() {
var doc = new Document();
2011-02-16 16:11:26 -05:00
var group = new Group();
var path = new Path();
path.fillColor = 'red';
group.appendTop(path);
var secondPath = new Path();
secondPath.fillColor = 'blue';
secondPath.strokeColor = 'red';
group.appendTop(secondPath);
// Change the fill color of the group:
group.fillColor = 'black';
// the paths contained in the group should now both have their fillColor
// set to black:
compareRGBColors(path.fillColor, 'black');
compareRGBColors(secondPath.fillColor, 'black');
2011-02-16 16:11:26 -05:00
// The second path still has its strokeColor set to red:
compareRGBColors(secondPath.strokeColor, 'red');
2011-02-16 16:11:26 -05:00
});
test('setting group styles 2', function() {
var doc = new Document();
2011-02-16 16:11:26 -05:00
var group = new Group();
var path = new Path();
path.fillColor = 'red';
group.appendTop(path);
compareRGBColors(group.fillColor, 'red');
2011-02-16 16:11:26 -05:00
var secondPath = new Path();
secondPath.fillColor = 'blue';
secondPath.strokeColor = 'red';
group.appendTop(secondPath);
compareRGBColors(secondPath.fillColor, 'blue');
compareRGBColors(secondPath.strokeColor, 'red');
2011-02-16 16:11:26 -05:00
// By appending a path with a different fillcolor,
// the group's fillColor should return null:
equals(group.fillColor, null);
// But, both paths have a red strokeColor, so:
compareRGBColors(group.strokeColor, 'red');
2011-02-16 16:11:26 -05:00
// Change the fill color of the group's style:
group.style.fillColor = 'black';
// the paths contained in the group should now both have their fillColor
// set to black:
compareRGBColors(path.fillColor, 'black');
compareRGBColors(secondPath.fillColor, 'black');
2011-02-16 16:11:26 -05:00
// The second path still has its strokeColor set to red:
compareRGBColors(secondPath.strokeColor, 'red');
2011-02-16 16:11:26 -05:00
});