Показать сообщение отдельно

  #5  
Старый 21.03.2010, 21:06
Gifts
Reservists Of Antichat - Level 6
Регистрация: 25.04.2008
Сообщений: 827
С нами: 9497186

Репутация: 1304


По умолчанию

draliokero Изображение мы должны изменять только после завершения итерации. Из-за того что мы насилуем imageGD постоянно - код получается очень медленным, по хорошему - лучше при бинаризации создавать двумерный массив, а потом уже раскрашивать обратно. Работающий код, без оптимизации:

PHP код:
<?php

set_time_limit
(0);


$im imagecreatefrompng("skeleton.png");
$width imagesx($im);
$height imagesy($im);
for (
$y 0$y $height$y++) {
    for (
$x 0$x $width$x++) {
        if (
imagecolorat($im$x $y) <= 0x7FFFFFimagesetpixel($im$x$y0x000000);
        else 
imagesetpixel($im$x$y0xFFFFFF);
    } 

// Функция скелетонизации бинарного изображения
function zhang_suen_thinning_iteration($condition_switch)
{
    global 
$width$height$im;
    
    
$im2 imagecreatetruecolor($width$height);
    
    
$running false;
    for(
$y 1$y $height 1$y++) {
        for(
$x 1$x $width 1$x++) {
            
$p1 imagecolorat($im$x$y) > 0;
        
            if (
$p1 0) {
            
imagesetpixel($im2,$x,$y,0xFFFFFF);
                
$p2 imagecolorat($im$x$y 1) > 0;
                
$p3 imagecolorat($im$x 1$y 1) > 0;
                
$p4 imagecolorat($im$x 1$y) > 0;
                
$p5 imagecolorat($im$x 1$y 1) > 0;
                
$p6 imagecolorat($im$x$y 1) > 0;
                
$p7 imagecolorat($im$x 1$y 1) > 0;
                
$p8 imagecolorat($im$x 1$y) > 0;
                
$p9 imagecolorat($im$x 1$y 1) > 0;
                
$connectivity =
                (
$p2 == && $p3 == 0) +
                (
$p3 == && $p4 == 0) +
                (
$p4 == && $p5 == 0) +
                (
$p5 == && $p6 == 0) +
                (
$p6 == && $p7 == 0) +
                (
$p7 == && $p8 == 0) +
                (
$p8 == && $p9 == 0) +
                (
$p9 == && $p2 == 0);
                
$non_zero_neighbors $p2 $p3 $p4 $p5 $p6 $p7 $p8 $p9;

                if (
<= $non_zero_neighbors && $non_zero_neighbors <= && $connectivity == 1) {
                    if (
$condition_switch == true) {
                        if ((
$p2 $p4 $p6 == 0) && ($p4 $p6 $p8 == 0)) {
                            
imagesetpixel($im2$x$y0x000000);
                            
$running true;
                        } 
                    } else {
                        if ((
$p2 $p4 $p8 == 0) && ($p2 $p6 $p8 == 0)) {
                            
imagesetpixel($im2$x$y0x000000);
                            
$running true;
                        } 
                    } 
                } 
            } else 
imagesetpixel($im2$x$y0x000000);
        } 
    } 
    
imagecopy($im,$im2,0,0,0,0,$width,$height);
    return 
$running;

$flag true;$count 0;

//zhang_suen_thinning_iteration($im, $flag);
while (zhang_suen_thinning_iteration($im$flag = !$flag) && $count++ < 60) {}

header('Content-type: image/png');
imagepng($im);
За 60 итераций получаем такое изображение из левой верхней картинки первого поста (С увеличением чиасла итераций треугольник конечно пропадет, но достаточно не быстро):


З.Ы. получить ЧБ изображение можно через среднее арифметическое трех каналов цветного (что, кстати, и будет яркостью пиксела)
__________________
Любая действущая программа устарела.
Создайте систему, которой сможет пользоваться даже дурак ,и только дурак захочет ею пользоваться.
Как правильно задавать вопросы: _http://www.yakimchuk.ru/questions.htm

Последний раз редактировалось Gifts; 21.03.2010 в 21:12..
 
Ответить с цитированием