Corning Community College
CSCS1320 C/C++ Programming
~~TOC~~
To apply our existing knowledge of programming constructs in the application of a specific end result: a program that utilizes an image processing library to produce an image of a circle, constructed of squares.
In addition to the new skills required on previous projects, to successfully accomplish/perform this project, the listed resources/experiences need to be consulted/achieved:
We've spent our time so far this semester covering the basic concepts of programming, in C. Variables, selection statements, iteration, functions, structs, etc.
Now that we've gotten through all of them, it is time to start applying those concepts so that deeper and further familiarity can be gained. This project is one such attempt at that.
We all know what a circle is, and in various math classes we've even explored various methods for doing things with circles (they have a radius, a circumference, a diameter), but how do would we enable the computer to draw a circle?
One piece of that, obviously, is the math.
Another piece is the programmatic piece. A circle implies something visual. On the computer that means an image.
So: we are going to use the gd image processing library to aid us in generating the image.
Your task is to write a program that generates an image (PNG file), that is placed in your lab46 webspace for viewing, that does the following:
Now, gd has functions for drawing circles. You are NOT to use them for this project. As I said, this is a circle of squares. As such, you will be making use of the gdImageFilledRectangle() function.
You may make use of the following skeleton program to assist you in doing this project:
/* * PROGRAM.c - skeleton code to use the GD graphics library to create * an image. * * To compile: gcc -o PROGRAM PROGRAM.c -lgd * To execute: ./PROGRAM * OR: ./PROGRAM cos0.png (creates in current directory) * * Functions: http://www.boutell.com/gd/manual2.0.33.html */ #include <stdio.h> #include <stdlib.h> #include <string.h> #include <gd.h> // color values // #define BLACK 0 #define BLUE 1 #define GREEN 2 #define RED 3 #define WHITE 4 int main(int argc, char **argv) { char *outfile; // name out of the output file FILE *out; // output file pointer gdImagePtr img; // GD Image Construct unsigned int color[5]; // color array unsigned short int wide, high; // image attributes if (argc == 2) { outfile = *(argv+1); fprintf(stdout, "Using '%s' as output filename\n", outfile); } else { outfile = (char *) malloc (sizeof(char) * 64); strcpy(outfile, "/home/USERNAME/public_html/cos0.png"); } // image dimensions // wide = 800; high = 600; // Create new image of specified wide-ness and high-ness // img = gdImageCreate(wide, high); // My GD color definitions // color[BLACK] = gdImageColorAllocate(img, 0x00, 0x00, 0x00); color[BLUE] = gdImageColorAllocate(img, 0x00, 0x00, 0xFF); color[GREEN] = gdImageColorAllocate(img, 0x00, 0xFF, 0x00); color[RED] = gdImageColorAllocate(img, 0xFF, 0x00, 0x00); color[WHITE] = gdImageColorAllocate(img, 0xFF, 0xFF, 0xFF); // Paint the background black // gdImageFilledRectangle(img, 0, 0, wide-1, high-1, color[BLACK]); /**************************************************************** * * * =============> YOUR CODE/PROGRAM GOES HERE <============ * * * ****************************************************************/ // Open the file // if((out = fopen(outfile, "wb")) == NULL) { fprintf(stderr, "Error opening '%s'\n", outfile); exit(1); } // Send image to file // gdImagePngEx(img, out, -1); // Close things up // fclose(out); gdImageDestroy(img); return(0); }
To successfully complete this project, the following criteria must be met:
To submit this program to me using the submit tool, run the following command at your lab46 prompt:
$ submit cprog cos0 cos0.c cos0.png http://lab46.corning-cc.edu/~USERNAME/cos0.png Submitting cprog project "cos0": -> cos0.c(OK) -> cos0.png(OK) -> http://lab46.corning-cc.edu/~USERNAME/cos0.png SUCCESSFULLY SUBMITTED
You should get some sort of confirmation indicating successful submission if all went according to plan. If not, check for typos and or locational mismatches.