Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti
La facilità di installazione e la completa automazione di tutte le fasi di utilizzo, rendono questo prodotto l'ideale per molti clienti. Ecco com'è andata la nostra prova in anteprima
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-02-2009, 13:45   #1
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
[C] Ingrandimento immagine, dove si blocca il programma??

Ciao a tutti
sto cercando di fare un programma che,da linea di comando riceve il nome di un immagine, e un numero intero N, e ne ingrandisce le dimensioni di N volte. Fin qui il programma funziona, ma adesso devo aggiungere un pezzo in modo tale da ridurre la quadrettatura, facendo una media per ogni pixel dei pixel adiancenti.
Questo è il programma che ho scritto:
Codice:
#include<stdio.h>
#include<stdlib.h>

#include"bmp.h"

void  ingrandisci(BITMAP bmpout,BITMAP bmpin,int N);
void  riduci_quadrettatura(BITMAP bmpout,int N);
double  calcola_media(BITMAP bmpout,int i,int j,int N,char colore);


int main(int argc, char *argv[])
{   BITMAP bmpin,bmpout;
    FILE *fpin,*fpout;
    int N;

    if (argc != 3)
    {   printf("Scrivere su linea di comando:
                nome immagine ingresso
                numero intero che rappresenta l'ingrandimento");
        exit (EXIT_FAILURE);
    }

    if((fpin=fopen(argv[1],"rb"))==NULL)
    {   printf("Errore apertura file ingresso");
        exit (EXIT_FAILURE);
    }

    if((fpout=fopen("ingrandita.bmp","wb"))==NULL)
    {   printf("Errore apertura file d'uscita");
        exit (EXIT_FAILURE);
    }
    bmpin=ReadBitmap(fpin);
    fclose(fpin);
    bmpout=CreateEmptyBitmap(bmpin.height*atoi(argv[2]),bmpin.width*atoi(argv[2]));

    
    ingrandisci(bmpout,bmpin,atoi(argv[2]));

    printf("Sono qui");
    riduci_quadrettatura(bmpout,atoi(argv[2]));
    
    WriteBitmap(bmpout,fpout);
    fclose(fpout);

    ReleaseBitmapData(&bmpin);
    ReleaseBitmapData(&bmpout);


    return EXIT_SUCCESS;

}


void  ingrandisci(BITMAP bmpout,BITMAP bmpin,int N)
{   int i,j,c=0,k,I,J;
    
  
    
    for(i=0; i<bmpin.height; i++)
    {   for(j=0; j<bmpin.width; j++)
        {  
           for(k=i*N; k<=i*N+N-1; k++)
           {             
               for(c=j*N; c<=j*N+N-1; c++)
               {   PIXEL(bmpout,k,c)=PIXEL(bmpin,i,j);
                   
               } 

            } 

         }
         
     } 
    
    return;

}


void  riduci_quadrettatura(BITMAP bmpout,int N)
{   int i,j;
    
    
    for(i=1; i<bmpout.height-1; i++)
    {   
        for(j=1; j<bmpout.width-1; j++)
        {    PIXEL(bmpout,i,j).red=calcola_media(bmpout,i,j,N,'r');
             PIXEL(bmpout,i,j).green=calcola_media(bmpout,i,j,N,'g');
             PIXEL(bmpout,i,j).blue=calcola_media(bmpout,i,j,N,'b');

        }
    } 

    return;
}

double calcola_media(BITMAP bmpout,int i,int j,int N,char colore)
{   double somma_rosso=0,somma_verde=0, somma_blu=0;
    int c,k;
    
    for(c=i; c<=i*N+N-1; i++)
    {
        for( k=j; k<= j*N+N-1; j++)
        {
            somma_rosso+=PIXEL(bmpout,c,k).red;
            somma_verde+=PIXEL(bmpout,c,k).green;
            somma_blu+=PIXEL(bmpout,c,k).blue;
        }
    }

    if (colore == 'r')
            return    (double)somma_rosso/(N*N);

    if (colore == 'g')
            return    (double)somma_verde/(N*N);

    if (colore == 'b')
            return    (double)somma_blu/(N*N);

    
}
Non riesco a capire perchè il programma entri in un ciclo infinito
Allora, se io tolgo tutta la parte della quadrettatura il programma funziona, se io invece l'aggiungo, non mi scrive neanche quel "Sono qui" nel main, un printf che ho aggiunto per cercare di vedere dove il programma si bloccava. Ma come fa a non arrivare a quel punto se la funzione ingrandisci funziona??
Grazie a tutti
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 13:52   #2
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
for( k=j; k<= j*N+N-1; j++)

Non sarebbe meglio k++?
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 13:53   #3
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
si si già modificato era la versione vecchia questa, anche il c sopra
non va comunque
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 14:08   #4
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
Inoltre come è possibile che una parte una funzione venga correttamente completata, e dopo, con l'aggiunta di un altro pezzo di programma, che non la utilizza, non arriva allo stesso punto di prima???
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 20:57   #5
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
Aiuto nessuno???
Non riesco proprio a capire dove sbaglio
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 21:18   #6
Kenger
Member
 
Iscritto dal: Aug 2005
Messaggi: 168
Se non posti anche bmp.h difficilmente qualcuno avrà voglia di guardare del codice non eseguibile. ^^
Kenger è offline   Rispondi citando il messaggio o parte di esso
Old 18-02-2009, 21:26   #7
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
si allora qui:
http://web.diegm.uniud.it/pierluca/p...magini/bmplib/
ci sono le librerie fatte dal mio professore.
Però non riesco a capire perchè se tolgo la parte di riduci_quadrettatura il programma funziona correttamente, mentre se aggiungo, non stampa a video il printf Sono qui, che sta immediatamente dopo alla funzione ingrandisci
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2009, 01:56   #8
eliano
Senior Member
 
L'Avatar di eliano
 
Iscritto dal: Mar 2002
Città: Capua (CE)
Messaggi: 317
Quote:
Originariamente inviato da MinaVagante Guarda i messaggi
Ciao a tutti
sto cercando di fare un programma che,da linea di comando riceve il nome di un immagine, e un numero intero N, e ne ingrandisce le dimensioni di N volte. Fin qui il programma funziona, ma adesso devo aggiungere un pezzo in modo tale da ridurre la quadrettatura, facendo una media per ogni pixel dei pixel adiancenti.
Questo è il programma che ho scritto:
Codice:
#include<stdio.h>
#include<stdlib.h>

#include"bmp.h"

void  ingrandisci(BITMAP bmpout,BITMAP bmpin,int N);
void  riduci_quadrettatura(BITMAP bmpout,int N);
double  calcola_media(BITMAP bmpout,int i,int j,int N,char colore);


int main(int argc, char *argv[])
{   BITMAP bmpin,bmpout;
    FILE *fpin,*fpout;
    int N;

    if (argc != 3)
    {   printf("Scrivere su linea di comando:
                nome immagine ingresso
                numero intero che rappresenta l'ingrandimento");
        exit (EXIT_FAILURE);
    }

    if((fpin=fopen(argv[1],"rb"))==NULL)
    {   printf("Errore apertura file ingresso");
        exit (EXIT_FAILURE);
    }

    if((fpout=fopen("ingrandita.bmp","wb"))==NULL)
    {   printf("Errore apertura file d'uscita");
        exit (EXIT_FAILURE);
    }
    bmpin=ReadBitmap(fpin);
    fclose(fpin);
    bmpout=CreateEmptyBitmap(bmpin.height*atoi(argv[2]),bmpin.width*atoi(argv[2]));

    
    ingrandisci(bmpout,bmpin,atoi(argv[2]));

    printf("Sono qui");
    riduci_quadrettatura(bmpout,atoi(argv[2]));
    
    WriteBitmap(bmpout,fpout);
    fclose(fpout);

    ReleaseBitmapData(&bmpin);
    ReleaseBitmapData(&bmpout);


    return EXIT_SUCCESS;

}


void  ingrandisci(BITMAP bmpout,BITMAP bmpin,int N)
{   int i,j,c=0,k,I,J;
    
  
    
    for(i=0; i<bmpin.height; i++)
    {   for(j=0; j<bmpin.width; j++)
        {  
           for(k=i*N; k<=i*N+N-1; k++)
           {             
               for(c=j*N; c<=j*N+N-1; c++)
               {   PIXEL(bmpout,k,c)=PIXEL(bmpin,i,j);
                   
               } 

            } 

         }
         
     } 
    
    return;

}


void  riduci_quadrettatura(BITMAP bmpout,int N)
{   int i,j;
    
    
    for(i=1; i<bmpout.height-1; i++)
    {   
        for(j=1; j<bmpout.width-1; j++)
        {    PIXEL(bmpout,i,j)->red=calcola_media(bmpout,i,j,N,'r');
             PIXEL(bmpout,i,j)->green=calcola_media(bmpout,i,j,N,'g');
             PIXEL(bmpout,i,j)->blue=calcola_media(bmpout,i,j,N,'b');

        }
    } 

    return;
}

double calcola_media(BITMAP bmpout,int i,int j,int N,char colore)
{   double somma_rosso=0,somma_verde=0, somma_blu=0;
    int c,k;
    
    for(c=i; c<=i*N+N-1; i++)
    {
        for( k=j; k<= j*N+N-1; j++)
        {
            somma_rosso+=PIXEL(bmpout,c,k).red;
            somma_verde+=PIXEL(bmpout,c,k).green;
            somma_blu+=PIXEL(bmpout,c,k).blue;
        }
    }

    if (colore == 'r')
            return    (double)somma_rosso/(N*N);

    if (colore == 'g')
            return    (double)somma_verde/(N*N);

    if (colore == 'b')
            return    (double)somma_blu/(N*N);

    
}
Non riesco a capire perchè il programma entri in un ciclo infinito
Allora, se io tolgo tutta la parte della quadrettatura il programma funziona, se io invece l'aggiungo, non mi scrive neanche quel "Sono qui" nel main, un printf che ho aggiunto per cercare di vedere dove il programma si bloccava. Ma come fa a non arrivare a quel punto se la funzione ingrandisci funziona??
Grazie a tutti
E' possibile che mi sbagli, data l'ora tarda, ma credo che per accedere alle tre componenti diel colore tu debba usare l'indirezione: infatti la dichiarazione di BITMAP è
Codice:
typedef struct tagBITMAP
{
   dword width;
   dword height;
   COLORTRIPLE *pixel;
   FILEHEADER fileheader;
   BMPHEADER bmpheader;
} BITMAP;
__________________
Se pensi di sapere, sappi che non sai di non saperlo!
Le mie statistiche - "real man uses Duron!"
Ho fatto affari con: schumyFast, navale, The_Nameless_One, Sonic80, diamante.picci, Downset88, ilviandante, tecno789
eliano è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2009, 08:57   #9
MinaVagante
Senior Member
 
Iscritto dal: Sep 2007
Messaggi: 351
Intendi che non devo scrivere:
PIXEL(bmpout,i,j).red=PIXEL(bmpin,i,j).red
ad esempio???
Perchè ho fatto altri programmi in cui assegnavo il valore per ciascun colore e tutto funziona, come questo ad esempio in cui dovevo modificare la luminosità:
Codice:
#include<stdio.h>
#include<stdlib.h>

#include "bmp.h"

BITMAP modifica_luminosita(BITMAP bmpin,float k);


int main(int argc, char *argv[])
{   float k;
    BITMAP bmpin,bmpout;
    FILE *fpin,*fpout;

    if(argc != 3)
    {   printf("Scrivere sulla linea di comando:
                nome file ingresso
                numeroreale (fattore di cambiamento luminosti…)");
        exit (EXIT_FAILURE);
    }

    if((fpin=fopen(argv[1],"rb"))==NULL)
    {   printf("Errore apertura file d'ingresso.");
        exit (EXIT_FAILURE);
    }

    if((fpout=fopen("Luminosit…_modificata.bmp","wb"))==NULL)
    {   printf("Errore nell'apertura file d'uscita");
        exit (EXIT_FAILURE);
    }

    k=atof(argv[2]);
    bmpin=ReadBitmap(fpin);

    bmpout=modifica_luminosita(bmpin,k);

    WriteBitmap(bmpout,fpout);

    ReleaseBitmapData(&bmpin);
    ReleaseBitmapData(&bmpout);

    fclose(fpin);
    fclose(fpout);

    return EXIT_SUCCESS;

}


BITMAP modifica_luminosita(BITMAP bmpin,float k)
{   int i,j;
    BITMAP bmpout;
    COLORTRIPLE white={255,255,255};

    bmpout=CreateEmptyBitmap(bmpin.height,bmpin.width);

    for(i=0; i<bmpin.height; i++)
    {   for(j=0; j<bmpin.width; j++)
        {  if ( (PIXEL(bmpout,i,j).red=PIXEL(bmpin,i,j).red * k/100 > 255)||
                (PIXEL(bmpout,i,j).green=PIXEL(bmpin,i,j).green * k/100 >255)||
                (PIXEL(bmpout,i,j).blue=PIXEL(bmpin,i,j).blue * k/100 > 255))
           {   PIXEL(bmpout,i,j)=white;
           }
           else
           {   PIXEL(bmpout,i,j).red=PIXEL(bmpin,i,j).red *k/100;
               PIXEL(bmpout,i,j).green=PIXEL(bmpin,i,j).green * k/100;
               PIXEL(bmpout,i,j).blue=PIXEL(bmpin,i,j).blue * k/100;
           }
        }
    }
    return bmpout;

}
MinaVagante è offline   Rispondi citando il messaggio o parte di esso
Old 19-02-2009, 11:39   #10
eliano
Senior Member
 
L'Avatar di eliano
 
Iscritto dal: Mar 2002
Città: Capua (CE)
Messaggi: 317
Oops!

Scusami, errore mio: avevo interpretato male la struttura.
__________________
Se pensi di sapere, sappi che non sai di non saperlo!
Le mie statistiche - "real man uses Duron!"
Ho fatto affari con: schumyFast, navale, The_Nameless_One, Sonic80, diamante.picci, Downset88, ilviandante, tecno789
eliano è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
Windows domina su Steam, ma molti utenti...
Per non incorrere in nuovi aumenti delle...
Cubi Z AI 8M visto da vicino, un mini-PC...
Datacenter nello Spazio, affascinante ma...
Social e minori, Butti apre al dibattito...
Tutte le offerte Amazon del weekend, sol...
Amazon spinge sull'usato garantito: 10% ...
TikTok rischia una maxi-multa in Europa:...
Bose su Amazon: QuietComfort SC over ear...
Scope elettriche super accessoriate in o...
Umidità e muffa addio: questo deu...
DREAME Aqua10 Ultra Roller a 999€ &egrav...
500.000 kit gratis consegnati: Noctua fa...
Il MIT sperimenta il calcolo termico: op...
Sembra ormai certo: la prossima Xbox sar...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 16:11.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v