diff options
| author | unknown <paulx161@umn.edu> | 2021-01-18 19:36:15 -0600 | 
|---|---|---|
| committer | unknown <paulx161@umn.edu> | 2021-01-18 19:36:15 -0600 | 
| commit | 8886c3d660ef857bd72d695d39e5eafd19992c38 (patch) | |
| tree | 1b267e3312363e0009e1279bb668b370c66f0f1a /dev/a1_textrain | |
| download | csci4611-8886c3d660ef857bd72d695d39e5eafd19992c38.tar csci4611-8886c3d660ef857bd72d695d39e5eafd19992c38.tar.gz csci4611-8886c3d660ef857bd72d695d39e5eafd19992c38.tar.bz2 csci4611-8886c3d660ef857bd72d695d39e5eafd19992c38.tar.lz csci4611-8886c3d660ef857bd72d695d39e5eafd19992c38.tar.xz csci4611-8886c3d660ef857bd72d695d39e5eafd19992c38.tar.zst csci4611-8886c3d660ef857bd72d695d39e5eafd19992c38.zip | |
Initial commit
Diffstat (limited to '')
| -rw-r--r-- | dev/a1_textrain/a1_textrain.pde | 159 | ||||
| -rw-r--r-- | dev/a1_textrain/data/TextRainInput.mov | bin | 0 -> 5615074 bytes | |||
| -rw-r--r-- | dev/a1_textrain/data/TextRainInput2.mov | bin | 0 -> 7548818 bytes | |||
| -rw-r--r-- | dev/a1_textrain/data/TextRainInput3.mov | bin | 0 -> 11075890 bytes | |||
| -rw-r--r-- | dev/a1_textrain/data/TextRainInput4.mov | bin | 0 -> 12460114 bytes | 
5 files changed, 159 insertions, 0 deletions
| diff --git a/dev/a1_textrain/a1_textrain.pde b/dev/a1_textrain/a1_textrain.pde new file mode 100644 index 0000000..686824c --- /dev/null +++ b/dev/a1_textrain/a1_textrain.pde @@ -0,0 +1,159 @@ +/* + * CSci-4611 Assignment #1 Text Rain + */ + + +/* Note: if Processing's video library does not support your particular combination of webcam and +   operating system, then the Sketch may hang in the setup() routine when the list of available +   image capture devices is requestd with "Capture.list()".  If this happens, you can skip all of +   the camera initilization code and just run in movie mode by setting the following global  +   variable to true.  + */ +boolean forceMovieMode = false; + +// Global vars used to access video frames from either a live camera or a prerecorded movie file +import processing.video.*; +String[] cameraModes; +Capture cameraDevice; +Movie inputMovie; +boolean initialized = false; + + +// Both modes of input (live camera and movie) will update this same variable with the lastest +// pixel data each frame.  Use this variable to access the new pixel data each frame! +PImage inputImage; + + + +// Called automatically by Processing, once when the program starts up +void setup() { +  size(1280, 720);   +  inputImage = createImage(width, height, RGB); +   +  if (!forceMovieMode) { +    println("Querying avaialble camera modes."); +    cameraModes = Capture.list(); +    println("Found " + cameraModes.length + " camera modes."); +    for (int i=0; i<cameraModes.length; i++) { +      println(" " + i + ". " + cameraModes[i]);  +    } +    // if no cameras were detected, then run in offline mode +    if (cameraModes.length == 0) { +      println("Starting movie mode automatically since no cameras were detected."); +      initializeMovieMode();  +    } +    else { +      println("Press a number key in the Processing window to select the desired camera mode."); +    } +  } +} + + + +// Called automatically by Processing, once per frame +void draw() { +  // start each frame by clearing the screen +  background(0); +     +  if (!initialized) { +    // IF NOT INITIALIZED, DRAW THE INPUT SELECTION MENU +    drawMenuScreen();       +  } +  else { +    // IF WE REACH THIS POINT, WE'RE PAST THE MENU AND THE INPUT MODE HAS BEEN INITIALIZED + + +    // GET THE NEXT FRAME OF INPUT DATA FROM LIVE CAMERA OR MOVIE   +    if ((cameraDevice != null) && (cameraDevice.available())) { +      // Get image data from cameara and copy it over to the inputImage variable +      cameraDevice.read(); +      inputImage.copy(cameraDevice, 0,0,cameraDevice.width,cameraDevice.height, 0,0,inputImage.width,inputImage.height); +    } +    else if ((inputMovie != null) && (inputMovie.available())) { +      // Get image data from the movie file and copy it over to the inputImage variable +      inputMovie.read(); +      inputImage.copy(inputMovie, 0,0,inputMovie.width,inputMovie.height, 0,0,inputImage.width,inputImage.height); +    } + + +    // DRAW THE INPUTIMAGE ACROSS THE ENTIRE SCREEN +    // Note, this is like clearing the screen with an image.  It will cover up anything drawn before this point. +    // So, draw your text rain after this! +    set(0, 0, inputImage); + + +    // DRAW THE TEXT RAIN, ETC. +    // TODO: Much of your implementation code should go here.  At this point, the latest pixel data from the +    // live camera or movie file will have been copied over to the inputImage variable.  So, if you access +    // the pixel data from the inputImage variable, your code should always work, no matter which mode you run in. +     +     + +  } +} + + +// Called automatically by Processing once per frame +void keyPressed() { +  if (!initialized) { +    // CHECK FOR A NUMBER KEY PRESS ON THE MENU SCREEN     +    if ((key >= '0') && (key <= '9')) {  +      int input = key - '0'; +      if (input == 0) { +        initializeMovieMode(); +      } +      else if ((input >= 1) && (input <= 9)) { +        initializeLiveCameraMode(input); +      } +    } +  } +  else { +    // CHECK FOR KEYPRESSES DURING NORMAL OPERATION +    // TODO: Fill in your code to handle keypresses here.. +    if (key == CODED) { +      if (keyCode == UP) { +        // up arrow key pressed +      } +      else if (keyCode == DOWN) { +        // down arrow key pressed +      } +    } +    else if (key == ' ') { +      // spacebar pressed +    }  +  } +} + + + +// Loads a movie from a file to simulate camera input. +void initializeMovieMode() { +  String movieFile = "TextRainInput.mov"; +  println("Simulating camera input using movie file: " + movieFile); +  inputMovie = new Movie(this, movieFile); +  inputMovie.loop(); +  initialized = true; +} + + +// Starts up a webcam to use for input. +void initializeLiveCameraMode(int cameraMode) { +  println("Activating camera mode #" + cameraMode + ": " + cameraModes[cameraMode]); +  cameraDevice = new Capture(this, cameraModes[cameraMode-1]); +  cameraDevice.start(); +  initialized = true; +} + + +// Draws a quick text-based menu to the screen +void drawMenuScreen() { +  int y=10; +  text("Press a number key to select an input mode", 20, y); +  y += 40; +  text("O: Offline mode, test with TextRainInput.mov movie file instead of live camera feed.", 20, y); +  y += 40;  +  for (int i = 0; i < min(9,cameraModes.length); i++) { +    text(i+1 + ": " + cameraModes[i], 20, y); +    y += 40; +  }   +} diff --git a/dev/a1_textrain/data/TextRainInput.mov b/dev/a1_textrain/data/TextRainInput.movBinary files differ new file mode 100644 index 0000000..ae45b66 --- /dev/null +++ b/dev/a1_textrain/data/TextRainInput.mov diff --git a/dev/a1_textrain/data/TextRainInput2.mov b/dev/a1_textrain/data/TextRainInput2.movBinary files differ new file mode 100644 index 0000000..d8fce10 --- /dev/null +++ b/dev/a1_textrain/data/TextRainInput2.mov diff --git a/dev/a1_textrain/data/TextRainInput3.mov b/dev/a1_textrain/data/TextRainInput3.movBinary files differ new file mode 100644 index 0000000..c1e6386 --- /dev/null +++ b/dev/a1_textrain/data/TextRainInput3.mov diff --git a/dev/a1_textrain/data/TextRainInput4.mov b/dev/a1_textrain/data/TextRainInput4.movBinary files differ new file mode 100644 index 0000000..9dff13b --- /dev/null +++ b/dev/a1_textrain/data/TextRainInput4.mov | 
