查看完整版本: 请教各位关于程序改写的问题

cfanfan 2006-1-27 04:13

请教各位关于程序改写的问题

请教各位朋友,我这里的程序想改写,main函数中的东西想通过class方法实现,可是我费劲想了很久还是没有好的思路,所以请教大家帮助,感谢!
#include <iostream>
#include <fstream>
#include <string>

using namespace std;

/*** New Data Types ***/
typedef unsigned char BYTE;

int main(int argc, char* argv[])
/**************************************************************************************************
Arguments:
        argv[1]: input file name
        argv[2]: output file name
**************************************************************************************************/
{
        ifstream infile;                                /* input file */
        ofstream outfile_R;
        ofstream outfile_G;                                /* output files */
        ofstream outfile_B;       
        char inFileName[128];                        /* input file name */
        char outFileName_R[128];
        char outFileName_G[128];                /* output file name */
        char outFileName_B[128];
        int width;                                                /* width of input source */
        int height;                                                /* height of input source */
        int Npixels, maxValue, i;
        BYTE *pRGB;
        BYTE *pR, *pG, *pB;
        char buf[16];
        int bufIndex;

        // read the arguments  
        if(argc == 5)
        {
                strcpy(inFileName, argv[1]);
                strcpy(outFileName_R, argv[2]);
                strcpy(outFileName_G, argv[3]);
                strcpy(outFileName_B, argv[4]);
        }
        else
        {
                cout<<"PPM(p6) converts to PGM(p5)
";
                cout<<"input Filename: ";
                cin>>inFileName;
                cout<<"Output Filename_R: ";
                cin>>outFileName_R;
                cout<<"Output Filename_G: ";
                cin>>outFileName_G;
                cout<<"Output Filename_B: ";
                cin>>outFileName_B;
        }

        /* open input/output file */
        infile.open(inFileName, ios::binary);
        outfile_R.open(outFileName_R, ios::binary);
        outfile_G.open(outFileName_G, ios::binary);
        outfile_B.open(outFileName_B, ios::binary);

        /* check input file */
        if(!infile)
        {
                cout<<"Cannot open input file "<< inFileName<<endl;
                return 1;
        }

        infile.read(buf, 2); // get the magic number
        buf[2]='';

        if(buf[0] == 'P' && buf[1] == '6'){
                infile.read(buf, 1);
                while(isspace(buf[0])){ // Skip white space(s)
                        infile.read(buf,1);
                }

                if(buf[0] == '#') { // Skip the comment line
                        while(buf[0] != '
'){ // search end of line
                                infile.read(buf,1);
                        }
                        while(isspace(buf[0])){ // Skip white space(s)
                                infile.read(buf,1);
                        }
                }

                // get width
                bufIndex = 0;
                while(bufIndex < 15 && !isspace(buf[bufIndex])){
                        bufIndex++;
                        infile.read(buf+bufIndex, 1);
                }
                buf[bufIndex] = NULL;  // null terminated string
                width = atoi(buf);

                // get height
                infile.read(buf,1);
                while(isspace(buf[0])){ // Skip white space(s)
                        infile.read(buf,1);
                }
                bufIndex = 0;
                while(bufIndex < 15 && !isspace(buf[bufIndex])){
                        bufIndex++;
                        infile.read(buf+bufIndex, 1);
                }
                buf[bufIndex] = NULL;  // null terminated string
                height = atoi(buf);

                // get max value
                infile.read(buf,1);
                while(isspace(buf[0])){ // Skip white space(s)
                        infile.read(buf,1);
                }
                bufIndex = 0;
                while(bufIndex < 15 && !isspace(buf[bufIndex])){
                        bufIndex++;
                        infile.read(buf+bufIndex, 1);
                }
                buf[bufIndex] = NULL;  // null terminated string
                maxValue = atoi(buf);

                if (maxValue == 255) { // 255 is the only type this program reads
                        Npixels = width * height;
                        pRGB = new BYTE [3*Npixels];
                        pR = new BYTE [Npixels];
                        pG = new BYTE [Npixels];
                        pB = new BYTE [Npixels];
                        infile.read(reinterpret_cast<char *>(pRGB), 3*Npixels);
                        outfile_R << "P5" << endl;
                        outfile_R << width << " " << height << endl;
                        outfile_R << maxValue << endl;
                        outfile_G << "P5" << endl;
                        outfile_G << width << " " << height << endl;
                        outfile_G << maxValue << endl;
                        outfile_B << "P5" << endl;
                        outfile_B << width << " " << height << endl;
                        outfile_B << maxValue << endl;
                        for (i=0; i < Npixels; i++){
                                pR[i] = pRGB[i*3];
                                pG[i] = pRGB[i*3+1];
                                pB[i] = pRGB[i*3+2];
                        }
                        outfile_R.write(reinterpret_cast<char *>(pR), Npixels);
                        outfile_G.write(reinterpret_cast<char *>(pG), Npixels);
                        outfile_B.write(reinterpret_cast<char *>(pB), Npixels);
                }
                else {
                        cout << "Error: wrong MaxGray value -- 255
";
                        width = height = 0;
                }
        }
        else {
                cout << "Error: wrong MagicValue -- P6
";
                width = height = 0;
        }

        /* Delete the pointers */
        delete [] pRGB;
        delete [] pR;
        delete [] pG;
        delete [] pB;

        /* Close file */
        outfile_R.close();
        outfile_G.close();
        outfile_B.close();
        infile.close();

        return 0;
}
页: [1]
查看完整版本: 请教各位关于程序改写的问题