-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathliang-barsky.min.js
173 lines (144 loc) · 17.1 KB
/
liang-barsky.min.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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
(function (exports) {
'use strict';
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) {
return typeof obj;
} : function (obj) {
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
};
/*
* @CreateTime: Mar 5, 2017 8:03 PM
* @Author: Emidio Bianco
* @Contact: [email protected]
* @Last Modified By: undefined
* @Last Modified Time: Mar 6, 2017 12:00 AM
* @Description: Class representing the point in a 2D plane
*/
function Point() {
this.x = this.y = 0;
switch (arguments.length) {
case 0:
break;
case 1:
if (_typeof(arguments[0]) == 'object') {
if (Array.isArray(arguments[0])) {
this.x = arguments[0][0];
this.y = arguments[0][1];
}
// TODO: should it clone the Point or use the instance ????
else if (arguments[0] instanceof Point) {
this.x = arguments[0].x;
this.y = arguments[0].y;
}
} else {
this.x = this.y = arguments[0];
}
break;
case 2:
this.x = arguments[0];
this.y = arguments[1];
}
}
Point.prototype = {
setX: function setX(x) {
this.x = x;
},
setY: function setY(y) {
this.y = y;
},
set: function set$$1(x, y) {
this.setX(x);
this.setY(y);
},
clone: function clone() {
return new Point(this.x, this.y);
}
};
// import * as glpk from './glpk.min.js';
// import * as jszip from 'jszip';
// import * as lalolib from './lalolib';
function LiangBarsky(startX, startY, endX, endY, width, height, rectX, rectY) {
this.pStart = new Point(startX, startY), this.pEnd = new Point(endX, endY);
this.xMin = rectX, this.yMin = rectY;
this.xMax = width, this.yMax = height;
}
LiangBarsky.prototype = {
compute: function compute() {
var deltaX = this.pEnd.x - this.pStart.x,
deltaY = this.pEnd.y - this.pStart.y;
var pLeft = -deltaX,
qLeft = this.pStart.x - this.xMin,
pRight = deltaX,
qRight = this.xMax - this.pStart.x,
pBottom = -deltaY,
qBottom = this.pStart.y - this.yMin,
pTop = deltaY,
qTop = this.yMax - this.pStart.y;
// pTop = -deltaY, qTop = this.pStart.y - this.yMin,
// pBottom = deltaY, qBottom = this.yMax - this.pStart.y;
var uLeft = qLeft / pLeft,
uRight = qRight / pRight,
uBottom = qBottom / pBottom,
uTop = qTop / pTop;
var p = new Array(),
q = new Array();
p.push(pLeft);p.push(pRight);p.push(pBottom);p.push(pTop);
q.push(qLeft);q.push(qRight);q.push(qBottom);q.push(qTop);
var x1 = this.pStart.x,
y1 = this.pStart.y,
x2 = this.pEnd.x,
y2 = this.pEnd.y;
for (var i = 0; i < 4; i++) {
if (p[i] == 0) {
console.debug("line is parallel to one of the clipping boundary");
// if q[i] >= 0 the line is inside the clipping boundary
if (q[i] >= 0) {
// vertical
if (i < 2) {
if (y1 < this.yMin) {
y1 = this.yMin;
}
if (y2 > this.yMax) {
y2 = this.yMax;
}
console.log('line( ' + this.pStart.x + ',' + y1 + ',' + this.pEnd.x + ',' + y2 + ')');
if (this.pStart.x < this.xMin || this.xMax < this.pEnd.x) return -1;else return [this.pStart.x, y1, this.pEnd.x, y2];
}
//horizontal
if (i > 1) {
if (x1 < this.xMin) {
x1 = this.xMin;
}
if (x2 > this.xMax) {
x2 = this.xMax;
}
console.log('line( ' + x1 + ',' + this.pStart.y + ',' + x2 + ',' + this.pEnd.y + ')');
if (this.pStart.y < this.yMin || this.yMax < this.pEnd.y) return -1;else return [x1, this.pStart.y, x2, this.pEnd.y];
}
}
}
}
var t1 = 0;
var t2 = 1;
for (var i = 0; i < 4; i++) {
var temp = q[i] / p[i];
console.log(temp);
if (p[i] < 0) {
if (t1 <= temp) t1 = temp;
} else {
if (t2 > temp) t2 = temp;
}
}
//TODO: review
if (t1 < t2) {
var xx1 = x1 + t1 * p[1];
var xx2 = x1 + t2 * p[1];
var yy1 = y1 + t1 * p[3];
var yy2 = y1 + t2 * p[3];
console.log('line( ' + xx1 + ',' + yy1 + ',' + xx2 + ',' + yy2 + ')');
return [xx1, yy1, xx2, yy2];
}
}
};
exports.LiangBarsky = LiangBarsky;
}((this.window = this.window || {})));
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"liang-barsky.min.js","sources":["geom.js","liang-barsky.js"],"sourcesContent":["/*\n * @CreateTime: Mar 5, 2017 8:03 PM \n * @Author: Emidio Bianco \n * @Contact: emidiobia@gmail.com \n * @Last Modified By: undefined\n * @Last Modified Time: Mar 6, 2017 12:00 AM\n * @Description: Class representing the point in a 2D plane \n */\n\n\nexport function Point(){\n  this.x = this.y =0;\n\n  switch(arguments.length){\n    case 0:\n      break;\n    case 1:\n      if (typeof(arguments[0]) == 'object' ){ \n        if(Array.isArray(arguments[0])){\n          this.x = arguments[0][0];\n          this.y = arguments[0][1];\n        }\n        // TODO: should it clone the Point or use the instance ???? \n        else if(arguments[0] instanceof(Point)) {\n          this.x = arguments[0].x;\n          this.y = arguments[0].y;\n        }\n      } else {\n        this.x = this.y = arguments[0];\n      }\n      break;\n    case 2:\n      this.x = arguments[0];\n      this.y = arguments[1];\n  }\n}\n\nPoint.prototype = {\n\n  setX: function(x){this.x = x},\n  setY: function(y){this.y = y},\n\n  set: function(x, y){\n    this.setX(x);\n    this.setY(y);\n  },\n \n  clone: function(){\n    return new Point(this.x, this.y);\n  },\n}\n\nexport function Rectangle(width, height, originX, originY){\n  this._width = width || 0;\n  this._height = height || 0;\n  \n  /**\n   * @class Point\n   */\n  this.origin = null;\n  this.maxPoint = null\n\n  if(arguments.length == 4){\n    this.origin = new Point(originX, originY);\n  } else {\n    this.origin = new Point(0,0);\n  }\n  // this.maxPoint = new Point(\n  //   this.origin.x + this._width,\n  //   this.origin.y + this._height\n  //   )\n}\n\nRectangle.prototype = {\n  //TODO:\n  setOrigin: function(newX, newY){\n    this.origin.set(newX, newY);\n  },\n\n  getOrigin: function(){\n    return this.origin;\n  },\n\n  getMinPoint : function(){\n    return this.getOrigin();\n  },\n  getmaxPoint : function(){\n    return new Point(\n      this.origin.x + this._width,\n      this.origin.y + this._height\n    );\n  }\n,}","// import * as glpk from './glpk.min.js';\n// import * as jszip from 'jszip';\n\n// import * as lalolib from './lalolib';\n\nimport {Point} from './geom';\n\nexport function LiangBarsky(startX, startY, endX, endY, width, height, rectX, rectY){\n\n  this.pStart = new Point(startX, startY), this.pEnd = new Point(endX, endY);\n\n  this.xMin = rectX, \n  this.yMin = rectY;\n  this.xMax = width,\n  this.yMax = height;\n\n}\n\n\nLiangBarsky.prototype = {\n compute: function(){\n\n  var deltaX = this.pEnd.x - this.pStart.x,\n    deltaY = this.pEnd.y - this.pStart.y;\n\n  var pLeft   = -deltaX, qLeft   = this.pStart.x - this.xMin,\n      pRight  = deltaX,  qRight  = this.xMax - this.pStart.x,\n      pBottom = -deltaY, qBottom = this.pStart.y - this.yMin,\n      pTop    = deltaY,  qTop    = this.yMax - this.pStart.y;\n      // pTop = -deltaY, qTop = this.pStart.y - this.yMin,\n      // pBottom    = deltaY,  qBottom    = this.yMax - this.pStart.y;\n\n  var uLeft  = qLeft/pLeft,\n    uRight  = qRight/pRight,\n    uBottom = qBottom/pBottom,\n    uTop  = qTop/pTop;\n  \n  var p = new Array(), q = new Array();\n  p.push(pLeft);p.push(pRight);p.push(pBottom);p.push(pTop);\n  q.push(qLeft);q.push(qRight);q.push(qBottom);q.push(qTop);\n\n  var x1 = this.pStart.x, y1 = this.pStart.y,\n      x2 = this.pEnd.x , y2 = this.pEnd.y;\n\n  for (var i = 0; i < 4; i++) {\n    if (p[i] == 0) {\n      console.debug(\"line is parallel to one of the clipping boundary\");\n      // if q[i] >= 0 the line is inside the clipping boundary\n      if (q[i] >= 0) {\n        // vertical\n        if (i < 2) {\n          if (y1 < this.yMin) {\n            y1 = this.yMin;\n          }\n\n          if (y2 > this.yMax) {\n            y2 = this.yMax;\n          }\n\n          console.log('line( ' + this.pStart.x + ',' + y1 + ',' + this.pEnd.x + ',' + y2 + ')');\n          if (this.pStart.x < this.xMin || this.xMax < this.pEnd.x)\n            return -1;\n          else \n            return  [this.pStart.x, y1, this.pEnd.x, y2];\n        }\n        //horizontal\n        if (i > 1) {\n          if (x1 < this.xMin) {\n            x1 = this.xMin;\n          }\n\n          if (x2 > this.xMax) {\n            x2 = this.xMax;\n          }\n          console.log('line( ' + x1 + ',' + this.pStart.y + ',' + x2 + ',' + this.pEnd.y + ')');\n          if (this.pStart.y < this.yMin || this.yMax < this.pEnd.y)\n            return -1;\n          else \n            return  [x1, this.pStart.y, x2, this.pEnd.y];\n        }\n      }\n    }\n  }\n\n  var t1 = 0;\n  var t2 = 1;\n\n  for (var i = 0; i < 4; i++) {\n    var temp = q[i] / p[i];\n    console.log(temp);\n    if (p[i] < 0) {\n      if (t1 <= temp)\n        t1 = temp;\n    }\n    else {\n      if (t2 > temp)\n        t2 = temp;\n    }\n  }\n\n//TODO: review\n  if (t1 < t2) {\n    let xx1 = x1 + t1 * p[1];\n    let xx2 = x1 + t2 * p[1];\n    let yy1 = y1 + t1 * p[3];\n    let yy2 = y1 + t2 * p[3];\n    console.log('line( ' + xx1 + ',' + yy1 + ',' + xx2 + ',' + yy2 + ')');\n    return [xx1, yy1, xx2, yy2];\n  }\n}\n\n}\n"],"names":["Point","x","y","arguments","length","babelHelpers.typeof","Array","isArray","prototype","setX","setY","Rectangle","LiangBarsky","startX","startY","endX","endY","width","height","rectX","rectY","pStart","pEnd","xMin","yMin","xMax","yMax","deltaX","deltaY","pLeft","qLeft","pRight","qRight","pBottom","qBottom","pTop","qTop","uLeft","uRight","uBottom","uTop","p","q","push","x1","y1","x2","y2","i","debug","log","t1","t2","temp","xx1","xx2","yy1","yy2"],"mappings":";;;;;;;;;AAAA;;;;;;;;;AAUA,AAAO,SAASA,KAAT,GAAgB;OAChBC,CAAL,GAAS,KAAKC,CAAL,GAAQ,CAAjB;;UAEOC,UAAUC,MAAjB;SACO,CAAL;;SAEK,CAAL;UACMC,QAAOF,UAAU,CAAV,CAAP,KAAwB,QAA5B,EAAsC;YACjCG,MAAMC,OAAN,CAAcJ,UAAU,CAAV,CAAd,CAAH,EAA+B;eACxBF,CAAL,GAASE,UAAU,CAAV,EAAa,CAAb,CAAT;eACKD,CAAL,GAASC,UAAU,CAAV,EAAa,CAAb,CAAT;;;aAGG,IAAGA,UAAU,CAAV,aAAwBH,KAA3B,EAAmC;iBACjCC,CAAL,GAASE,UAAU,CAAV,EAAaF,CAAtB;iBACKC,CAAL,GAASC,UAAU,CAAV,EAAaD,CAAtB;;OARJ,MAUO;aACAD,CAAL,GAAS,KAAKC,CAAL,GAASC,UAAU,CAAV,CAAlB;;;SAGC,CAAL;WACOF,CAAL,GAASE,UAAU,CAAV,CAAT;WACKD,CAAL,GAASC,UAAU,CAAV,CAAT;;;;AAINH,MAAMQ,SAAN,GAAkB;;QAEV,cAASP,CAAT,EAAW;SAAMA,CAAL,GAASA,CAAT;GAFF;QAGV,cAASC,CAAT,EAAW;SAAMA,CAAL,GAASA,CAAT;GAHF;;OAKX,gBAASD,CAAT,EAAYC,CAAZ,EAAc;SACZO,IAAL,CAAUR,CAAV;SACKS,IAAL,CAAUR,CAAV;GAPc;;SAUT,iBAAU;WACR,IAAIF,KAAJ,CAAU,KAAKC,CAAf,EAAkB,KAAKC,CAAvB,CAAP;;CAXJ,CAeA,AAAO,AAqBPS;;ACzEA;;;;;AAKA,AAEA,AAAO,SAASC,WAAT,CAAqBC,MAArB,EAA6BC,MAA7B,EAAqCC,IAArC,EAA2CC,IAA3C,EAAiDC,KAAjD,EAAwDC,MAAxD,EAAgEC,KAAhE,EAAuEC,KAAvE,EAA6E;;OAE7EC,MAAL,GAAc,IAAIrB,KAAJ,CAAUa,MAAV,EAAkBC,MAAlB,CAAd,EAAyC,KAAKQ,IAAL,GAAY,IAAItB,KAAJ,CAAUe,IAAV,EAAgBC,IAAhB,CAArD;;OAEKO,IAAL,GAAYJ,KAAZ,EACA,KAAKK,IAAL,GAAYJ,KADZ;OAEKK,IAAL,GAAYR,KAAZ,EACA,KAAKS,IAAL,GAAYR,MADZ;;;AAMFN,YAAYJ,SAAZ,GAAwB;WACd,mBAAU;;QAEdmB,SAAS,KAAKL,IAAL,CAAUrB,CAAV,GAAc,KAAKoB,MAAL,CAAYpB,CAAvC;QACE2B,SAAS,KAAKN,IAAL,CAAUpB,CAAV,GAAc,KAAKmB,MAAL,CAAYnB,CADrC;;QAGI2B,QAAU,CAACF,MAAf;QAAuBG,QAAU,KAAKT,MAAL,CAAYpB,CAAZ,GAAgB,KAAKsB,IAAtD;QACIQ,SAAUJ,MADd;QACuBK,SAAU,KAAKP,IAAL,GAAY,KAAKJ,MAAL,CAAYpB,CADzD;QAEIgC,UAAU,CAACL,MAFf;QAEuBM,UAAU,KAAKb,MAAL,CAAYnB,CAAZ,GAAgB,KAAKsB,IAFtD;QAGIW,OAAUP,MAHd;QAGuBQ,OAAU,KAAKV,IAAL,GAAY,KAAKL,MAAL,CAAYnB,CAHzD;;;;QAOImC,QAASP,QAAMD,KAAnB;QACES,SAAUN,SAAOD,MADnB;QAEEQ,UAAUL,UAAQD,OAFpB;QAGEO,OAAQJ,OAAKD,IAHf;;QAKIM,IAAI,IAAInC,KAAJ,EAAR;QAAqBoC,IAAI,IAAIpC,KAAJ,EAAzB;MACEqC,IAAF,CAAOd,KAAP,EAAcY,EAAEE,IAAF,CAAOZ,MAAP,EAAeU,EAAEE,IAAF,CAAOV,OAAP,EAAgBQ,EAAEE,IAAF,CAAOR,IAAP;MAC3CQ,IAAF,CAAOb,KAAP,EAAcY,EAAEC,IAAF,CAAOX,MAAP,EAAeU,EAAEC,IAAF,CAAOT,OAAP,EAAgBQ,EAAEC,IAAF,CAAOP,IAAP;;QAEzCQ,KAAK,KAAKvB,MAAL,CAAYpB,CAArB;QAAwB4C,KAAK,KAAKxB,MAAL,CAAYnB,CAAzC;QACI4C,KAAK,KAAKxB,IAAL,CAAUrB,CADnB;QACuB8C,KAAK,KAAKzB,IAAL,CAAUpB,CADtC;;SAGK,IAAI8C,IAAI,CAAb,EAAgBA,IAAI,CAApB,EAAuBA,GAAvB,EAA4B;UACtBP,EAAEO,CAAF,KAAQ,CAAZ,EAAe;gBACLC,KAAR,CAAc,kDAAd;;YAEIP,EAAEM,CAAF,KAAQ,CAAZ,EAAe;;cAETA,IAAI,CAAR,EAAW;gBACLH,KAAK,KAAKrB,IAAd,EAAoB;mBACb,KAAKA,IAAV;;;gBAGEuB,KAAK,KAAKrB,IAAd,EAAoB;mBACb,KAAKA,IAAV;;;oBAGMwB,GAAR,CAAY,WAAW,KAAK7B,MAAL,CAAYpB,CAAvB,GAA2B,GAA3B,GAAiC4C,EAAjC,GAAsC,GAAtC,GAA4C,KAAKvB,IAAL,CAAUrB,CAAtD,GAA0D,GAA1D,GAAgE8C,EAAhE,GAAqE,GAAjF;gBACI,KAAK1B,MAAL,CAAYpB,CAAZ,GAAgB,KAAKsB,IAArB,IAA6B,KAAKE,IAAL,GAAY,KAAKH,IAAL,CAAUrB,CAAvD,EACE,OAAO,CAAC,CAAR,CADF,KAGE,OAAQ,CAAC,KAAKoB,MAAL,CAAYpB,CAAb,EAAgB4C,EAAhB,EAAoB,KAAKvB,IAAL,CAAUrB,CAA9B,EAAiC8C,EAAjC,CAAR;;;cAGAC,IAAI,CAAR,EAAW;gBACLJ,KAAK,KAAKrB,IAAd,EAAoB;mBACb,KAAKA,IAAV;;;gBAGEuB,KAAK,KAAKrB,IAAd,EAAoB;mBACb,KAAKA,IAAV;;oBAEMyB,GAAR,CAAY,WAAWN,EAAX,GAAgB,GAAhB,GAAsB,KAAKvB,MAAL,CAAYnB,CAAlC,GAAsC,GAAtC,GAA4C4C,EAA5C,GAAiD,GAAjD,GAAuD,KAAKxB,IAAL,CAAUpB,CAAjE,GAAqE,GAAjF;gBACI,KAAKmB,MAAL,CAAYnB,CAAZ,GAAgB,KAAKsB,IAArB,IAA6B,KAAKE,IAAL,GAAY,KAAKJ,IAAL,CAAUpB,CAAvD,EACE,OAAO,CAAC,CAAR,CADF,KAGE,OAAQ,CAAC0C,EAAD,EAAK,KAAKvB,MAAL,CAAYnB,CAAjB,EAAoB4C,EAApB,EAAwB,KAAKxB,IAAL,CAAUpB,CAAlC,CAAR;;;;;;QAMNiD,KAAK,CAAT;QACIC,KAAK,CAAT;;SAEK,IAAIJ,IAAI,CAAb,EAAgBA,IAAI,CAApB,EAAuBA,GAAvB,EAA4B;UACtBK,OAAOX,EAAEM,CAAF,IAAOP,EAAEO,CAAF,CAAlB;cACQE,GAAR,CAAYG,IAAZ;UACIZ,EAAEO,CAAF,IAAO,CAAX,EAAc;YACRG,MAAME,IAAV,EACEF,KAAKE,IAAL;OAFJ,MAIK;YACCD,KAAKC,IAAT,EACED,KAAKC,IAAL;;;;;QAKFF,KAAKC,EAAT,EAAa;UACPE,MAAMV,KAAKO,KAAKV,EAAE,CAAF,CAApB;UACIc,MAAMX,KAAKQ,KAAKX,EAAE,CAAF,CAApB;UACIe,MAAMX,KAAKM,KAAKV,EAAE,CAAF,CAApB;UACIgB,MAAMZ,KAAKO,KAAKX,EAAE,CAAF,CAApB;cACQS,GAAR,CAAY,WAAWI,GAAX,GAAiB,GAAjB,GAAuBE,GAAvB,GAA6B,GAA7B,GAAmCD,GAAnC,GAAyC,GAAzC,GAA+CE,GAA/C,GAAqD,GAAjE;aACO,CAACH,GAAD,EAAME,GAAN,EAAWD,GAAX,EAAgBE,GAAhB,CAAP;;;;CAxFJ;;;;"}