Commit 9a217659 authored by Dmitry.Shahtanov's avatar Dmitry.Shahtanov Committed by Alexander.Trofimov

scroll ver 4.2

добавлена анимация стрелок;
добавлена подсветка ползунка при наведении на подложку скролла.

git-svn-id: svn://192.168.3.15/activex/AVS/Sources/TeamlabOffice/trunk/OfficeWeb@58442 954022d7-b5bf-4e40-9824-e11837661b57
parent e82564f7
...@@ -12,7 +12,8 @@ var ScrollOverType = { ...@@ -12,7 +12,8 @@ var ScrollOverType = {
NONE:0, NONE:0,
OVER:1, OVER:1,
ACTIVE:2, ACTIVE:2,
STABLE:3 STABLE:3,
LAYER:4
}; };
var ArrowStatus = { var ArrowStatus = {
...@@ -77,17 +78,17 @@ function CArrowDrawer( settings ) { ...@@ -77,17 +78,17 @@ function CArrowDrawer( settings ) {
this.ColorGradStart = []; this.ColorGradStart = [];
this.ColorGradEnd = []; this.ColorGradEnd = [];
this.ColorGradStart[ScrollOverType.NONE] = HEXTORGB( settings && settings.arrowColor ? settings.arrowColor : "#888888" )//{R:207, G:207, B:207}; this.ColorGradStart[ScrollOverType.NONE] = HEXTORGB( settings && settings.arrowColor ? settings.arrowColor : "#888888" );
this.ColorGradEnd[ScrollOverType.NONE] = HEXTORGB( settings && settings.arrowColor ? settings.arrowColor : "#888888" )//{R:207, G:207, B:207}; this.ColorGradEnd[ScrollOverType.NONE] = HEXTORGB( settings && settings.arrowColor ? settings.arrowColor : "#888888" );
this.ColorGradStart[ScrollOverType.STABLE] = HEXTORGB( settings && settings.arrowStableColor ? settings.arrowStableColor : "#888888" )//{R:203, G:203, B:203}; this.ColorGradStart[ScrollOverType.STABLE] = HEXTORGB( settings && settings.arrowStableColor ? settings.arrowStableColor : "#888888" );
this.ColorGradEnd[ScrollOverType.STABLE] = HEXTORGB( settings && settings.arrowStableColor ? settings.arrowStableColor : "#888888" )//{R:203, G:203, B:203}; this.ColorGradEnd[ScrollOverType.STABLE] = HEXTORGB( settings && settings.arrowStableColor ? settings.arrowStableColor : "#888888" );
this.ColorGradStart[ScrollOverType.OVER] = HEXTORGB( settings && settings.arrowOverColor ? settings.arrowOverColor : "#f1f1f1" )//{R:241, G:241, B:241}; this.ColorGradStart[ScrollOverType.OVER] = HEXTORGB( settings && settings.arrowOverColor ? settings.arrowOverColor : "#f1f1f1" );
this.ColorGradEnd[ScrollOverType.OVER] = HEXTORGB( settings && settings.arrowOverColor ? settings.arrowOverColor : "#f1f1f1" )//{R:241, G:241, B:241}; this.ColorGradEnd[ScrollOverType.OVER] = HEXTORGB( settings && settings.arrowOverColor ? settings.arrowOverColor : "#f1f1f1" );
this.ColorGradStart[ScrollOverType.ACTIVE] = HEXTORGB( settings && settings.arrowActiveColor ? settings.arrowActiveColor : "#f1f1f1" )//{R:207, G:207, B:207}; this.ColorGradStart[ScrollOverType.ACTIVE] = HEXTORGB( settings && settings.arrowActiveColor ? settings.arrowActiveColor : "#f1f1f1" );
this.ColorGradEnd[ScrollOverType.ACTIVE] = HEXTORGB( settings && settings.arrowActiveColor ? settings.arrowActiveColor : "#f1f1f1" )//{R:207, G:207, B:207}; this.ColorGradEnd[ScrollOverType.ACTIVE] = HEXTORGB( settings && settings.arrowActiveColor ? settings.arrowActiveColor : "#f1f1f1" );
this.ColorBorderNone = settings && settings.arrowBorderColor ? settings.arrowBorderColor : "#cfcfcf"; this.ColorBorderNone = settings && settings.arrowBorderColor ? settings.arrowBorderColor : "#cfcfcf";
this.ColorBorderStable = settings && settings.arrowStableBorderColor ? settings.arrowStableBorderColor : "#cfcfcf"; this.ColorBorderStable = settings && settings.arrowStableBorderColor ? settings.arrowStableBorderColor : "#cfcfcf";
...@@ -95,23 +96,10 @@ function CArrowDrawer( settings ) { ...@@ -95,23 +96,10 @@ function CArrowDrawer( settings ) {
this.ColorBorderActive = settings && settings.arrowActiveBorderColor ? settings.arrowActiveBorderColor : "#848484"; this.ColorBorderActive = settings && settings.arrowActiveBorderColor ? settings.arrowActiveBorderColor : "#848484";
this.ColorBackNone = settings && settings.arrowBackgroundColor ? settings.arrowBackgroundColor : "#F1F1F1"; this.ColorBackNone = settings && settings.arrowBackgroundColor ? settings.arrowBackgroundColor : "#F1F1F1";
this.ColorBackStable = settings && settings.arrowStableBackgroundColor ? settings.arrowStableBackgroundColor : "#848484"; this.ColorBackStable = settings && settings.arrowStableBackgroundColor ? settings.arrowStableBackgroundColor : "#F1F1F1";
this.ColorBackOver = settings && settings.arrowOverBackgroundColor ? settings.arrowOverBackgroundColor : "#cfcfcf"; this.ColorBackOver = settings && settings.arrowOverBackgroundColor ? settings.arrowOverBackgroundColor : "#cfcfcf";
this.ColorBackActive = settings && settings.arrowActiveBackgroundColor ? settings.arrowActiveBackgroundColor : "#848484"; this.ColorBackActive = settings && settings.arrowActiveBackgroundColor ? settings.arrowActiveBackgroundColor : "#848484";
// arrowNormalColor
// arrowNormalBorderColor
// arrowNormalBackgroundColor
// arrowStableColor
// arrowStableBorderColor
// arrowStableBackgroundColor
// arrowOverColor
// arrowOverBorderColor
// arrowOverBackgroundColor
// arrowActiveColor
// arrowActiveBorderColor
// arrowActiveBackgroundColor
// вот такие мега настройки для кастомизации) // вот такие мега настройки для кастомизации)
this.IsDrawBorderInNoneMode = false; this.IsDrawBorderInNoneMode = false;
this.IsDrawBorders = true this.IsDrawBorders = true
...@@ -123,6 +111,27 @@ function CArrowDrawer( settings ) { ...@@ -123,6 +111,27 @@ function CArrowDrawer( settings ) {
this.ImageBottom = null; this.ImageBottom = null;
this.IsNeedInvertOnActive = settings && settings.isNeedInvertOnActive ? settings.isNeedInvertOnActive : false; this.IsNeedInvertOnActive = settings && settings.isNeedInvertOnActive ? settings.isNeedInvertOnActive : false;
this.lastArrowStatus1 = -1;
this.lastArrowStatus2 = -1;
this.startColorFadeInOutStart1 = {R:-1,G:-1,B:-1};
this.startColorFadeInOutStart2 = {R:-1,G:-1,B:-1};
this.fadeInTimeoutFirst = -1;
this.fadeOutTimeoutFirst = -1;
this.fadeInTimeout1 = -1;
this.fadeOutTimeout1 = -1;
this.fadeInTimeout2 = -1;
this.fadeOutTimeout2 = -1;
this.fadeInActive1 = false;
this.fadeOutActive1 = false;
this.fadeInActive2 = false;
this.fadeOutActive2 = false;
} }
CArrowDrawer.prototype.InitSize = function ( sizeW, sizeH, is_retina ) { CArrowDrawer.prototype.InitSize = function ( sizeW, sizeH, is_retina ) {
if ( ( sizeH == this.SizeH || sizeW == this.SizeW ) && is_retina == this.IsRetina && null != this.ImageLeft ) if ( ( sizeH == this.SizeH || sizeW == this.SizeW ) && is_retina == this.IsRetina && null != this.ImageLeft )
...@@ -144,208 +153,1130 @@ CArrowDrawer.prototype.InitSize = function ( sizeW, sizeH, is_retina ) { ...@@ -144,208 +153,1130 @@ CArrowDrawer.prototype.InitSize = function ( sizeW, sizeH, is_retina ) {
this.ImageLeft[ScrollOverType.NONE].width = this.SizeW; this.ImageLeft[ScrollOverType.NONE].width = this.SizeW;
this.ImageLeft[ScrollOverType.NONE].height = this.SizeH; this.ImageLeft[ScrollOverType.NONE].height = this.SizeH;
this.ImageLeft[ScrollOverType.STABLE].width = this.SizeW;
this.ImageLeft[ScrollOverType.STABLE].height = this.SizeH;
this.ImageLeft[ScrollOverType.OVER].width = this.SizeW; this.ImageLeft[ScrollOverType.OVER].width = this.SizeW;
this.ImageLeft[ScrollOverType.OVER].height = this.SizeH; this.ImageLeft[ScrollOverType.OVER].height = this.SizeH;
this.ImageLeft[ScrollOverType.ACTIVE].width = this.SizeW; this.ImageLeft[ScrollOverType.ACTIVE].width = this.SizeW;
this.ImageLeft[ScrollOverType.ACTIVE].height = this.SizeH; this.ImageLeft[ScrollOverType.ACTIVE].height = this.SizeH;
this.ImageLeft[ScrollOverType.STABLE].width = this.SizeW;
this.ImageLeft[ScrollOverType.STABLE].height = this.SizeH;
this.ImageTop[ScrollOverType.NONE].width = this.SizeW; this.ImageTop[ScrollOverType.NONE].width = this.SizeW;
this.ImageTop[ScrollOverType.NONE].height = this.SizeH; this.ImageTop[ScrollOverType.NONE].height = this.SizeH;
this.ImageTop[ScrollOverType.STABLE].width = this.SizeW;
this.ImageTop[ScrollOverType.STABLE].height = this.SizeH;
this.ImageTop[ScrollOverType.OVER].width = this.SizeW; this.ImageTop[ScrollOverType.OVER].width = this.SizeW;
this.ImageTop[ScrollOverType.OVER].height = this.SizeH; this.ImageTop[ScrollOverType.OVER].height = this.SizeH;
this.ImageTop[ScrollOverType.ACTIVE].width = this.SizeW; this.ImageTop[ScrollOverType.ACTIVE].width = this.SizeW;
this.ImageTop[ScrollOverType.ACTIVE].height = this.SizeH; this.ImageTop[ScrollOverType.ACTIVE].height = this.SizeH;
this.ImageTop[ScrollOverType.STABLE].width = this.SizeW;
this.ImageTop[ScrollOverType.STABLE].height = this.SizeH;
this.ImageRight[ScrollOverType.NONE].width = this.SizeW; this.ImageRight[ScrollOverType.NONE].width = this.SizeW;
this.ImageRight[ScrollOverType.NONE].height = this.SizeH; this.ImageRight[ScrollOverType.NONE].height = this.SizeH;
this.ImageRight[ScrollOverType.STABLE].width = this.SizeW;
this.ImageRight[ScrollOverType.STABLE].height = this.SizeH;
this.ImageRight[ScrollOverType.OVER].width = this.SizeW; this.ImageRight[ScrollOverType.OVER].width = this.SizeW;
this.ImageRight[ScrollOverType.OVER].height = this.SizeH; this.ImageRight[ScrollOverType.OVER].height = this.SizeH;
this.ImageRight[ScrollOverType.ACTIVE].width = this.SizeW; this.ImageRight[ScrollOverType.ACTIVE].width = this.SizeW;
this.ImageRight[ScrollOverType.ACTIVE].height = this.SizeH; this.ImageRight[ScrollOverType.ACTIVE].height = this.SizeH;
this.ImageRight[ScrollOverType.STABLE].width = this.SizeW;
this.ImageRight[ScrollOverType.STABLE].height = this.SizeH;
this.ImageBottom[ScrollOverType.NONE].width = this.SizeW; this.ImageBottom[ScrollOverType.NONE].width = this.SizeW;
this.ImageBottom[ScrollOverType.NONE].height = this.SizeH; this.ImageBottom[ScrollOverType.NONE].height = this.SizeH;
this.ImageBottom[ScrollOverType.STABLE].width = this.SizeW;
this.ImageBottom[ScrollOverType.STABLE].height = this.SizeH;
this.ImageBottom[ScrollOverType.OVER].width = this.SizeW; this.ImageBottom[ScrollOverType.OVER].width = this.SizeW;
this.ImageBottom[ScrollOverType.OVER].height = this.SizeH; this.ImageBottom[ScrollOverType.OVER].height = this.SizeH;
this.ImageBottom[ScrollOverType.ACTIVE].width = this.SizeW; this.ImageBottom[ScrollOverType.ACTIVE].width = this.SizeW;
this.ImageBottom[ScrollOverType.ACTIVE].height = this.SizeH; this.ImageBottom[ScrollOverType.ACTIVE].height = this.SizeH;
this.ImageBottom[ScrollOverType.STABLE].width = this.SizeW;
this.ImageBottom[ScrollOverType.STABLE].height = this.SizeH;
var len = 6; var len = 6;
if ( this.SizeH < 6 ) if ( this.SizeH < 6 )
return; return;
// else (this.SizeH > 12) // else (this.SizeH > 12)
// len = this.Size - 8; // len = this.Size - 8;
// теперь делаем нечетную длину
if ( 0 == (len & 1) )
len += 1;
var countPart = (len + 1) >> 1,
plusColor, _data, px,
_x = ((this.SizeW - len) >> 1),
_y = this.SizeH - ((this.SizeH - countPart) >> 1),
_radx = _x + (len >> 1),
_rady = _y - (countPart >> 1),
ctx_lInactive, ctx_tInactive, ctx_rInactive, ctx_bInactive,
r, g, b;
for ( var index = 0; index < this.ImageTop.length; index++ ) {
var __x = _x, __y = _y, _len = len;
r = this.ColorGradStart[index].R;
g = this.ColorGradStart[index].G;
b = this.ColorGradStart[index].B;
ctx_tInactive = this.ImageTop[index].getContext( '2d' );
ctx_lInactive = this.ImageLeft[index].getContext( '2d' );
ctx_rInactive = this.ImageRight[index].getContext( '2d' );
ctx_bInactive = this.ImageBottom[index].getContext( '2d' );
plusColor = (this.ColorGradEnd[index].R - this.ColorGradStart[index].R) / countPart;
_data = ctx_tInactive.createImageData( this.SizeW, this.SizeH );
px = _data.data;
while ( _len > 0 ) {
var ind = 4 * ( this.SizeW * __y + __x );
for ( var i = 0; i < _len; i++ ) {
px[ind++] = r;
px[ind++] = g;
px[ind++] = b;
px[ind++] = 255;
}
r = (r + plusColor) >> 0;
g = (g + plusColor) >> 0;
b = (b + plusColor) >> 0;
__x += 1;
__y -= 1;
_len -= 2;
}
ctx_tInactive.putImageData( _data, 0, -1 );
ctx_lInactive.translate( _radx, _rady + 1 );
ctx_lInactive.rotate( -Math.PI / 2 );
ctx_lInactive.translate( -_radx, -_rady );
ctx_lInactive.drawImage( this.ImageTop[index], 0, 0 );
ctx_rInactive.translate( _radx + 1, _rady );
ctx_rInactive.rotate( Math.PI / 2 );
ctx_rInactive.translate( -_radx, -_rady );
ctx_rInactive.drawImage( this.ImageTop[index], 0, 0 );
ctx_bInactive.translate( _radx + 1, _rady + 1 );
ctx_bInactive.rotate( Math.PI );
ctx_bInactive.translate( -_radx, -_rady );
ctx_bInactive.drawImage( this.ImageTop[index], 0, 0 );
}
if ( this.IsRetina ) {
this.SizeW >>= 1;
this.SizeH >>= 1;
}
}
CArrowDrawer.prototype.drawArrow = function ( type, mode, ctx, w, h ) {
ctx.beginPath();
var startColorFadeIn = _HEXTORGB_( this.ColorBackNone ),
startColorFadeOut = _HEXTORGB_( this.ColorBackOver ),
that = this,
img = this.ImageTop[mode],
x = 0, y = 0, is_vertical = true,
bottomRightDelta = 1,
xDeltaIMG = 0, yDeltaIMG = 0, xDeltaBORDER = 0.5, yDeltaBORDER = 1.5,
tempIMG1 = document.createElement( 'canvas' ),
tempIMG2 = document.createElement( 'canvas' );
tempIMG1.width = 14;
tempIMG1.height = 15;
tempIMG2.width = 14;
tempIMG2.height = 15;
var ctx1 = tempIMG1.getContext('2d'),
ctx2 = tempIMG2.getContext('2d');
function fadeIn(){
ctx1.fillStyle = "rgb(" + that.startColorFadeInOutStart1.R + "," +
that.startColorFadeInOutStart1.G + "," +
that.startColorFadeInOutStart1.B + ")";
startColorFadeIn.R -= 2;
startColorFadeIn.G -= 2;
startColorFadeIn.B -= 2;
ctx1.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH );
ctx1.fill();
if ( that.IsDrawBorders ) {
ctx.strokeStyle = that.ColorBorderOver;
ctx.stroke();
}
ctx1.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, that.SizeW, that.SizeH );
if ( startColorFadeIn.R >= 207 ) {
that.startColorFadeInOutStart1 = startColorFadeIn;
that.fadeInTimeout = setTimeout( fadeIn, 30 );
}
else {
clearTimeout( that.fadeInTimeout );
that.fadeInTimeout = null;
that.fadeInActiveFirst = false;
startColorFadeIn.R += 2;
startColorFadeIn.G += 2;
startColorFadeIn.B += 2;
that.startColorFadeInOutStart1 = startColorFadeIn;
}
}
function fadeOut(){
ctx.fillStyle = "rgb(" + that.startColorFadeInOutStart1.R + "," +
that.startColorFadeInOutStart1.G + "," +
that.startColorFadeInOutStart1.B + ")";
startColorFadeOut.R += 2;
startColorFadeOut.G += 2;
startColorFadeOut.B += 2;
ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH );
ctx.fill();
if ( that.IsDrawBorders ) {
ctx.strokeStyle = that.ColorBorderOver;
ctx.stroke();
}
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, that.SizeW, that.SizeH );
if ( startColorFadeOut.R <= 241 ) {
that.startColorFadeInOutStart1 = startColorFadeOut;
that.fadeOutTimeout = setTimeout( fadeOut, 30 );
}
else {
clearTimeout( that.fadeOutTimeout );
that.fadeOutTimeout = null;
that.fadeOutActiveFirst = false;
startColorFadeOut.R -= 2;
startColorFadeOut.G -= 2;
startColorFadeOut.B -= 2;
that.startColorFadeInOutStart1 = startColorFadeOut;
}
}
if ( mode === null || mode === undefined ) {
mode = ScrollOverType.NONE;
}
switch ( type ) {
case ScrollArrowType.ARROW_LEFT:
{
x = 1;
y = -1;
is_vertical = false;
img = this.ImageLeft[mode];
break;
}
case ScrollArrowType.ARROW_RIGHT:
{
is_vertical = false;
x = w - this.SizeW - bottomRightDelta;
y = -1;
img = this.ImageRight[mode];
break;
}
case ScrollArrowType.ARROW_BOTTOM:
{
y = h - this.SizeH - bottomRightDelta - 1;
img = this.ImageBottom[mode];
break;
}
default:{
y = 0;
break;
}
}
ctx.lineWidth = 1;
var strokeW = is_vertical ? this.SizeW - 1 : this.SizeW - 1;
var strokeH = is_vertical ? this.SizeH - 1 : this.SizeH - 1;
switch ( mode ) {
case ScrollOverType.NONE:
{
if ( this.lastArrowStatus1 == ScrollOverType.OVER ) {
clearTimeout( this.fadeInTimeout );
this.fadeInTimeout = null;
clearTimeout( this.fadeOutTimeout );
this.fadeOutTimeout = null;
this.lastArrowStatus1 = mode;
this.startColorFadeInOutStart1 = this.startColorFadeInOutStart1.R < 0 ? startColorFadeOut : this.startColorFadeInOutStart1;
this.fadeOutActiveFirst = true;
fadeOut();
}
else{
ctx.fillStyle = this.ColorBackNone;
ctx.fillRect( x + 0, y + 0, strokeW + xDeltaBORDER + 1, strokeH + yDeltaBORDER + 1 );
ctx.beginPath();
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH );
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderNone;
ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
}
break;
}
case ScrollOverType.STABLE:
{
if ( this.lastArrowStatus1 == ScrollOverType.OVER ) {
clearTimeout( this.fadeInTimeout );
this.fadeInTimeout = null;
clearTimeout( this.fadeOutTimeout );
this.fadeOutTimeout = null;
this.lastArrowStatus1 = mode;
this.startColorFadeInOutStart1 = this.startColorFadeInOutStart1.R < 0 ? startColorFadeOut : this.startColorFadeInOutStart1;
this.fadeOutActiveFirst = true;
fadeOut();
}
else{
ctx.fillStyle = this.ColorBackStable;
ctx.fillRect( x + 0, y + 0, strokeW + xDeltaBORDER + 1, strokeH + yDeltaBORDER + 1 );
ctx.beginPath();
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH );
ctx.strokeStyle = this.ColorBackStable;
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderStable;
ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
}
break;
}
case ScrollOverType.OVER:
{
if ( this.lastArrowStatus1 == ScrollOverType.NONE || this.lastArrowStatus1 == ScrollOverType.STABLE ) {
clearTimeout( this.fadeInTimeout );
this.fadeInTimeout = null;
clearTimeout( this.fadeOutTimeout );
this.fadeOutTimeout = null;
this.lastArrowStatus1 = mode;
this.startColorFadeInOutStart1 = this.startColorFadeInOutStart1.R < 0 ? startColorFadeIn : this.startColorFadeInOutStart1;
this.fadeInActiveFirst = true;
fadeIn();
}
else{
ctx.beginPath();
ctx.fillStyle = this.ColorBackOver;
ctx.fillRect( x + xDeltaBORDER - .5, y + yDeltaBORDER - .5, strokeW + 1, strokeH + 1 );
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH );
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderOver;
ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
}
break;
}
case ScrollOverType.ACTIVE:
{
ctx.fillStyle = this.ColorBackActive;
ctx.fillRect( x + 0, y + 0, strokeW + xDeltaBORDER + 1, strokeH + yDeltaBORDER + 1 );
ctx.beginPath();
ctx.fillStyle = this.ColorBackActive;
ctx.fillRect( x + xDeltaBORDER - .5, y + yDeltaBORDER - .5, strokeW + 1, strokeH + 1 );
if ( !this.IsNeedInvertOnActive ) {
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH );
}
else {
// slow method
var _ctx = img.getContext( "2d" );
var _data = _ctx.getImageData( 0, 0, this.SizeW, this.SizeH );
var _data2 = _ctx.getImageData( 0, 0, this.SizeW, this.SizeH );
var _len = 4 * this.SizeW * this.SizeH;
for ( var i = 0; i < _len; i += 4 ) {
if ( _data.data[i + 3] == 255 ) {
_data.data[i] = 255;// - _data.data[i];
_data.data[i + 1] = 255;// - _data.data[i + 1];
_data.data[i + 2] = 255;// - _data.data[i + 2];
}
}
_ctx.putImageData( _data, 0, 0 );
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH );
for ( var i = 0; i < _len; i += 4 ) {
if ( _data.data[i + 3] == 255 ) {
_data.data[i] = 255 - _data.data[i];
_data.data[i + 1] = 255 - _data.data[i + 1];
_data.data[i + 2] = 255 - _data.data[i + 2];
}
}
_ctx.putImageData( _data2, 0, 0 );
_data = null;
_data2 = null;
}
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderActive;
ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
break;
}
default:{
break;
}
}
this.lastArrowStatus1 = mode;
}
CArrowDrawer.prototype.drawTopLeftArrow = function(type,mode,ctx,w,h){
clearTimeout( this.fadeInTimeout1 );
this.fadeInTimeout1 = null;
clearTimeout( this.fadeOutTimeout1 );
this.fadeOutTimeout1 = null;
ctx.beginPath();
var startColorFadeIn = this.startColorFadeInOutStart1.R < 0 ? _HEXTORGB_( this.ColorBackNone ) : this.startColorFadeInOutStart1,
startColorFadeOut = this.startColorFadeInOutStart1.R < 0 ? _HEXTORGB_( this.ColorBackOver ) : this.startColorFadeInOutStart1,
that = this,
img1 = this.ImageTop[mode],
x1 = 0, y1 = 0,
is_vertical = true,
xDeltaIMG = 0, yDeltaIMG = 0, xDeltaBORDER = 0.5, yDeltaBORDER = 1.5,
tempIMG1 = document.createElement( 'canvas' );
tempIMG1.width = 14;
tempIMG1.height = 15;
var ctx1 = tempIMG1.getContext('2d');
function fadeIn(){
var ctx_piperImg, px, _len;
ctx1.fillStyle = "rgb(" + that.startColorFadeInOutStart1.R + "," +
that.startColorFadeInOutStart1.G + "," +
that.startColorFadeInOutStart1.B + ")";
startColorFadeIn.R -= 2;
startColorFadeIn.G -= 2;
startColorFadeIn.B -= 2;
ctx1.rect( 0.5, 1.5, strokeW, strokeH );
ctx1.fill();
if ( that.IsDrawBorders ) {
ctx1.strokeStyle = that.ColorBorderOver;
ctx1.stroke();
}
ctx_piperImg = img1.getContext( '2d' );
_data = ctx_piperImg.getImageData( 0, 0, img1.width, img1.height );
px = _data.data;
_len = px.length;
for ( var i = 0; i < _len; i += 4 ) {
if ( px[i + 3] == 255 ) {
px[i] += 4;
px[i + 1] += 4;
px[i + 2] += 4;
}
}
ctx_piperImg.putImageData( _data, 0, 0 );
ctx1.drawImage( img1, 0, 0, that.SizeW, that.SizeH );
if ( startColorFadeIn.R >= 207 ) {
that.startColorFadeInOutStart1 = startColorFadeIn;
ctx.drawImage(tempIMG1,x1 + xDeltaIMG,y1 + yDeltaIMG);
that.fadeInTimeout1 = setTimeout( fadeIn, 30 );
}
else {
clearTimeout( that.fadeInTimeout1 );
that.fadeInTimeout1 = null;
that.fadeInActive1 = false;
startColorFadeIn.R += 2;
startColorFadeIn.G += 2;
startColorFadeIn.B += 2;
that.startColorFadeInOutStart1 = startColorFadeIn;
ctx_piperImg = img1.getContext( '2d' );
_data = ctx_piperImg.getImageData( 0, 0, img1.width, img1.height );
px = _data.data;
_len = px.length;
for ( var i = 0; i < _len; i += 4 ) {
if ( px[i + 3] == 255 ) {
px[i] -= 4;
px[i + 1] -= 4;
px[i + 2] -= 4;
}
}
ctx_piperImg.putImageData( _data, 0, 0 );
}
}
function fadeOut(){
var ctx_piperImg, px, _len;
ctx1.fillStyle = "rgb(" + that.startColorFadeInOutStart1.R + "," +
that.startColorFadeInOutStart1.G + "," +
that.startColorFadeInOutStart1.B + ")";
startColorFadeOut.R += 2;
startColorFadeOut.G += 2;
startColorFadeOut.B += 2;
ctx1.rect( 0.5, 1.5, strokeW, strokeH );
ctx1.fill();
if ( that.IsDrawBorders ) {
ctx1.strokeStyle = that.ColorBorderOver;
ctx1.stroke();
}
ctx_piperImg = img1.getContext( '2d' );
_data = ctx_piperImg.getImageData( 0, 0, img1.width, img1.height );
px = _data.data;
_len = px.length;
for ( var i = 0; i < _len; i += 4 ) {
if ( px[i + 3] == 255 ) {
// console.log("3 " + i + " " + " " + px[i])
px[i] -= 4;
px[i + 1] -= 4;
px[i + 2] -= 4;
}
}
ctx_piperImg.putImageData( _data, 0, 0 );
ctx1.drawImage( img1, 0, 0, that.SizeW, that.SizeH );
if ( startColorFadeOut.R <= 241 ) {
that.startColorFadeInOutStart1 = startColorFadeOut;
ctx.drawImage(tempIMG1,x1 + xDeltaIMG,y1 + yDeltaIMG);
that.fadeOutTimeout1 = setTimeout( fadeOut, 30 );
}
else {
clearTimeout( that.fadeOutTimeout1 );
that.fadeOutTimeout1 = null;
that.fadeOutActive1 = false;
startColorFadeOut.R -= 2;
startColorFadeOut.G -= 2;
startColorFadeOut.B -= 2;
that.startColorFadeInOutStart1 = startColorFadeOut;
ctx_piperImg = img1.getContext( '2d' );
_data = ctx_piperImg.getImageData( 0, 0, img1.width, img1.height );
px = _data.data;
_len = px.length;
for ( var i = 0; i < _len; i += 4 ) {
if ( px[i + 3] == 255 ) {
px[i] += 4;
px[i + 1] += 4;
px[i + 2] += 4;
}
}
ctx_piperImg.putImageData( _data, 0, 0 );
}
}
if ( mode === null || mode === undefined ) {
mode = ScrollOverType.NONE;
}
switch ( type ) {
case ScrollArrowType.ARROW_LEFT:
{
x1 = 1;
y1 = -1;
is_vertical = false;
img1 = this.ImageLeft[mode];
break;
}
default:
{
y1 = 0;
img1 = this.ImageTop[mode];
break;
}
}
ctx.lineWidth = 1;
var strokeW = is_vertical ? this.SizeW - 1 : this.SizeW - 1;
var strokeH = is_vertical ? this.SizeH - 1 : this.SizeH - 1;
switch ( mode ) {
case ScrollOverType.NONE:
{
if ( this.lastArrowStatus1 == ScrollOverType.OVER ) {
switch ( type ) {
case ScrollArrowType.ARROW_LEFT:
{
img1 = this.ImageLeft[ScrollOverType.STABLE];
break;
}
default:
{
img1 = this.ImageTop[ScrollOverType.STABLE];
break;
}
}
this.lastArrowStatus1 = mode;
this.startColorFadeInOutStart1 = this.startColorFadeInOutStart1.R < 0 ? startColorFadeOut : this.startColorFadeInOutStart1;
this.fadeOutActive1 = true;
fadeOut();
}
else{
if ( this.lastArrowStatus1 == ScrollOverType.ACTIVE ) {
var im, ctx_im, px, _data, c = this.ColorGradStart[ScrollOverType.STABLE];
switch ( type ) {
case ScrollArrowType.ARROW_LEFT:
{
im = this.ImageLeft[ScrollOverType.STABLE];
break;
}
default:
{
im = this.ImageTop[ScrollOverType.STABLE];
break;
}
}
ctx_im = im.getContext( '2d' );
_data = ctx_im.getImageData( 0, 0, img1.width, img1.height );
px = _data.data;
_len = px.length;
for ( var i = 0; i < _len; i += 4 ) {
if ( px[i + 3] == 255 ) {
px[i] = c.R;
px[i + 1] = c.G;
px[i + 2] = c.B;
}
}
this.startColorFadeInOutStart1 = {R:-1,G:-1,B:-1};
ctx_im.putImageData( _data, 0, 0 )
}
ctx.beginPath();
ctx.fillStyle = this.ColorBackNone;
ctx.fillRect( x1 + 0, y1 + 0, strokeW + xDeltaBORDER + 1, strokeH + yDeltaBORDER + 1 );
ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderNone;
ctx.rect( x1 + xDeltaBORDER, y1 + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
}
break;
}
case ScrollOverType.STABLE:
{
if ( this.lastArrowStatus1 == ScrollOverType.OVER ) {
switch ( type ) {
case ScrollArrowType.ARROW_LEFT:
{
img1 = this.ImageLeft[ScrollOverType.STABLE];
break;
}
default:
{
img1 = this.ImageTop[ScrollOverType.STABLE];
break;
}
}
this.lastArrowStatus1 = mode;
this.startColorFadeInOutStart1 = this.startColorFadeInOutStart1.R < 0 ? startColorFadeOut : this.startColorFadeInOutStart1;
this.fadeOutActive1 = true;
fadeOut();
}
else{
ctx.beginPath();
ctx.fillStyle = this.ColorBackStable;
ctx.fillRect( x1 + 0, y1 + 0, strokeW + xDeltaBORDER + 1, strokeH + yDeltaBORDER + 1 );
ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderStable;
ctx.rect( x1 + xDeltaBORDER, y1 + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
}
break;
}
case ScrollOverType.OVER:
{
if ( this.lastArrowStatus1 == ScrollOverType.NONE || this.lastArrowStatus1 == ScrollOverType.STABLE ) {
switch ( type ) {
case ScrollArrowType.ARROW_LEFT:
{
img1 = this.ImageLeft[ScrollOverType.STABLE];
break;
}
default:
{
img1 = this.ImageTop[ScrollOverType.STABLE];
break;
}
}
this.lastArrowStatus1 = mode;
this.startColorFadeInOutStart1 = this.startColorFadeInOutStart1.R < 0 ? startColorFadeIn : this.startColorFadeInOutStart1;
this.fadeInActive1 = true;
fadeIn();
}
else{
ctx.beginPath();
ctx.fillStyle = this.ColorBackOver;
ctx.fillRect( x1 + xDeltaBORDER - .5, y1 + yDeltaBORDER - .5, strokeW + 1, strokeH + 1 );
ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderOver;
ctx.rect( x1 + xDeltaBORDER, y1 + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
}
break;
}
case ScrollOverType.ACTIVE:
{
ctx.beginPath();
ctx.fillStyle = this.ColorBackActive;
ctx.fillRect( x1 + xDeltaBORDER - .5, y1 + yDeltaBORDER - .5, strokeW + 1, strokeH + 1 );
if ( !this.IsNeedInvertOnActive ) {
ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
}
else {
// slow method
var _ctx = img1.getContext( "2d" );
var _data = _ctx.getImageData( 0, 0, this.SizeW, this.SizeH );
var _data2 = _ctx.getImageData( 0, 0, this.SizeW, this.SizeH );
var _len = 4 * this.SizeW * this.SizeH;
for ( var i = 0; i < _len; i += 4 ) {
if ( _data.data[i + 3] == 255 ) {
_data.data[i] = 255;// - _data.data[i];
_data.data[i + 1] = 255;// - _data.data[i + 1];
_data.data[i + 2] = 255;// - _data.data[i + 2];
}
}
_ctx.putImageData( _data, 0, 0 );
ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
for ( var i = 0; i < _len; i += 4 ) {
if ( _data.data[i + 3] == 255 ) {
_data.data[i] = 255 - _data.data[i];
_data.data[i + 1] = 255 - _data.data[i + 1];
_data.data[i + 2] = 255 - _data.data[i + 2];
}
}
_ctx.putImageData( _data2, 0, 0 );
_data = null;
_data2 = null;
}
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderActive;
ctx.rect( x1 + xDeltaBORDER, y1 + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
break;
}
default:{
break;
}
}
this.lastArrowStatus1 = mode;
}
CArrowDrawer.prototype.drawBottomRightArrow = function(type,mode,ctx,w,h){
clearTimeout( this.fadeInTimeout2 );
this.fadeInTimeout2 = null;
clearTimeout( this.fadeOutTimeout2 );
this.fadeOutTimeout2 = null;
ctx.beginPath();
var startColorFadeIn = this.startColorFadeInOutStart2.R < 0 ? _HEXTORGB_( this.ColorBackNone ) : this.startColorFadeInOutStart2,
startColorFadeOut = this.startColorFadeInOutStart2.R < 0 ? _HEXTORGB_( this.ColorBackOver ) : this.startColorFadeInOutStart2,
that = this,
img1 = this.ImageTop[mode],
x1 = 0, y1 = 0,
is_vertical = true,
bottomRightDelta = 1,
xDeltaIMG = 0, yDeltaIMG = 0, xDeltaBORDER = 0.5, yDeltaBORDER = 1.5,
tempIMG1 = document.createElement( 'canvas' );
tempIMG1.width = 14;
tempIMG1.height = 15;
var ctx1 = tempIMG1.getContext('2d');
function fadeIn(){
var ctx_piperImg, px, _len;
ctx1.fillStyle = "rgb(" + that.startColorFadeInOutStart2.R + "," +
that.startColorFadeInOutStart2.G + "," +
that.startColorFadeInOutStart2.B + ")";
startColorFadeIn.R -= 2;
startColorFadeIn.G -= 2;
startColorFadeIn.B -= 2;
ctx1.rect( .5, 1.5, strokeW, strokeH );
ctx1.fill();
if ( that.IsDrawBorders ) {
ctx1.strokeStyle = that.ColorBorderOver;
ctx1.stroke();
}
ctx_piperImg = img1.getContext( '2d' );
_data = ctx_piperImg.getImageData( 0, 0, img1.width, img1.height );
px = _data.data;
_len = px.length;
for ( var i = 0; i < _len; i += 4 ) {
if ( px[i + 3] == 255 ) {
px[i] += 4;
px[i + 1] += 4;
px[i + 2] += 4;
}
}
ctx_piperImg.putImageData( _data, 0, 0 );
ctx1.drawImage( img1, 0, 0, that.SizeW, that.SizeH );
if ( startColorFadeIn.R >= 207 ) {
that.startColorFadeInOutStart2 = startColorFadeIn;
ctx.drawImage(tempIMG1,x1 + xDeltaIMG,y1 + yDeltaIMG);
that.fadeInTimeout2 = setTimeout( fadeIn, 30 );
}
else {
clearTimeout( that.fadeInTimeout2 );
that.fadeInTimeout2 = null;
that.fadeInActive2 = false;
startColorFadeIn.R += 2;
startColorFadeIn.G += 2;
startColorFadeIn.B += 2;
that.startColorFadeInOutStart2 = startColorFadeIn;
ctx_piperImg = img1.getContext( '2d' );
_data = ctx_piperImg.getImageData( 0, 0, img1.width, img1.height );
px = _data.data;
_len = px.length;
for ( var i = 0; i < _len; i += 4 ) {
if ( px[i + 3] == 255 ) {
px[i] -= 4;
px[i + 1] -= 4;
px[i + 2] -= 4;
}
}
ctx_piperImg.putImageData( _data, 0, 0 );
}
// теперь делаем нечетную длину }
if ( 0 == (len & 1) )
len += 1;
var countPart = (len + 1) >> 1, function fadeOut(){
plusColor, _data, px,
_x = ((this.SizeW - len) >> 1),
_y = this.SizeH - ((this.SizeH - countPart) >> 1),
_radx = _x + (len >> 1),
_rady = _y - (countPart >> 1),
ctx_lInactive, ctx_tInactive, ctx_rInactive, ctx_bInactive,
r, g, b;
for ( var index = 0; index < this.ImageTop.length; index++ ) { var ctx_piperImg, px, _len;
var __x = _x, __y = _y, _len = len;
r = this.ColorGradStart[index].R;
g = this.ColorGradStart[index].G;
b = this.ColorGradStart[index].B;
ctx_tInactive = this.ImageTop[index].getContext( '2d' ); ctx1.fillStyle = "rgb(" + that.startColorFadeInOutStart2.R + "," +
ctx_lInactive = this.ImageLeft[index].getContext( '2d' ); that.startColorFadeInOutStart2.G + "," +
ctx_rInactive = this.ImageRight[index].getContext( '2d' ); that.startColorFadeInOutStart2.B + ")";
ctx_bInactive = this.ImageBottom[index].getContext( '2d' );
plusColor = (this.ColorGradEnd[index].R - this.ColorGradStart[index].R) / countPart; startColorFadeOut.R += 2;
startColorFadeOut.G += 2;
startColorFadeOut.B += 2;
_data = ctx_tInactive.createImageData( this.SizeW, this.SizeH ); ctx1.rect( .5, 1.5, strokeW, strokeH );
px = _data.data; ctx1.fill();
while ( _len > 0 ) { if ( that.IsDrawBorders ) {
var ind = 4 * ( this.SizeW * __y + __x ); ctx1.strokeStyle = that.ColorBorderOver;
for ( var i = 0; i < _len; i++ ) { ctx1.stroke();
px[ind++] = r;
px[ind++] = g;
px[ind++] = b;
px[ind++] = 255;
} }
r = (r + plusColor) >> 0; ctx_piperImg = img1.getContext( '2d' );
g = (g + plusColor) >> 0; _data = ctx_piperImg.getImageData( 0, 0, img1.width, img1.height );
b = (b + plusColor) >> 0; px = _data.data;
_len = px.length;
__x += 1; for ( var i = 0; i < _len; i += 4 ) {
__y -= 1; if ( px[i + 3] == 255 ) {
_len -= 2; px[i] -= 4;
px[i + 1] -= 4;
px[i + 2] -= 4;
}
} }
ctx_tInactive.putImageData( _data, 0, -1 ); ctx_piperImg.putImageData( _data, 0, 0 );
ctx_lInactive.translate( _radx, _rady + 1 ); ctx1.drawImage( img1, 0, 0, that.SizeW, that.SizeH );
ctx_lInactive.rotate( -Math.PI / 2 );
ctx_lInactive.translate( -_radx, -_rady );
ctx_lInactive.drawImage( this.ImageTop[index], 0, 0 );
ctx_rInactive.translate( _radx + 1, _rady ); if ( startColorFadeOut.R <= 241 ) {
ctx_rInactive.rotate( Math.PI / 2 ); that.startColorFadeInOutStart2 = startColorFadeOut;
ctx_rInactive.translate( -_radx, -_rady ); ctx.drawImage(tempIMG1,x1 + xDeltaIMG,y1 + yDeltaIMG);
ctx_rInactive.drawImage( this.ImageTop[index], 0, 0 ); that.fadeOutTimeout2 = setTimeout( fadeOut, 30 );
}
else {
clearTimeout( that.fadeOutTimeout2 );
that.fadeOutTimeout2 = null;
that.fadeOutActive2 = false;
startColorFadeOut.R -= 2;
startColorFadeOut.G -= 2;
startColorFadeOut.B -= 2;
that.startColorFadeInOutStart2 = startColorFadeOut;
ctx_piperImg = img1.getContext( '2d' );
_data = ctx_piperImg.getImageData( 0, 0, img1.width, img1.height );
px = _data.data;
ctx_bInactive.translate( _radx + 1, _rady + 1 ); _len = px.length;
ctx_bInactive.rotate( Math.PI );
ctx_bInactive.translate( -_radx, -_rady ); for ( var i = 0; i < _len; i += 4 ) {
ctx_bInactive.drawImage( this.ImageTop[index], 0, 0 ); if ( px[i + 3] == 255 ) {
px[i] += 4;
px[i + 1] += 4;
px[i + 2] += 4;
}
}
ctx_piperImg.putImageData( _data, 0, 0 );
} }
if ( this.IsRetina ) {
this.SizeW >>= 1;
this.SizeH >>= 1;
} }
}
CArrowDrawer.prototype.drawArrow = function ( type, mode, ctx, w, h ) {
if ( mode === null || mode === undefined ) { if ( mode === null || mode === undefined ) {
mode = ScrollOverType.NONE; mode = ScrollOverType.NONE;
} }
var img = this.ImageTop[mode],
x = 0, y = 0, is_vertical = true,
bottomRightDelta = 1,
xDeltaIMG = 0, yDeltaIMG = 0, xDeltaBORDER = 0.5, yDeltaBORDER = 1.5;
switch ( type ) { switch ( type ) {
case ScrollArrowType.ARROW_LEFT: case ScrollArrowType.ARROW_RIGHT:
{ {
x = 1;
y = -1;
is_vertical = false; is_vertical = false;
img = this.ImageLeft[mode]; x1 = w - this.SizeW - bottomRightDelta;
y1 = -1;
img1 = this.ImageRight[mode];
break;
}
case ScrollArrowType.ARROW_BOTTOM:
{
y1 = h - this.SizeH - bottomRightDelta - 1;
img1 = this.ImageBottom[mode];
break; break;
} }
}
ctx.lineWidth = 1;
var strokeW = is_vertical ? this.SizeW - 1 : this.SizeW - 1;
var strokeH = is_vertical ? this.SizeH - 1 : this.SizeH - 1;
switch ( mode ) {
case ScrollOverType.NONE:
{
if ( this.lastArrowStatus2 == ScrollOverType.OVER ) {
switch ( type ) {
case ScrollArrowType.ARROW_RIGHT: case ScrollArrowType.ARROW_RIGHT:
{ {
is_vertical = false; img1 = this.ImageRight[ScrollOverType.STABLE];
x = w - this.SizeW - bottomRightDelta;
y = -1;
img = this.ImageRight[mode];
break; break;
} }
case ScrollArrowType.ARROW_BOTTOM: default:
{ {
y = h - this.SizeH - bottomRightDelta - 1; img1 = this.ImageBottom[ScrollOverType.STABLE];
img = this.ImageBottom[mode]; break;
}
}
this.lastArrowStatus2 = mode;
this.startColorFadeInOutStart2 = this.startColorFadeInOutStart2.R < 0 ? startColorFadeOut : this.startColorFadeInOutStart2;
this.fadeOutActive2 = true;
fadeOut();
}
else{
if ( this.lastArrowStatus2 == ScrollOverType.ACTIVE ) {
var im, ctx_im, px, _data, c = this.ColorGradStart[ScrollOverType.STABLE];
switch ( type ) {
case ScrollArrowType.ARROW_RIGHT:
{
im = this.ImageRight[ScrollOverType.STABLE];
break; break;
} }
default: default:
y = 0; {
im = this.ImageBottom[ScrollOverType.STABLE];
break; break;
} }
}
ctx.lineWidth = 1; ctx_im = im.getContext( '2d' );
var strokeW = is_vertical ? this.SizeW - 1 : this.SizeW - 1; _data = ctx_im.getImageData( 0, 0, img1.width, img1.height );
var strokeH = is_vertical ? this.SizeH - 1 : this.SizeH - 1; px = _data.data;
_len = px.length;
for ( var i = 0; i < _len; i += 4 ) {
if ( px[i + 3] == 255 ) {
px[i] = c.R;
px[i + 1] = c.G;
px[i + 2] = c.B;
}
}
this.startColorFadeInOutStart2 = {R:-1,G:-1,B:-1};
ctx_im.putImageData( _data, 0, 0 )
}
ctx.fillStyle = this.ColorBackNone;
ctx.fillRect( x, y, strokeW + xDeltaBORDER + 1, strokeH + yDeltaBORDER + 1 );
ctx.beginPath(); ctx.beginPath();
ctx.fillStyle = this.ColorBackNone;
ctx.fillRect( x1 + 0, y1 + 0, strokeW + xDeltaBORDER + 1, strokeH + yDeltaBORDER + 1 );
ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderNone;
ctx.rect( x1 + xDeltaBORDER, y1 + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
}
break;
}
case ScrollOverType.STABLE:
{
if ( this.lastArrowStatus2 == ScrollOverType.OVER ) {
switch ( mode ) { switch ( type ) {
case ScrollOverType.NONE: case ScrollArrowType.ARROW_RIGHT:
{
img1 = this.ImageRight[ScrollOverType.STABLE];
break;
}
default:
{ {
img1 = this.ImageBottom[ScrollOverType.STABLE];
break;
}
}
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH ); this.lastArrowStatus2 = mode;
this.startColorFadeInOutStart2 = this.startColorFadeInOutStart2.R < 0 ? startColorFadeOut : this.startColorFadeInOutStart2;
this.fadeOutActive2 = true;
fadeOut();
}
else{
ctx.beginPath();
ctx.fillStyle = this.ColorBackStable;
ctx.fillRect( x1 + 0, y1 + 0, strokeW + xDeltaBORDER + 1, strokeH + yDeltaBORDER + 1 );
ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
ctx.strokeStyle = this.ColorBackStable;
if ( this.IsDrawBorders ) { if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderNone; ctx.strokeStyle = this.ColorBorderStable;
ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH ); ctx.rect( x1 + xDeltaBORDER, y1 + yDeltaBORDER, strokeW, strokeH );
ctx.stroke(); ctx.stroke();
} }
}
break; break;
} }
case ScrollOverType.OVER: case ScrollOverType.OVER:
{ {
ctx.fillStyle = this.ColorBackOver;
// ctx.fill();
// ctx.fillStyle = this.ColorBackNone; if ( this.lastArrowStatus2 == ScrollOverType.NONE || this.lastArrowStatus2 == ScrollOverType.STABLE ) {
// ctx.fillRect( x + .5, y + .5, strokeW+2.5, strokeH+2.5 );
ctx.fillRect( x + xDeltaBORDER - .5, y + yDeltaBORDER - .5, strokeW + 1, strokeH + 1 ); switch ( type ) {
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH ); case ScrollArrowType.ARROW_RIGHT:
/*if ( this.IsDrawBorders ) { {
ctx.strokeStyle = this.ColorBorder; img1 = this.ImageRight[ScrollOverType.STABLE];
ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH ); break;
}
default:
{
img1 = this.ImageBottom[ScrollOverType.STABLE];
break;
}
}
this.lastArrowStatus2 = mode;
this.startColorFadeInOutStart2 = this.startColorFadeInOutStart2.R < 0 ? startColorFadeIn : this.startColorFadeInOutStart2;
this.fadeInActive2 = true;
fadeIn();
}
else{
ctx.beginPath();
ctx.fillStyle = this.ColorBackOver;
ctx.fillRect( x1 + xDeltaBORDER - .5, y1 + yDeltaBORDER - .5, strokeW + 1, strokeH + 1 );
ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderOver;
ctx.rect( x1 + xDeltaBORDER, y1 + yDeltaBORDER, strokeW, strokeH );
ctx.stroke(); ctx.stroke();
}*/ }
}
break; break;
} }
case ScrollOverType.ACTIVE: case ScrollOverType.ACTIVE:
{ {
ctx.beginPath();
ctx.fillStyle = this.ColorBackNone;
ctx.fillRect( x1 + 0, y1 + 0, strokeW + xDeltaBORDER + 1, strokeH + yDeltaBORDER + 1 );
ctx.fillStyle = this.ColorBackActive; ctx.fillStyle = this.ColorBackActive;
ctx.fillRect( x + xDeltaBORDER - .5, y + yDeltaBORDER - .5, strokeW + 1, strokeH + 1 ); ctx.fillRect( x1 + xDeltaBORDER - .5, y1 + yDeltaBORDER - .5, strokeW + 1, strokeH + 1 );
// ctx.fill();
if ( !this.IsNeedInvertOnActive ) { if ( !this.IsNeedInvertOnActive ) {
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH ); ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
// ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH );
} }
else { else {
// slow method // slow method
var _ctx = img.getContext( "2d" ); var _ctx = img1.getContext( "2d" );
var _data = _ctx.getImageData( 0, 0, this.SizeW, this.SizeH ); var _data = _ctx.getImageData( 0, 0, this.SizeW, this.SizeH );
var _data2 = _ctx.getImageData( 0, 0, this.SizeW, this.SizeH ); var _data2 = _ctx.getImageData( 0, 0, this.SizeW, this.SizeH );
...@@ -360,7 +1291,7 @@ CArrowDrawer.prototype.drawArrow = function ( type, mode, ctx, w, h ) { ...@@ -360,7 +1291,7 @@ CArrowDrawer.prototype.drawArrow = function ( type, mode, ctx, w, h ) {
} }
_ctx.putImageData( _data, 0, 0 ); _ctx.putImageData( _data, 0, 0 );
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH ); ctx.drawImage( img1, x1 + xDeltaIMG, y1 + yDeltaIMG, this.SizeW, this.SizeH );
for ( var i = 0; i < _len; i += 4 ) { for ( var i = 0; i < _len; i += 4 ) {
if ( _data.data[i + 3] == 255 ) { if ( _data.data[i + 3] == 255 ) {
...@@ -376,34 +1307,24 @@ CArrowDrawer.prototype.drawArrow = function ( type, mode, ctx, w, h ) { ...@@ -376,34 +1307,24 @@ CArrowDrawer.prototype.drawArrow = function ( type, mode, ctx, w, h ) {
} }
if ( this.IsDrawBorders ) { if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderActive; ctx.strokeStyle = this.ColorBorderActive;
ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH ); ctx.rect( x1 + xDeltaBORDER, y1 + yDeltaBORDER, strokeW, strokeH );
ctx.stroke(); ctx.stroke();
} }
break; break;
} }
case ScrollOverType.STABLE: default:{
{
ctx.drawImage( img, x + xDeltaIMG, y + yDeltaIMG, this.SizeW, this.SizeH );
ctx.strokeStyle = this.ColorBackStable;
if ( this.IsDrawBorders ) {
ctx.strokeStyle = this.ColorBorderStable;
ctx.rect( x + xDeltaBORDER, y + yDeltaBORDER, strokeW, strokeH );
ctx.stroke();
}
break; break;
} }
default:
break;
} }
ctx.beginPath(); this.lastArrowStatus2 = mode;
} }
function _HEXTORGB_( colorHEX ) { function _HEXTORGB_( colorHEX ) {
return { return {
R:parseInt( colorHEX.substring( 0, 2 ), 16 ), R:parseInt( colorHEX.substring( 1, 3 ), 16 ),
G:parseInt( colorHEX.substring( 2, 4 ), 16 ), G:parseInt( colorHEX.substring( 3, 5 ), 16 ),
B:parseInt( colorHEX.substring( 4, 6 ), 16 ) B:parseInt( colorHEX.substring( 5, 7 ), 16 )
} }
} }
...@@ -452,6 +1373,7 @@ function ScrollObject( elemID, settings, dbg ) { ...@@ -452,6 +1373,7 @@ function ScrollObject( elemID, settings, dbg ) {
arrowDim:13, arrowDim:13,
scrollerColor:"#f1f1f1", scrollerColor:"#f1f1f1",
scrollerColorOver:"#cfcfcf", scrollerColorOver:"#cfcfcf",
scrollerColorLayerOver:"#cfcfcf",
scrollerColorActive:"#848484", scrollerColorActive:"#848484",
scrollBackgroundColor:"#F1F1F1", scrollBackgroundColor:"#F1F1F1",
scrollBackgroundColorHover:"#F1F1F1", scrollBackgroundColorHover:"#F1F1F1",
...@@ -555,7 +1477,7 @@ function ScrollObject( elemID, settings, dbg ) { ...@@ -555,7 +1477,7 @@ function ScrollObject( elemID, settings, dbg ) {
this.piperImgHor[1].height = 5; this.piperImgHor[1].height = 5;
var r, g, b, ctx_piperImg, _data, px; var r, g, b, ctx_piperImg, _data, px;
r = _HEXTORGB_( "CFCFCF" ); r = _HEXTORGB_( "#CFCFCF" );
g = r.G; g = r.G;
b = r.B; b = r.B;
r = r.R; r = r.R;
...@@ -590,7 +1512,7 @@ function ScrollObject( elemID, settings, dbg ) { ...@@ -590,7 +1512,7 @@ function ScrollObject( elemID, settings, dbg ) {
ctx_piperImg.putImageData( _data, 0, 0 ) ctx_piperImg.putImageData( _data, 0, 0 )
r = _HEXTORGB_( "F1F1F1" ); r = _HEXTORGB_( "#F1F1F1" );
g = r.G; g = r.G;
b = r.B; b = r.B;
r = r.R; r = r.R;
...@@ -606,8 +1528,9 @@ ScrollObject.prototype = { ...@@ -606,8 +1528,9 @@ ScrollObject.prototype = {
var holder = document.getElementById( elemID ); var holder = document.getElementById( elemID );
if ( holder.getElementsByTagName( 'canvas' ).length == 0 ) if ( holder.getElementsByTagName( 'canvas' ).length == 0 ){
this.canvas = holder.appendChild( document.createElement( "CANVAS" ) ); this.canvas = holder.appendChild( document.createElement( "CANVAS" ) );
}
else { else {
this.canvas = holder.children[1]; this.canvas = holder.children[1];
} }
...@@ -619,17 +1542,21 @@ ScrollObject.prototype = { ...@@ -619,17 +1542,21 @@ ScrollObject.prototype = {
this.canvas.style.zIndex = 100; this.canvas.style.zIndex = 100;
this.canvas.style.position = "absolute"; this.canvas.style.position = "absolute";
this.canvas.style.top = "0px"; this.canvas.style.top = "0px";
if ( navigator.userAgent.toLowerCase().indexOf( "webkit" ) != -1 ) if ( navigator.userAgent.toLowerCase().indexOf( "webkit" ) != -1 ){
this.canvas.style.webkitUserSelect = "none"; this.canvas.style.webkitUserSelect = "none";
}
this.context = this.canvas.getContext( '2d' ); this.context = this.canvas.getContext( '2d' );
if ( !this.IsRetina ) if ( !this.IsRetina ){
this.context.setTransform( 1, 0, 0, 1, 0, 0 ); this.context.setTransform( 1, 0, 0, 1, 0, 0 );
else }
else{
this.context.setTransform( 2, 0, 0, 2, 0, 0 ); this.context.setTransform( 2, 0, 0, 2, 0, 0 );
}
if ( this.settings.showArrows ) if ( this.settings.showArrows ){
this.arrowPosition = this.settings.arrowDim + 2; this.arrowPosition = this.settings.arrowDim + 2;
}
this._setDimension( holder.clientHeight, holder.clientWidth ); this._setDimension( holder.clientHeight, holder.clientWidth );
this.maxScrollY = holder.firstElementChild.clientHeight - this.settings.screenH > 0 ? holder.firstElementChild.clientHeight - this.settings.screenH : 0; this.maxScrollY = holder.firstElementChild.clientHeight - this.settings.screenH > 0 ? holder.firstElementChild.clientHeight - this.settings.screenH : 0;
...@@ -666,8 +1593,9 @@ ScrollObject.prototype = { ...@@ -666,8 +1593,9 @@ ScrollObject.prototype = {
return false; return false;
} }
if ( this.canvas.addEventListener ) if ( this.canvas.addEventListener ){
this.canvas.addEventListener( 'DOMMouseScroll', this.evt_mousewheel, false ); this.canvas.addEventListener( 'DOMMouseScroll', this.evt_mousewheel, false );
}
this.context.fillStyle = this.settings.scrollBackgroundColor; this.context.fillStyle = this.settings.scrollBackgroundColor;
this.context.fillRect(0,0,this.canvasW,this.canvasH); this.context.fillRect(0,0,this.canvasW,this.canvasH);
...@@ -815,8 +1743,6 @@ ScrollObject.prototype = { ...@@ -815,8 +1743,6 @@ ScrollObject.prototype = {
that.scrollVCurrentY = pos; that.scrollVCurrentY = pos;
evt.scrollD = evt.scrollPositionY = that.scrollVCurrentY; evt.scrollD = evt.scrollPositionY = that.scrollVCurrentY;
evt.maxScrollY = that.maxScrollY; evt.maxScrollY = that.maxScrollY;
// that._drawArrow();
that._draw(); that._draw();
that.handleEvents( "onscrollvertical", evt ); that.handleEvents( "onscrollvertical", evt );
} }
...@@ -1041,17 +1967,20 @@ ScrollObject.prototype = { ...@@ -1041,17 +1967,20 @@ ScrollObject.prototype = {
startColorFadeIn = this.startColorFadeInOutStart < 0 ? this.startColorFadeInStart : this.startColorFadeInOutStart, startColorFadeIn = this.startColorFadeInOutStart < 0 ? this.startColorFadeInStart : this.startColorFadeInOutStart,
startColorFadeOut = this.startColorFadeInOutStart < 0 ? this.startColorFadeOutStart : this.startColorFadeInOutStart; startColorFadeOut = this.startColorFadeInOutStart < 0 ? this.startColorFadeOutStart : this.startColorFadeInOutStart;
function fadeIn() { function fadeIn() {
var x, y, img, clearTimeout( that.fadeInTimeout );
ctx_piperImg, _data, px; that.fadeInTimeout = null;
clearTimeout( that.fadeOutTimeout );
that.fadeOutTimeout = null;
var x, y, img, ctx_piperImg, _data, px;
that.context.beginPath(); that.context.beginPath();
drawScroller(); drawScroller();
that.context.fillStyle = "rgb(" + (that.startColorFadeInOutStart + 1) + "," + (that.startColorFadeInOutStart + 1) + "," + (that.startColorFadeInOutStart + 1) + ")"; that.context.fillStyle = "rgb(" + that.startColorFadeInOutStart + "," + that.startColorFadeInOutStart + "," + that.startColorFadeInOutStart + ")";
that.context.strokeStyle = that.settings.strokeStyleOver; that.context.strokeStyle = that.settings.strokeStyleOver;
that.context.fill(); that.context.fill();
...@@ -1148,18 +2077,22 @@ ScrollObject.prototype = { ...@@ -1148,18 +2077,22 @@ ScrollObject.prototype = {
img = that.piperImgHor[0]; img = that.piperImgHor[0];
} }
} }
if(img){ if(img){
that.context.drawImage( img, x, y ); that.context.drawImage( img, x, y );
} }
} }
function fadeOut() { function fadeOut() {
var x, y, img, clearTimeout( that.fadeInTimeout );
ctx_piperImg, _data, px; that.fadeInTimeout = null;
clearTimeout( that.fadeOutTimeout );
that.fadeOutTimeout = null;
var x, y, img, ctx_piperImg, _data, px;
that.context.beginPath(); that.context.beginPath();
...@@ -1265,7 +2198,6 @@ ScrollObject.prototype = { ...@@ -1265,7 +2198,6 @@ ScrollObject.prototype = {
img = that.piperImgHor[0]; img = that.piperImgHor[0];
} }
} }
if(img){ if(img){
...@@ -1323,7 +2255,7 @@ ScrollObject.prototype = { ...@@ -1323,7 +2255,7 @@ ScrollObject.prototype = {
_h = this.canvasH - (_y << 1); _h = this.canvasH - (_y << 1);
if ( _h > 0 ) { if ( _h > 0 ) {
this.context.rect( 0, _y, this.canvasW, _h/* + 1*/ ); this.context.rect( 0, _y, this.canvasW, _h );
} }
} }
else if ( this.isHorizontalScroll ) { else if ( this.isHorizontalScroll ) {
...@@ -1331,7 +2263,7 @@ ScrollObject.prototype = { ...@@ -1331,7 +2263,7 @@ ScrollObject.prototype = {
_w = this.canvasW - (_x << 1); _w = this.canvasW - (_x << 1);
if ( _w > 0 ) { if ( _w > 0 ) {
this.context.rect( _x/* - 1*/, 0, _w /*+ 1*/, this.canvasH ); this.context.rect( _x, 0, _w, this.canvasH );
} }
} }
...@@ -1364,17 +2296,20 @@ ScrollObject.prototype = { ...@@ -1364,17 +2296,20 @@ ScrollObject.prototype = {
this.context.lineWidth = 1; this.context.lineWidth = 1;
switch ( this.scrollerStatus ) { switch ( this.scrollerStatus ) {
case ScrollOverType.LAYER:
case ScrollOverType.OVER: case ScrollOverType.OVER:
{ {
this.context.fillStyle = this.settings.scrollerColorOver;
this.context.strokeStyle = this.settings.strokeStyleOver;
piperImgIndex = 1;
if ( this.lastScrollerStatus == ScrollOverType.NONE ) { if ( this.lastScrollerStatus == ScrollOverType.NONE ) {
this.lastScrollerStatus = this.scrollerStatus; this.lastScrollerStatus = this.scrollerStatus;
this.startColorFadeInOutStart = this.startColorFadeInOutStart < 0 ? startColorFadeIn : this.startColorFadeInOutStart; this.startColorFadeInOutStart = this.startColorFadeInOutStart < 0 ? startColorFadeIn : this.startColorFadeInOutStart;
this.fadeInActive = true; this.fadeInActive = true;
fadeIn(); fadeIn();
} }
else{
this.context.fillStyle = this.settings.scrollerColorOver;
this.context.strokeStyle = this.settings.strokeStyleOver;
piperImgIndex = 1;
}
break; break;
} }
case ScrollOverType.ACTIVE: case ScrollOverType.ACTIVE:
...@@ -1387,15 +2322,17 @@ ScrollObject.prototype = { ...@@ -1387,15 +2322,17 @@ ScrollObject.prototype = {
case ScrollOverType.NONE: case ScrollOverType.NONE:
default: default:
{ {
this.context.fillStyle = this.settings.scrollerColor;
this.context.strokeStyle = this.settings.strokeStyleNone;
piperImgIndex = 0;
if ( this.lastScrollerStatus == ScrollOverType.OVER ) { if ( this.lastScrollerStatus == ScrollOverType.OVER ) {
this.lastScrollerStatus = this.scrollerStatus; this.lastScrollerStatus = this.scrollerStatus;
this.startColorFadeInOutStart = this.startColorFadeInOutStart < 0 ? startColorFadeOut : this.startColorFadeInOutStart; this.startColorFadeInOutStart = this.startColorFadeInOutStart < 0 ? startColorFadeOut : this.startColorFadeInOutStart;
this.fadeOutActive = true; this.fadeOutActive = true;
fadeOut(); fadeOut();
} }
else{
this.context.fillStyle = this.settings.scrollerColor;
this.context.strokeStyle = this.settings.strokeStyleNone;
piperImgIndex = 0;
}
break; break;
} }
...@@ -1425,61 +2362,61 @@ ScrollObject.prototype = { ...@@ -1425,61 +2362,61 @@ ScrollObject.prototype = {
switch ( type ) { switch ( type ) {
case ArrowStatus.upLeftArrowHover_downRightArrowNonActive://upArrow mouse hover, downArrow stable case ArrowStatus.upLeftArrowHover_downRightArrowNonActive://upArrow mouse hover, downArrow stable
if ( ScrollOverType.OVER != this.ScrollOverType1 ) { if ( ScrollOverType.OVER != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_TOP, ScrollOverType.OVER, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_TOP, ScrollOverType.OVER, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.OVER; this.ScrollOverType1 = ScrollOverType.OVER;
} }
if ( ScrollOverType.STABLE != this.ScrollOverType2 ) { if ( ScrollOverType.STABLE != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_BOTTOM, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow( ScrollArrowType.ARROW_BOTTOM, ScrollOverType.STABLE, this.context, w, h );
this.ScrollOverType2 = ScrollOverType.STABLE; this.ScrollOverType2 = ScrollOverType.STABLE;
} }
break; break;
case ArrowStatus.upLeftArrowActive_downRightArrowNonActive://upArrow mouse down, downArrow stable case ArrowStatus.upLeftArrowActive_downRightArrowNonActive://upArrow mouse down, downArrow stable
if ( ScrollOverType.ACTIVE != this.ScrollOverType1 ) { if ( ScrollOverType.ACTIVE != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_TOP, ScrollOverType.ACTIVE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_TOP, ScrollOverType.ACTIVE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.ACTIVE; this.ScrollOverType1 = ScrollOverType.ACTIVE;
} }
if ( ScrollOverType.STABLE != this.ScrollOverType2 ) { if ( ScrollOverType.STABLE != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_BOTTOM, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_BOTTOM, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.STABLE; this.ScrollOverType2 = ScrollOverType.STABLE;
} }
break; break;
case ArrowStatus.upLeftArrowNonActive_downRightArrowHover://upArrow stable, downArrow mouse hover case ArrowStatus.upLeftArrowNonActive_downRightArrowHover://upArrow stable, downArrow mouse hover
if ( ScrollOverType.STABLE != this.ScrollOverType1 ) { if ( ScrollOverType.STABLE != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_TOP, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_TOP, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.STABLE; this.ScrollOverType1 = ScrollOverType.STABLE;
} }
if ( ScrollOverType.OVER != this.ScrollOverType2 ) { if ( ScrollOverType.OVER != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_BOTTOM, ScrollOverType.OVER, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_BOTTOM, ScrollOverType.OVER, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.OVER; this.ScrollOverType2 = ScrollOverType.OVER;
} }
break; break;
case ArrowStatus.upLeftArrowNonActive_downRightArrowActive://upArrow stable, downArrow mouse down case ArrowStatus.upLeftArrowNonActive_downRightArrowActive://upArrow stable, downArrow mouse down
if ( ScrollOverType.STABLE != this.ScrollOverType1 ) { if ( ScrollOverType.STABLE != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_TOP, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_TOP, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.STABLE; this.ScrollOverType1 = ScrollOverType.STABLE;
} }
if ( ScrollOverType.ACTIVE != this.ScrollOverType2 ) { if ( ScrollOverType.ACTIVE != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_BOTTOM, ScrollOverType.ACTIVE, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_BOTTOM, ScrollOverType.ACTIVE, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.ACTIVE; this.ScrollOverType2 = ScrollOverType.ACTIVE;
} }
break; break;
case ArrowStatus.arrowHover://upArrow stable, downArrow mouse down case ArrowStatus.arrowHover://upArrow stable, downArrow mouse down
if ( ScrollOverType.STABLE != this.ScrollOverType1 ) { if ( ScrollOverType.STABLE != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_TOP, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_TOP, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.STABLE; this.ScrollOverType1 = ScrollOverType.STABLE;
} }
if ( ScrollOverType.STABLE != this.ScrollOverType2 ) { if ( ScrollOverType.STABLE != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_BOTTOM, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_BOTTOM, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.STABLE; this.ScrollOverType2 = ScrollOverType.STABLE;
} }
break; break;
default ://upArrow stable, downArrow stable default ://upArrow stable, downArrow stable
if ( ScrollOverType.NONE != this.ScrollOverType1 ) { if ( ScrollOverType.NONE != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_TOP, ScrollOverType.NONE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_TOP, ScrollOverType.NONE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.NONE; this.ScrollOverType1 = ScrollOverType.NONE;
} }
if ( ScrollOverType.NONE != this.ScrollOverType2 ) { if ( ScrollOverType.NONE != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_BOTTOM, ScrollOverType.NONE, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_BOTTOM, ScrollOverType.NONE, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.NONE; this.ScrollOverType2 = ScrollOverType.NONE;
} }
break; break;
...@@ -1489,61 +2426,62 @@ ScrollObject.prototype = { ...@@ -1489,61 +2426,62 @@ ScrollObject.prototype = {
switch ( type ) { switch ( type ) {
case ArrowStatus.upLeftArrowHover_downRightArrowNonActive://leftArrow mouse hover, rightArrow stable case ArrowStatus.upLeftArrowHover_downRightArrowNonActive://leftArrow mouse hover, rightArrow stable
if ( ScrollOverType.OVER != this.ScrollOverType1 ) { if ( ScrollOverType.OVER != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_LEFT, ScrollOverType.OVER, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_LEFT, ScrollOverType.OVER, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.OVER; this.ScrollOverType1 = ScrollOverType.OVER;
} }
if ( ScrollOverType.STABLE != this.ScrollOverType2 ) { if ( ScrollOverType.STABLE != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_RIGHT, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_RIGHT, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.STABLE; this.ScrollOverType2 = ScrollOverType.STABLE;
} }
break; break;
case ArrowStatus.upLeftArrowActive_downRightArrowNonActive://leftArrow mouse down, rightArrow stable case ArrowStatus.upLeftArrowActive_downRightArrowNonActive://leftArrow mouse down, rightArrow stable
if ( ScrollOverType.ACTIVE != this.ScrollOverType1 ) { if ( ScrollOverType.ACTIVE != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_LEFT, ScrollOverType.ACTIVE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_LEFT, ScrollOverType.ACTIVE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.ACTIVE; this.ScrollOverType1 = ScrollOverType.ACTIVE;
} }
if ( ScrollOverType.STABLE != this.ScrollOverType2 ) { if ( ScrollOverType.STABLE != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_RIGHT, ScrollOverType.STABLE, this.context, w, h ); // this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_RIGHT, ScrollOverType.STABLE, this.context, w, h );
this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_RIGHT, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.STABLE; this.ScrollOverType2 = ScrollOverType.STABLE;
} }
break; break;
case ArrowStatus.upLeftArrowNonActive_downRightArrowHover://leftArrow stable, rightArrow mouse hover case ArrowStatus.upLeftArrowNonActive_downRightArrowHover://leftArrow stable, rightArrow mouse hover
if ( ScrollOverType.STABLE != this.ScrollOverType1 ) { if ( ScrollOverType.STABLE != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_LEFT, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_LEFT, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.STABLE; this.ScrollOverType1 = ScrollOverType.STABLE;
} }
if ( ScrollOverType.OVER != this.ScrollOverType2 ) { if ( ScrollOverType.OVER != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_RIGHT, ScrollOverType.OVER, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_RIGHT, ScrollOverType.OVER, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.OVER; this.ScrollOverType2 = ScrollOverType.OVER;
} }
break; break;
case ArrowStatus.upLeftArrowNonActive_downRightArrowActive://leftArrow stable, rightArrow mouse down case ArrowStatus.upLeftArrowNonActive_downRightArrowActive://leftArrow stable, rightArrow mouse down
if ( ScrollOverType.STABLE != this.ScrollOverType1 ) { if ( ScrollOverType.STABLE != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_LEFT, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_LEFT, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.STABLE; this.ScrollOverType1 = ScrollOverType.STABLE;
} }
if ( ScrollOverType.ACTIVE != this.ScrollOverType2 ) { if ( ScrollOverType.ACTIVE != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_RIGHT, ScrollOverType.ACTIVE, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_RIGHT, ScrollOverType.ACTIVE, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.ACTIVE; this.ScrollOverType2 = ScrollOverType.ACTIVE;
} }
break; break;
case ArrowStatus.arrowHover://upArrow stable, downArrow mouse down case ArrowStatus.arrowHover://upArrow stable, downArrow mouse down
if ( ScrollOverType.OVER != this.ScrollOverType1 ) { if ( ScrollOverType.OVER != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_LEFT, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_LEFT, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.STABLE; this.ScrollOverType1 = ScrollOverType.STABLE;
} }
if ( ScrollOverType.OVER != this.ScrollOverType2 ) { if ( ScrollOverType.OVER != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_RIGHT, ScrollOverType.STABLE, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_RIGHT, ScrollOverType.STABLE, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.STABLE; this.ScrollOverType2 = ScrollOverType.STABLE;
} }
break; break;
default ://leftArrow stable, rightArrow stable default ://leftArrow stable, rightArrow stable
if ( ScrollOverType.NONE != this.ScrollOverType1 ) { if ( ScrollOverType.NONE != this.ScrollOverType1 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_LEFT, ScrollOverType.NONE, this.context, w, h ); this.ArrowDrawer.drawTopLeftArrow(ScrollArrowType.ARROW_LEFT, ScrollOverType.NONE, this.context, w, h);
this.ScrollOverType1 = ScrollOverType.NONE; this.ScrollOverType1 = ScrollOverType.NONE;
} }
if ( ScrollOverType.NONE != this.ScrollOverType2 ) { if ( ScrollOverType.NONE != this.ScrollOverType2 ) {
this.ArrowDrawer.drawArrow( ScrollArrowType.ARROW_RIGHT, ScrollOverType.NONE, this.context, w, h ); this.ArrowDrawer.drawBottomRightArrow(ScrollArrowType.ARROW_RIGHT, ScrollOverType.NONE, this.context, w, h);
this.ScrollOverType2 = ScrollOverType.NONE; this.ScrollOverType2 = ScrollOverType.NONE;
} }
break; break;
...@@ -1719,28 +2657,24 @@ ScrollObject.prototype = { ...@@ -1719,28 +2657,24 @@ ScrollObject.prototype = {
if ( scrollerHover ) { if ( scrollerHover ) {
this.that.scrollerStatus = ScrollOverType.OVER; this.that.scrollerStatus = ScrollOverType.OVER;
// this.that._drawArrow( ArrowStatus.arrowHover );
arrowStat = ArrowStatus.arrowHover; arrowStat = ArrowStatus.arrowHover;
} }
else if ( this.that.settings.showArrows && (downHover || upHover) ) { else if ( this.that.settings.showArrows && (downHover || upHover) ) {
this.that.scrollerStatus = ScrollOverType.OVER; this.that.scrollerStatus = ScrollOverType.OVER;
if ( !this.that.mouseDownArrow ) { if ( !this.that.mouseDownArrow ) {
if ( upHover ) { if ( upHover ) {
// this.that._drawArrow( ArrowStatus.upLeftArrowHover_downRightArrowNonActive );
arrowStat = ArrowStatus.upLeftArrowHover_downRightArrowNonActive; arrowStat = ArrowStatus.upLeftArrowHover_downRightArrowNonActive;
} }
else if ( downHover ) { else if ( downHover ) {
// this.that._drawArrow( ArrowStatus.upLeftArrowNonActive_downRightArrowHover );
arrowStat = ArrowStatus.upLeftArrowNonActive_downRightArrowHover arrowStat = ArrowStatus.upLeftArrowNonActive_downRightArrowHover
} }
} }
} }
else { else {
if ( this.that.mouseover ) { if ( this.that.mouseover ) {
// this.that._drawArrow( ArrowStatus.arrowHover );
arrowStat = ArrowStatus.arrowHover; arrowStat = ArrowStatus.arrowHover;
} }
this.that.scrollerStatus = ScrollOverType.NONE; this.that.scrollerStatus = ScrollOverType.OVER;
} }
if ( this.that.mouseDown && this.that.scrollerMouseDown ) { if ( this.that.mouseDown && this.that.scrollerMouseDown ) {
this.that.moveble = true; this.that.moveble = true;
...@@ -1832,13 +2766,11 @@ ScrollObject.prototype = { ...@@ -1832,13 +2766,11 @@ ScrollObject.prototype = {
var evt = e || window.event; var evt = e || window.event;
// clearTimeout( this.that.fadeInTimeout );
if ( this.that.settings.showArrows ) { if ( this.that.settings.showArrows ) {
this.that.mouseDownArrow = false; this.that.mouseDownArrow = false;
this.that.handleEvents( "onmouseout", evt ); this.that.handleEvents( "onmouseout", evt );
} }
if ( !this.that.moveble ) { if ( !this.that.moveble ) {
this.that.scrollerStatus = ScrollOverType.NONE; this.that.scrollerStatus = ScrollOverType.NONE;
this.that._drawArrow(); this.that._drawArrow();
...@@ -1989,7 +2921,7 @@ ScrollObject.prototype = { ...@@ -1989,7 +2921,7 @@ ScrollObject.prototype = {
var _tmp = this, var _tmp = this,
direction = mousePos.x - this.that.scroller.x - this.that.scroller.w / 2, direction = mousePos.x - this.that.scroller.x - this.that.scroller.w / 2,
step = this.that.paneWidth * this.that.settings.scrollPagePercent, step = this.that.paneWidth * this.that.settings.scrollPagePercent,
horizontalDragPosition = this.that.scroller.x, // horizontalDragPosition = this.that.scroller.x,
isFirst = true, isFirst = true,
doScroll = function () { doScroll = function () {
_tmp.that.lock = true; _tmp.that.lock = true;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment