Ver Mensaje Individual
  #20 (permalink)  
Antiguo 27/12/2011, 14:41
edie8
 
Fecha de Ingreso: noviembre-2011
Mensajes: 516
Antigüedad: 13 años
Puntos: 10
Respuesta: codigo pho en javascript

parte 2
Código PHP:
function _resize_container_image_box(intImageWidth,intImageHeight) {
            
// Get current width and height
            
var intCurrentWidth = $('#lightbox-container-image-box').width();
            var 
intCurrentHeight = $('#lightbox-container-image-box').height();
            
// Get the width and height of the selected image plus the padding
            
var intWidth = (intImageWidth + (settings.containerBorderSize 2)); // Plus the image´s width and the left and right padding value
            
var intHeight = (intImageHeight + (settings.containerBorderSize 2)); // Plus the image´s height and the left and right padding value
            // Diferences
            
var intDiffW intCurrentWidth intWidth;
            var 
intDiffH intCurrentHeight intHeight;
            
// Perfomance the effect
            
$('#lightbox-container-image-box').animate({ widthintWidthheightintHeight },settings.containerResizeSpeed,function() { _show_image(); });
            if ( ( 
intDiffW == ) && ( intDiffH == ) ) {
                if ( $.
browser.msie ) {
                    
___pause(250);
                } else {
                    
___pause(100);    
                }
            } 
            $(
'#lightbox-container-image-data-box').css({ widthintImageWidth });
            $(
'#lightbox-nav-btnPrev,#lightbox-nav-btnNext').css({ heightintImageHeight + (settings.containerBorderSize 2) });
        };
        
/**
         * Show the prepared image
         *
         */
        
function _show_image() {
            $(
'#lightbox-loading').hide();
            $(
'#lightbox-image').fadeIn(function() {
                
_show_image_data();
                
_set_navigation();
            });
            
_preload_neighbor_images();
        };
        
/**
         * Show the image information
         *
         */
        
function _show_image_data() {
            $(
'#lightbox-container-image-data-box').slideDown('fast');
            $(
'#lightbox-image-details-caption').hide();
            if ( 
settings.imageArray[settings.activeImage][1] ) {
                $(
'#lightbox-image-details-caption').html(settings.imageArray[settings.activeImage][1]).show();
            }
            
// If we have a image set, display 'Image X of X'
            
if ( settings.imageArray.length ) {
                $(
'#lightbox-image-details-currentNumber').html(settings.txtImage ' ' + ( settings.activeImage ) + ' ' settings.txtOf ' ' settings.imageArray.length).show();
            }        
        }
        
/**
         * Display the button navigations
         *
         */
        
function _set_navigation() {
            $(
'#lightbox-nav').show();

            
// Instead to define this configuration in CSS file, we define here. And it´s need to IE. Just.
            
$('#lightbox-nav-btnPrev,#lightbox-nav-btnNext').css({ 'background' 'transparent url(' settings.imageBlank ') no-repeat' });
            
            
// Show the prev button, if not the first image in set
            
if ( settings.activeImage != ) {
                if ( 
settings.fixedNavigation ) {
                    $(
'#lightbox-nav-btnPrev').css({ 'background' 'url(' settings.imageBtnPrev ') left 15% no-repeat' })
                        .
unbind()
                        .
bind('click',function() {
                            
settings.activeImage settings.activeImage 1;
                            
_set_image_to_view();
                            return 
false;
                        });
                } else {
                    
// Show the images button for Next buttons
                    
$('#lightbox-nav-btnPrev').unbind().hover(function() {
                        $(
this).css({ 'background' 'url(' settings.imageBtnPrev ') left 15% no-repeat' });
                    },function() {
                        $(
this).css({ 'background' 'transparent url(' settings.imageBlank ') no-repeat' });
                    }).
show().bind('click',function() {
                        
settings.activeImage settings.activeImage 1;
                        
_set_image_to_view();
                        return 
false;
                    });
                }
            }
            
            
// Show the next button, if not the last image in set
            
if ( settings.activeImage != ( settings.imageArray.length -) ) {
                if ( 
settings.fixedNavigation ) {
                    $(
'#lightbox-nav-btnNext').css({ 'background' 'url(' settings.imageBtnNext ') right 15% no-repeat' })
                        .
unbind()
                        .
bind('click',function() {
                            
settings.activeImage settings.activeImage 1;
                            
_set_image_to_view();
                            return 
false;
                        });
                } else {
                    
// Show the images button for Next buttons
                    
$('#lightbox-nav-btnNext').unbind().hover(function() {
                        $(
this).css({ 'background' 'url(' settings.imageBtnNext ') right 15% no-repeat' });
                    },function() {
                        $(
this).css({ 'background' 'transparent url(' settings.imageBlank ') no-repeat' });
                    }).
show().bind('click',function() {
                        
settings.activeImage settings.activeImage 1;
                        
_set_image_to_view();
                        return 
false;
                    });
                }
            }
            
// Enable keyboard navigation
            
_enable_keyboard_navigation();
        }
        
/**
         * Enable a support to keyboard navigation
         *
         */
        
function _enable_keyboard_navigation() {
            $(
document).keydown(function(objEvent) {
                
_keyboard_action(objEvent);
            });
        }
        
/**
         * Disable the support to keyboard navigation
         *
         */
        
function _disable_keyboard_navigation() {
            $(
document).unbind();
        }
        
/**
         * Perform the keyboard actions
         *
         */
        
function _keyboard_action(objEvent) {
            
// To ie
            
if ( objEvent == null ) {
                
keycode event.keyCode;
                
escapeKey 27;
            
// To Mozilla
            
} else {
                
keycode objEvent.keyCode;
                
escapeKey objEvent.DOM_VK_ESCAPE;
            }
            
// Get the key in lower case form
            
key String.fromCharCode(keycode).toLowerCase();
            
// Verify the keys to close the ligthBox
            
if ( ( key == settings.keyToClose ) || ( key == 'x' ) || ( keycode == escapeKey ) ) {
                
_finish();
            }
            
// Verify the key to show the previous image
            
if ( ( key == settings.keyToPrev ) || ( keycode == 37 ) ) {
                
// If we´re not showing the first image, call the previous
                
if ( settings.activeImage != ) {
                    
settings.activeImage settings.activeImage 1;
                    
_set_image_to_view();
                    
_disable_keyboard_navigation();
                }
            }
            
// Verify the key to show the next image
            
if ( ( key == settings.keyToNext ) || ( keycode == 39 ) ) {
                
// If we´re not showing the last image, call the next
                
if ( settings.activeImage != ( settings.imageArray.length ) ) {
                    
settings.activeImage settings.activeImage 1;
                    
_set_image_to_view();
                    
_disable_keyboard_navigation();
                }
            }
        }
        
/**
         * Preload prev and next images being showed
         *
         */
        
function _preload_neighbor_images() {
            if ( (
settings.imageArray.length -1) > settings.activeImage ) {
                
objNext = new Image();
                
objNext.src settings.imageArray[settings.activeImage 1][0];
            }
            if ( 
settings.activeImage ) {
                
objPrev = new Image();
                
objPrev.src settings.imageArray[settings.activeImage -1][0];
            }
        }
        
/**
         * Remove jQuery lightBox plugin HTML markup
         *
         */
        
function _finish() {
            $(
'#jquery-lightbox').remove();
            $(
'#jquery-overlay').fadeOut(function() { $('#jquery-overlay').remove(); });
            
// Show some elements to avoid conflict with overlay in IE. These elements appear above the overlay.
            
$('embed, object, select').css({ 'visibility' 'visible' });
        }
        
/**
         / THIRD FUNCTION
         * getPageSize() by quirksmode.com
         *
         * @return Array Return an array with page width, height and window width, height
         */
        
function ___getPageSize() {
            var 
xScrollyScroll;
            if (
window.innerHeight && window.scrollMaxY) {    
                
xScroll window.innerWidth window.scrollMaxX;
                
yScroll window.innerHeight window.scrollMaxY;
            } else if (
document.body.scrollHeight document.body.offsetHeight){ // all but Explorer Mac
                
xScroll document.body.scrollWidth;
                
yScroll document.body.scrollHeight;
            } else { 
// Explorer Mac...would also work in Explorer 6 Strict, Mozilla and Safari
                
xScroll document.body.offsetWidth;
                
yScroll document.body.offsetHeight;
            }
            var 
windowWidthwindowHeight;
            if (
self.innerHeight) {    // all except Explorer
                
if(document.documentElement.clientWidth){
                    
windowWidth document.documentElement.clientWidth
                } else {
                    
windowWidth self.innerWidth;
                }
                
windowHeight self.innerHeight;
            } else if (
document.documentElement && document.documentElement.clientHeight) { // Explorer 6 Strict Mode
                
windowWidth document.documentElement.clientWidth;
                
windowHeight document.documentElement.clientHeight;
            } else if (
document.body) { // other Explorers
                
windowWidth document.body.clientWidth;
                
windowHeight document.body.clientHeight;
            }    
            
// for small pages with total height less then height of the viewport
            
if(yScroll windowHeight){
                
pageHeight windowHeight;
            } else { 
                
pageHeight yScroll;
            }
            
// for small pages with total width less then width of the viewport
            
if(xScroll windowWidth){    
                
pageWidth xScroll;        
            } else {
                
pageWidth windowWidth;
            }
            
arrayPageSize = new Array(pageWidth,pageHeight,windowWidth,windowHeight);
            return 
arrayPageSize;
        };
        
/**
         / THIRD FUNCTION
         * getPageScroll() by quirksmode.com
         *
         * @return Array Return an array with x,y page scroll values.
         */
        
function ___getPageScroll() {
            var 
xScrollyScroll;
            if (
self.pageYOffset) {
                
yScroll self.pageYOffset;
                
xScroll self.pageXOffset;
            } else if (
document.documentElement && document.documentElement.scrollTop) {     // Explorer 6 Strict
                
yScroll document.documentElement.scrollTop;
                
xScroll document.documentElement.scrollLeft;
            } else if (
document.body) {// all other Explorers
                
yScroll document.body.scrollTop;
                
xScroll document.body.scrollLeft;    
            }
            
arrayPageScroll = new Array(xScroll,yScroll);
            return 
arrayPageScroll;
        };
         
/**
          * Stop the code execution from a escified time in milisecond
          *
          */
         
function ___pause(ms) {
            var 
date = new Date(); 
            
curDate null;
            do { var 
curDate = new Date(); }
            while ( 
curDate date ms);
         };
        
// Return the jQuery object for chaining. The unbind method is used to avoid click conflict when the plugin is called more than once
        
return this.unbind('click').click(_initialize);
    };
    var 
objeto="hola";
})(
jQuery); // Call and execute the function immediately passing the jQuery object