-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy pathlinearbrush.js
103 lines (77 loc) · 2.87 KB
/
linearbrush.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
var contextMargin = {top: 10, right: 40, bottom: 25, left: 60},
contextWidth = 440 - contextMargin.left - contextMargin.right,
contextHeight = 100 - contextMargin.top - contextMargin.bottom;
function linearBrush(layout, callbackObj) {
this.layout;
this.callbackObj = callbackObj;
if('undefined' !== typeof layout.offset) {
this.start_offset = layout.offset;
} else {
this.start_offset = 0;
}
this.brushContainer = d3.select(layout.container)
.append("svg")
.attr("width", contextWidth + contextMargin.left + contextMargin.right)
.attr("height", contextHeight + contextMargin.top + contextMargin.bottom)
.attr("class", "contextTracks");
this.x1 = d3.scale.linear()
.range([0,contextWidth])
.domain([this.start_offset, layout.genomesize + this.start_offset]);
this.mini = this.brushContainer.append("g")
.attr("transform", "translate(" + contextMargin.left + "," + contextMargin.top + ")")
.attr("width", contextWidth)
.attr("height", contextHeight)
.attr("class", "miniBrush");
this.brush = d3.svg.brush()
.x(this.x1)
.on("brush", this.brushUpdate.bind(this));
// this.brush = brush;
this.brushContainer = this.mini.append("g")
.attr("class", "track brush")
.call(this.brush.bind(this))
.selectAll("rect")
.attr("y", 1)
.attr("height", contextHeight - 1);
this.axisContainer = this.mini.append("g")
.attr('class', 'brushAxis')
.attr("transform", "translate(" + 0 + "," + contextHeight + ")");
this.xAxis = d3.svg.axis().scale(this.x1).orient("bottom")
.tickFormat(d3.format("s"));
this.axisContainer.append("g")
.attr("class", "context axis bottom")
.attr("transform", "translate(0," + 0 + ")")
.call(this.xAxis);
}
linearBrush.prototype.brushUpdate = function(b) {
var minExtent = this.brush.extent()[0];
var maxExtent = this.brush.extent()[1];
if( Object.prototype.toString.call( this.callbackObj ) === '[object Array]' ) {
for(var obj in this.callbackObj) {
if(this.callbackObj.hasOwnProperty(obj)) {
this.callbackObj[obj].update(minExtent, maxExtent);
}
}
} else {
this.callbackObj.update(minExtent, maxExtent);
}
}
linearBrush.prototype.update = function(startBP, endBP) {
this.brush.extent([startBP, endBP]);
d3.selectAll('.brush').call(this.brush);
}
linearBrush.prototype.update_finished = function(startBP, endBP) {
}
linearBrush.prototype.addBrushCallback = function(obj) {
// We allow multiple brushes to be associated with a linear plot, if we have
// a brush already, add this new one on. Otherwise just remember it.
if('undefined' !== typeof this.callbackObj) {
if( Object.prototype.toString.call( obj ) === '[object Array]' ) {
this.callbackObj.push(obj);
} else {
var tmpobj = this.callbackObj;
this.callbackObj = [tmpobj, obj];
}
} else {
this.callbackObj = obj;
}
}