Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più
Dreame X60 Pro Ultra Complete implementa due bracci estensibili, per spazzola e moccio, che si spingono ben oltre quanto visto sino ad oggi permettendo una pulizia di casa ancor più capillare e precisa
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati
La tecnologia SQD-Mini LED di TCL arriva sul taglio da 65 pollici con la serie C8L: 2040 zone, pannello WHVA 2.0 e un picco che alle rilevazioni delle sonde tocca i 4400 nit nel profilo Filmmaker e un HDR quasi perfetto
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro
Wireless 2.4 GHz, Bluetooth 5.4, cancellazione attiva del rumore, design pieghevole e un'autonomia che mette in imbarazzo prodotti che costano il doppio. Le Maestro 500 non eccellono in nulla, ma offrono tutto. E a questo prezzo è difficile chiedere di più
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 18-02-2009, 12: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, 12: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, 12: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, 13: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, 19: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, 20: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, 20: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, 00: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, 07: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, 10: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


Dreame X60 Pro Ultra Complete: i bracci si estendono sempre di più Dreame X60 Pro Ultra Complete: i bracci si esten...
TCL 65C8L, la recensione del SQD-Mini LED da 4400 nit misurati TCL 65C8L, la recensione del SQD-Mini LED da 440...
MSI Maestro 500 Wireless: ANC e 90 ore di autonomia a 70 euro MSI Maestro 500 Wireless: ANC e 90 ore di autono...
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
Samsung Galaxy S27, il compatto potrebbe...
Sempre più IA nei videogiochi: con PUBG ...
La NASA avrebbe fermato i lavori sul mod...
Mancano pochi giorni al lancio della mis...
Prime Day in anticipo, giorno 7: tempo d...
Lo smartphone HONOR con batteria da 11.0...
Amazfit Bip 5, Active 3 Premium e Balanc...
Xiaomi potrebbe portare i suoi Pro e Pro...
Crisi delle memorie: CMF annulla il pros...
La PS6 si farà attendere: il lanc...
OnePlus non sente la crisi delle memorie...
I futuri iPhone 18 Pro potrebbero costar...
Bosch eBike Systems MY2027: a sorpresa a...
Amazon, le top 5 offerte del weekend per...
Sesto giorno di Prime Day anticipato Ama...
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:01.


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