Вход Регистрация
Файл: xmyx.ru/sys/inc/MultiWave.php
Строк: 43
<?
function MultiWave($img)
{
    
$width=imagesx($img);
    
$height=imagesy($img);

    
$img2=imagecreatetruecolor($width$height);

    
$rand1 mt_rand(7000001000000) / 15000000;
    
$rand2 mt_rand(7000001000000) / 15000000;
    
$rand3 mt_rand(7000001000000) / 15000000;
    
$rand4 mt_rand(7000001000000) / 15000000;

    
// фазы
    
$rand5 mt_rand(03141592) / 1000000;
    
$rand6 mt_rand(03141592) / 1000000;
    
$rand7 mt_rand(03141592) / 1000000;
    
$rand8 mt_rand(03141592) / 1000000;

    
// амплитуды
    
$rand9 mt_rand(400600) / 100;
    
$rand10 mt_rand(400600) / 100;

    for(
$x 0$x $width$x++){
      for(
$y 0$y $height$y++){
        
// координаты пикселя-первообраза.
        
$sx $x + ( sin($x $rand1 $rand5) + sin($y $rand3 $rand6) ) * $rand9;
        
$sy $y + ( sin($x $rand2 $rand7) + sin($y $rand4 $rand8) ) * $rand10;

        
// первообраз за пределами изображения
        
if($sx || $sy || $sx >= $width || $sy >= $height 1){
          
$color 255;
          
$color_x 255;
          
$color_y 255;
          
$color_xy 255;
        }else{ 
// цвета основного пикселя и его 3-х соседей для лучшего антиалиасинга
          
$color = (imagecolorat($img$sx$sy) >> 16) & 0xFF;
          
$color_x = (imagecolorat($img$sx 1$sy) >> 16) & 0xFF;
          
$color_y = (imagecolorat($img$sx$sy 1) >> 16) & 0xFF;
          
$color_xy = (imagecolorat($img$sx 1$sy 1) >> 16) & 0xFF;
        }    
// сглаживаем только точки, цвета соседей которых отличается
        
if($color == $color_x && $color == $color_y && $color == $color_xy){
          
$newcolor=$color;
        }else{
          
$frsx $sx floor($sx); //отклонение координат первообраза от целого
          
$frsy $sy floor($sy);
          
$frsx1 $frsx;
          
$frsy1 $frsy;

          
// вычисление цвета нового пикселя как пропорции от цвета основного пикселя и его соседей
          
$newcolor floor$color    $frsx1 $frsy1 +
                             
$color_x  $frsx  $frsy1 +
                             
$color_y  $frsx1 $frsy  +
                             
$color_xy $frsx  $frsy );
        }
        
imagesetpixel($img2$x$yimagecolorallocate($img2$newcolor$newcolor$newcolor));
      }
    }
    return 
$img2;
}
?>
Онлайн: 0
Реклама