-
Notifications
You must be signed in to change notification settings - Fork 9
Homework Shiffman Thursday 2
A big part of learning at ITP is learning from each other. So share your work and in exchange you'll get to see everyone else's!
- Do the assignment.
- Contribute a question.
- Post documentation in the form of a blog post. Ideally something visual, some written thoughts, and code. If you are struggling with your sketch and can't get things to work, you should feel free to put your energy into writing about what didn't work (and vent any frustrations!).
- Final project presentations are Thursday, December 8th. In class presentations will be approximately 7 minutes each, I will be strict about the time.
- Please post your final project documentation to a web page (blog post is fine) and link next to your name below. This is due Friday, December 16.
- It's up to you to figure out how to best document your project, here are some loose guidelines if you aren't sure what to include.
- Title
- Brief written description
- Visual Documentation: sketch running online, images, video, etc.
- References: links to related projects, code samples, etc.
- Source code (please cite your sources in the code comments)
- This is the arbitrary randomized order, please shuffle your names as you wish.
- If you are presenting outside of room 50, please indicate below.
- Grant & Katie [Virtual Baseball Simulator Documentation...still in progress] (http://www.katattakacs.com/itp/2016/12/19/all-about-that-baseball/)
- Roxanne & Yun
- Eric Blog,Source code,Visual Documentation
- Yanlin
- Dorothy
- Jade,
- Ji Young, Shakit
- Alexia, [Blog Interactive News Map] (http://www.alexiak.com/2016/12/08/interactive-news-map/), [Blog Kinect Experimentation] (http://www.alexiak.com/2016/11/20/experimentations-with-movement-kinect/), [Map code] (https://github.com/alexiak24/itpmap), [Kinect code] (https://alpha.editor.p5js.org/alexiak/sketches/HJNWATvZe)
- Patrick Documentation (sorry for the slides, I'm having blog issues and will update over break) ITPodcast Code
- Hayley - Blog, Code
- Or - Forever, Code, Documentation
- Mint - Documentation, Blog
- Ishaan - Villains & Coins, Code, Blog
- Jenny - Laser Cats
The testing will follow a "speed-dating" format. The class will be divided into two groups and we'll do two rounds. For each round half the students will set up on a laptop in the class room and the other half will "view" or "interact with" or "listen to" your project for ~5-7 minutes. We'll rotate so that all "testers" will try each project and provide feedback.
It's up to you to design your "user testing". It can mean something different for each project. For a game, it's pretty obvious what to do. For a physical installation or performance or sound piece, this will be more difficult. The "rule" that we will try to adhere to is no explaining of the project until after the user has viewed/interacted.
If you are not sure how to design your testing, e-mail me or come and see me and we'll discuss.
Yanlin, Or, Ishaan, Dorothy, Hayley, Eric, Grant & Katie
Jade, Patrick, Jenny, Roxanne & Yun, Mint, Ji Young
Final projects are a creative idea inspired by the concepts in this class. There is no requirement to use a particular aspect of programming. The idea and your enjoyment and interest in the idea is what counts. Some things to remember.
- Keeping things simple and small in scope is a plus. If your project idea is a big one, consider documenting the larger idea but implementing just a small piece of it.
- Also think about making a final project for a small audience, even one single person like a family member or friend. . . or yourself. This can be a good way to focus your idea and design process. "Generalizing" the idea can come later (or maybe not at all.)
- Final projects can be collaborations with anyone in any class.
- Final projects can be one part of a larger project integrated with Physical Computing or another class.
- Final Project Proposals: a few minutes of slides, sketches...something to ILLUSTRATE what's in your head.
- Collect inspirations: How did you become interested in this idea? quotes, photographs, products, projects, people, music, political events, social ills.
- Collect source material: drawings, images, videos, sounds, text
- Collect code: your own sketches and/or other people's sketches.
- Collect ideas for title
- Collect ideas for 1-sentence description?
- Context? Who's it for? How will people experience it? Is it interactive? Is it practical? Is it for fun? Is it emotional? Is it to provoke something?
-
Collect questions for your classmates.
- What are you unsure of? Conceptually and technically.
- Plan to present your idea in ~2-3 minutes leaving about 5 minutes for discussion. You can present your idea however you like visually, but make sure you also document your thoughts in a blog post linked below.
- Dorothy --
- Eric -- Night Seat
- Yanlin --iii
- Grant, Katie --
- Ishaan --[Villains & Coins] (http://ishaanchaudhary.com/2016/11/09/icm-final-proposal/)
- Jade -- [Illusion] (https://docs.google.com/presentation/d/1teXkQKGLWL1ZI-XNdtAnuci3yFiW1TtrWCguNgEtMb4/edit#slide=id.gc6f90357f_0_0/)
- Ji Young --
- Patrick --
- Alexia --
- Or --
- Roxanne, Yun -- [Show me the Beatbox] (https://docs.google.com/presentation/d/1GRws2-AfTXtkX-_C750QB6cuJjkANCkbmdgwwWU6j84/edit#slide=id.g13b2a8f746_0_0), [Yun's Blog] (http://www.seetheunseen.xyz/2016/10/30/design-for-the-real-world-tech-research/)
- Hayley --Text-to-Voice
- Mint -- Blog Link
- Jenny -- [Go Yang Yi] (http://jlimetc.tumblr.com/post/153280152037/goyangyi-evolves)
Here's another mini trial run for a final project. Just like last week, all students should complete the assignment but only 1/2 will present in class.
-
Create a sketch that uses external media (sound or video). Some ideas are:
- Make something responsive to microphone input.
- Create a "photobooth" with augmented snapshots from a camera.
- Create a "painting" system that colors pixels according to camera input or a video.
-
Create a blog post documenting your work. Also include links to other projects that serve as references, inspiration, or deal with similar ideas as your piece.
-
READ AND WATCH (optional):
- Chapter 7 in Getting Started with p5.js.
- p5.js sound tutorials
- p5.js video and pixels tutorials
- p5.sound reference
- Video/capture: p5.MediaElement reference
- Computer Vision Tutorials in Processing squint and it's the same as p5.js.
- Video
- Sound
Questions (example questions)
- questions
- In AudioIn, stop() function doesn't work saying it is not defined
Note that those of you who did not present last week will present this week as indicated below.
- Presenters
- Jenny -- Sketch in progress, Blog Post
- Ishaan -- [Ritual Interactive Visualizer] (https://alpha.editor.p5js.org/full/BJ-tpQuxl)
- Hayley -- TypingPiano, [Blog]
- Dorothy --
- Grant -- [Code] (https://alpha.editor.p5js.org/projects/ry-gmnugg), [Blog] (http://www.grantalanhenry.com/2016/11/03/the-cubs-win/)
- Or -- Mask
- Yanlin -- |||(https://alpha.editor.p5js.org/projects/rkCqilKgx)
- Non-presenters
- Alexia --pixelized (http://www.alexiak.com/2016/11/03/pixelized/)
- Katie -- [Rains With Sound] (https://alpha.editor.p5js.org/projects/rydwdwbgl), [Cubs Photobooth] (https://alpha.editor.p5js.org/projects/S10dtGOgl), [Almost Immediately] (http://www.katattakacs.com/itp/2016/11/03/when-media-works-immediately/)
- Yun -- [Particle Sound Visualizer] (https://alpha.editor.p5js.org/embed/SyC7uyFex), [Blog] (http://www.seetheunseen.xyz/2016/11/03/icm-w9_particle-music-visualizer/)
- Mint --
- Roxanne --
- Patrick --
- Ji Young -- [Music Visualizer] (https://alpha.editor.p5js.org/projects/SyjlNZKle)
- Jade --
- Eric --Trippy III, Blog
Start thinking about and doing some mini trial runs for a final project. They can be small sketches that form a tiny component of a larger idea. All students should complete the assignments for this week and next but only 1/2 will present each week.
- Create a sketch that uses an external data source. Plan to present in class using the classroom computer or your own laptop if you prefer. Here are some ideas:
- Track personal data over the course of a few days (exercise, sleep, computer use, eating, etc.). Enter the data manually into a JSON file and visualize the results.
- Count word frequencies in two different text sources (i.e. two different authors, two different newspapers, two different political speeches) and visualize the results.
- Use weather data to affect elements in a sketch.
- Gather data from a google spreadsheet and use in a sketch.
- Here's a list of other data sources you might investigate and try.
-
Create a blog post documenting your work and process. Include links to other projects that serve as references and inspiration for your work.
-
READ AND WATCH (whatever is helpful to you):
- Videos about Data and APIs
- Videos about word counting and text analysis - videos are from the A to Z class and include some materials out of scope of our class.
- Getting Started with p5.js - chapter 12
- Tutorial about data 1
- Tutorial about data 2 - these notes are from the A to Z class and include some materials out of scope of our class.
- Art and the API, Jer Thorp
- The Anxieties of Big Data, Kate Crawford
- JSON Basics
- More JSON
- Weather Data
- Giphy API
- Wordnik API
- NYTimes
- ITP Project Finder API
- More Data Examples from A2Z
- More Data Examples from GSWP5
- In-class
Questions (example questions)
- Math.floor(Math.random() * arrays.length - 1); This is a good method at being random? On stackoverflow site, it mentioned that it’s much less likely to pick the first and last elements and they don’t have equal chance on being picked. Can you please explain?
Note that half of you will present this week, the other half next. You should complete both assignments, however, and of course you can present both weeks if you have a question or something you really want to get feedback on. Feel free to switch with each other or e-mail me if you would like to switch.
- Presenters
- Katie -- [Code] (http://alpha.editor.p5js.org/projects/SJEQiJ1xe), [The JSON Will Come Out Tomorrow] (http://www.katattakacs.com/itp/2016/10/27/the-json-will-come-out-tomorrow/)
- Yun -- [the Star Words Poem] (https://alpha.editor.p5js.org/projects/HyAm5CAJg), [Blog Post] (http://www.seetheunseen.xyz/2016/10/26/icm-w8_star-words-1st-data-visualization/)
- Mint -- Code, Blog Post
- Roxanne -- Code, Blog Post
- Patrick -- [Bar chart] (http://alpha.editor.p5js.org/projects/rJccHR9kl) Text
- Ji Young -- [Data Visualization-Foursquare] (http://alpha.editor.p5js.org/projects/ry8SohRyg)
- Jade -- Code
- Eric --Weather Space, Blog Post
- Non-presenters
- Jenny -- Lucky Loans 4 U, [blog post] (http://jlimetc.tumblr.com/post/152251274602/lucky-loans-4-u)
- Or --
- Ishaan -- [Current Cloud Coverage] (http://alpha.editor.p5js.org/projects/Hy-AQcAJg)
- Hayley --[TodayThanYesterday] (http://alpha.editor.p5js.org/projects/SJ08IAklx), Blog
- Alexia -- *Used offline editor [Blog] (http://www.alexiak.com/2016/10/27/world-map-itp/)
- Dorothy -- [population visualisation] (http://alpha.editor.p5js.org/projects/BkIvRTyle)
- Grant -- [Code] (https://alpha.editor.p5js.org/projects/B1t1z9Jgl), [Blog] (http://www.grantalanhenry.com/2016/10/27/lights-camera-api/)
- Yanlin --
-
READ / REVIEW
- Tutorial: Intro to HTML and CSS
- Tutorial: Beyond the Canvas in P5
- p5.js DOM library videos
- Chapter 13 in Getting Started with P5.js
- p5.js dom reference
- CSS reference
-
DO
- Create a webpage that extends beyond the canvas, using p5.dom.js. You are welcome to incorporate other javascript libraries as well if you're feeling ambitious. If you're stuck for ideas, you can try going back to the graphical user interface (GUI) elements that we experimented with in week 3, and try recreating that functionality with DOM elements. Try using a callback in your sketch! Some questions to consider:
- Do you write HTML elements into
index.html
? - Do you "generate" HTML elements with code in p5?
- Do you write CSS styles into
index.html
orstyle.css
? - Do you apply styles in code with the
style()
function?
- Do you write HTML elements into
- Next week we will look at working with data and APIs in class. If you feel so inclined you can take a look at some of the video tutorials in advance. Please add a link to a data set or "API" that interests you. You don't have to know anything about how to use it, but having a list of examples we can examine in class next week will add to the discussion. You can also contribute to this wiki list of data sources.
- Create a webpage that extends beyond the canvas, using p5.dom.js. You are welcome to incorporate other javascript libraries as well if you're feeling ambitious. If you're stuck for ideas, you can try going back to the graphical user interface (GUI) elements that we experimented with in week 3, and try recreating that functionality with DOM elements. Try using a callback in your sketch! Some questions to consider:
-
EXAMPLE CODE
- DOM library videos accompanying code
- GSWP5 Chapter 13
- Optional quiz to test your knowledge
- editor examples
- in-class code
Questions (example questions)
- Hayley -- p5 web editor warned 'infinite loop', I am really not sure where it is, and how can I solve this problem?
- Sport Stats - [ESPN] (http://www.espn.com/static/apis/devcenter/docs/scores.html#using-the-api) - mostly baseball stats because they are so specific and sortable (I think that's a useful thing, right?) - Katie
- Facebook/twitter data - Ishaan
- spotify/itunes/shazzam data sets - Ishaan
- US gov API (Catalog)| (https://www.whitehouse.gov/digitalgov/apis) - Patrick
- Futbol/Soccer data (https://www.jokecamp.com/blog/guide-to-football-and-soccer-data-and-apis/) - Patrick
- [Panama Papers] (https://offshoreleaks.icij.org/pages/database) - Jenny
- [Echonest Remix] (https://echonest.github.io/remix/) - Or
- [NYC Local Data] (https://nycopendata.socrata.com/) - Roxanne
- [NASA APIs] (https://api.nasa.gov/index.html#getting-started) - Dorothy
- Jenny -- [Blog Post] (http://jlimetc.tumblr.com/post/152044353982/outside-the-sandbox), [Code in Progress] (https://alpha.editor.p5js.org/projects/HkBpjNrA)
- Katie -- [Blame it on the Rain] (http://www.katattakacs.com/itp/2016/10/20/blame-it-on-the-rain/), [Code in Progress] (https://alpha.editor.p5js.org/projects/rJsVTcTC)
- Or -- Israeli Alphabet
- Yun -- Blog Post, [Message Network] (https://alpha.editor.p5js.org/full/ByrcGQL1e)
- Ishaan -- [Fire Dance] (https://alpha.editor.p5js.org/projects/SyZAdPUkl)
- Mint -- Blog Post, code
- Hayley -- OMOK(GOMOKU)game , blog
- Roxanne -- html/css, [Video] (https://player.vimeo.com/video/187439511)
- Alexia -- optical illusion
- Patrick -- Adding html/css
- Dorothy -- [Morse Code Translator] (http://alpha.editor.p5js.org/projects/By9bHDLJl)
- Ji Young -- Fishing Blog, [Fishing] (https://alpha.editor.p5js.org/projects/By3yicUyg)
- Grant -- [Blog] (http://www.grantalanhenry.com/2016/10/20/traffic-lights/), [Code] (http://alpha.editor.p5js.org/projects/BywjXcSJg)
- Jade --
- Eric -- Weather Space, Blog Post, integrated work with week 8 project
- Yanlin --
- Videos 6.1-6.11 cover more about objects, arrays, and the constructor function.
- Getting Started with p5.js chapters 10-11 also cover the same material.
- Next week we'll be covering the p5.js DOM library. If you want to get a head start take a look at
- Videos 7.1-7.16
- p5.dom section of Chapter 13 in Getting Started with P5.js
- Tutorial: Beyond the Canvas in P5
- In your blog post this week, please include some thoughts on the synthesis workshop, what you liked or didn't like about it, and any documentation of what you made.
- Design a sketch in an object-oriented fashion. Follow these steps and see how far you get (even just doing the first couple steps is ok!)
- Write a constructor function with just variables and generate one single object.
- Put one or more functions in the constructor function and call them on the object.
- Try making two objects without an array. Can you make them different?
- Duplicate the object using an array and make as many as you like!
In the end the goal is to have code in draw()
that only makes calls to objects. Something like:
function draw() {
background(0);
// A single object
apple.chop();
// Another object
orange.peel();
// Calling a function on all of the objects in an array
for (var i = 0; i < grapes.length; i++) {
grapes[i].pluck();
}
}
- Code from videos
- Learning Processing in p5.js: Chapters 8-9
- Getting Started with p5.js: Chapters 10-11
- examples (in editor)
- Optional quiz to test your knowledge
Questions (example questions)
- your question here
- Your Name -- [Title of Blog Post](Link to Blog Post), [Title of Sketch](Link to Sketch) -- any other comments
- Yun -- Synthesis, Dot Movements using Math
- Katie -- [Branching Out: ICM PComp Synthesis] (http://www.katattakacs.com/itp/2016/10/12/branching-out-icm-and-pcomp-synthesis-workshop/), [Raining: The Re-Return] (http://www.katattakacs.com/itp/2016/10/12/raining-the-re-return/), [The Rains Sketch] (https://alpha.editor.p5js.org/projects/SJ5HJUE0)
- Jade -- [Synthesis blog] (http://www.jingfei-lin.com/2016/10/12/icm-synthesis/), [serial drawing] (https://alpha.editor.p5js.org/projects/rkBlxwBA)
- Eric -- Trippy 3rd,Synthesis Blog:Trippy 2nd
- Jenny -- [Synthesis: Push-Button Mickeys] (https://alpha.editor.p5js.org/projects/Bkn53DFR), [Video of Mickeys] (https://www.youtube.com/watch?v=bW1l1A28Vxo&feature=youtu.be)
- Alexia -- [under_the_sea] (https://alpha.editor.p5js.org/projects/ry77ro5C), [synthesis] (http://www.alexiak.com/2016/10/11/328/)
- Ji Young -- Synthesis Workshop, Apple Pick
- Dorothy --
- Yanlin --
- Or Synthesis, Serial Drum Machine, leapo
- Grant -- [rbSmoke] (https://alpha.editor.p5js.org/projects/SJcUVSTA), [Blog] (http://www.grantalanhenry.com/2016/10/13/rbsmoke/)
- Mint --
- Patrick -- [Sketch] (https://alpha.editor.p5js.org/projects/BkKs2JnA)| [Blog] (http://www.letspresto.com/2016/10/13/visualizing-sleep-sound-by-jamie-xx/)
- Hayley -- Synthesis : backpack ,blog,weavingGenerator-smartphone , [Object : Pistachio] (https://alpha.editor.p5js.org/projects/Sy9GxUlJe)
- Roxanne -- Pop Flowers, [Object: Pistachio!] (https://alpha.editor.p5js.org/projects/Sy9GxUlJe)
- Ishaan -- [Pizza Munch Game] (https://alpha.editor.p5js.org/projects/SyXj5U6A)
-
The idea this week is to explore re-organizing your code. It is 100% legitimate to turn in a version of a previous assignment where nothing changes for the end user, but the code has been restructured. You may, however, choose to try a new experiment from scratch. Aim to keep
setup()
anddraw()
as clean as possible, and do everything (all calculations, drawing, etc.) in functions that you create yourself. Possibilities (choose one or more):- Break code out of
setup()
anddraw()
into functions. - Use a function to draw a complex design (like this) multiple times with different arguments.
- Write a function to that returns the result of a mathematical operation that you need to do several times in your code.
- Reorganize "groups of variables" into objects.
- If you are feeling ambitious, try embedding a function into an object.
- Break code out of
-
An optional quiz to test your knowledge if you like.
-
READ / WATCH (Nothing required, read or watch what you find most helpful)
- Videos 5.1-5.4 cover functions. If you want to get started on what we'll discuss next week, you can also watch 6.1-6.11. Last year, I emphasized "JavaScript object literals" over the "JavaScript Constructor function" for making objects. I think this was a mistake. I'll discuss the distinction in class next week and might re-record these videos eventually, but keep that in mind as you watch. 6.4: The Constructor Function might be the most useful.
- Getting Started with p5.js chapters 9-10 (see e-mail re: PDF)
-
Examples
- p5.js editor
- other
Questions (example questions)
- your question
- If I want to make a lot of something, what are the benefits of making an object that contains a function v. a function that constructs objects?
- Is there a way to add .js file into the sketch.js file that I’m working on without having to download the file to my laptop then upload.
- Your Name -- [Title of Blog Post](Link to Blog Post), [Title of Sketch](Link to Sketch) -- any other comments
- Yun Choi -- , Moon, Clouds, Rain -- lower speed than local server
- Katie Takacs - [Rain] (http://www.katattakacs.com/itp/2016/10/06/raining/) - ...in progress...
- Jade -- [Twisting Drawing] (https://alpha.editor.p5js.org/projects/HyT86I7R)
- Eric Li -- Week 4 - Trippy, Trippy
- Jenny Lim -- [Blog] (http://jlimetc.tumblr.com/post/151421732237/two-steps-back) -- Kitties and Mice II
- Alexia -- [pong 2 in progress] (https://alpha.editor.p5js.org/projects/HkSPcf70)
- Ji Young -- [#4 Monster Game] (http://www.jiyoungchun.com/2016/10/06/4-monster-game/), MonsterGame
- Dorothy -- [updated] (http://www.dorothylamzihong.com/single-post/2016/10/04/People-walking-experiment)
- Yanlin -- hkdfekw~~
- Or 5 Tones of Emotion
- Grant -- Blog, Mickey Warhol
- Mint -- Blog -- Code Clean Up
- Patrick -- Particles
- Hayley -- Blog, weavingGenerator v03
- Roxanne -- [takashi murakami flower] (https://alpha.editor.p5js.org/projects/Sk7MUzV0)
- Ishaan -- snake
- In general this week, you should work with rule-based animation, motion, and interaction. You can use the ideas below or invent your own assignment. Start by working in pairs as specified below. Can you divide an idea into two parts and combine those parts? Can you swap sketches and riff of of your partner's work? You can post together or break off and complete the assignment individually.
- Try making a rollover, button, or slider from scratch. Compare your code to the examples below. Later we'll look at how this compare to interface elements we'll get for free from the browser.
- Create an algorithmic design with simple parameters. (One example is 10PRINT, see: 10PRINT example.
- Tie the above two together and have an interface element control the visual design or behavior of other elements in your sketch.
- Try this quiz if you want to test your knowledge.
- Videos 3.1-4.2 cover conditionals and loops.
- For a preview of next week 5.1-5.4 cover functions.
- Getting Started with p5.js chapters 9-10
- from class:
- Motion
- GUI
- Examples for Videos
- Getting Started with p5 Examples Chapters 9-10
- Learning Processing examples ported to p5.js Chapters 7-8
Questions (example questions)
- your question here
- Your Name -- [Title of Blog Post](Link to Blog Post), [Title of Sketch](Link to Sketch) -- any other comments
- Alexia, Ji Young -- [Blog: Door to the other world] (http://www.jiyoungchun.com/2016/09/29/3-door-to-the-other-world/) , [Sketch: Door to the Other World] (https://alpha.editor.p5js.org/projects/HyOqvkaT)
- Katie, Yun -- [Star Treck Blog] (http://www.katattakacs.com/itp/2016/09/29/star-treck-when-yun-and-katie-work-together/), StarScreenSaverWithYun p5.js, [Star Treck Fractal Blog] (http://www.seetheunseen.xyz/2016/09/29/icm-enexpected-fractal-code-2-working-with-katie/), [StarTreckFractalwithKatie] (https://alpha.editor.p5js.org/projects/S1jw8y5T)
- Dorothy, Yanlin, -- [people walking part] (https://alpha.editor.p5js.org/projects/BJSAbRFa), [slider control] (https://alpha.editor.p5js.org/projects/H1y5CdFa) , [0101] (https://alpha.editor.p5js.org/projects/S1RBDTcT)
- Or, Jade Flow
- Grant, Mint [Grant's Blog] (http://www.grantalanhenry.com/2016/09/29/are-you-ready-for-some-football/), Mint's Blog, [Are You Ready for Some Football?] (https://alpha.editor.p5js.org/projects/SJdVWTcT)
- Patrick, Jenny Kitties and Mice and Mice Blog Post || [Patrick's Blog] (http://www.letspresto.com/2016/09/29/icm-lines-positions-buttons-rinse-repeat/) || [Lines,positions, buttons, rinse, repeat] (https://alpha.editor.p5js.org/projects/B1y-TCL6)
- Haley, Eric Hayley's Blog||[Weaving Generator] (https://alpha.editor.p5js.org/projects/rJN7Uysa)
- Roxanne, Ishaan - [bouncing banana] (https://alpha.editor.p5js.org/projects/HkfKO05a)
- REVIEW - If you haven't already...
- Variables videos 2.1-2.3 and 1st half of Chapter 4 of Getting Started with p5 (up to Example 4-5).
-
map()
andrandom()
videos 2.4 - 2.5
- DO:
- Create a sketch that includes (all of these):
- One element controlled by the mouse.
- One element that changes over time, independently of the mouse.
- One element that is different every time you run the sketch.
- (You can choose to build off of your week 1 design, but I might suggest starting over and working with one or two simple shapes in order to emphasize practicing with variables. See if you can eliminate all (or as much as you can) hard-coded numbers from the sketch.)
- Here is an optional "take-home" quiz to test your knowledge.
- READ AND WATCH:
- Videos
- Getting Started with p5:
- Read Chapters 5 (Response) and 8 (Motion).
- Read the 2nd half of Chapter 4 on Loops (starting from Example 4-5 thru 4-13).
- If you're interested, read Chapter 6 on Translate, Rotate and Scale.
- EXAMPLE CODE:
- accompanying video code
- Learning Processing Examples: [chp03-06] (https://github.com/shiffman/LearningProcessing-p5.js)
- Getting Started with p5 Examples: 04, 05, 06, 08.
- Animation examples from ICM 2015
Questions (example questions)
- It seems that we couldn’t use both of the angleMode in one project.
- How to make text fixed at the center of the canvas?
- How to make a shape with stroke totally disappeared?
- How can I change triangle and reangle's color when I refresh?
- How many times can you call the Setup function/Draw function/Event Functions in your sketch?
- How do you fit a random pattern inside a shape?
-
Your Name -- [blog post](Link to Blog Post), [sketch](Link to Sketch) -- any other comments
-
Katie -- blog post, [sketch] (https://alpha.editor.p5js.org/projects/By7xK_nh) -- Still working on it...but here's a start...
-
Eric -- blog post, [The Small Bang] (https://alpha.editor.p5js.org/projects/SJiEf3e6)
-
YUN -- blog post, [Unexpected Fractal Code] (https://alpha.editor.p5js.org/projects/rykTNjZa)
-
Roxanne -- blog post, [Saturate Myself in p5.js] (https://alpha.editor.p5js.org/projects/rkMK6LW6)
-
Jade -- [1.playWithRandom] (https://alpha.editor.p5js.org/projects/Hkot1tWT) [2.flow] (https://alpha.editor.p5js.org/projects/SkKrTib6)
-
Jenny -- [Kitty Clicker] (https://alpha.editor.p5js.org/projects/SkhNDUxa), [Spinning Kitty] (https://alpha.editor.p5js.org/projects/rJ0Potba), [Blog Post] (http://jlimetc.tumblr.com/post/150748336147/coding-for-kitties)
-
Yanlin -- [Rotating Circles] (https://alpha.editor.p5js.org/projects/SJ1bDrxT)
-
Patrick -- [Random Shapes] (https://alpha.editor.p5js.org/projects/H1LIARF3)
-
Ishaan -- [MEMBA MASK] (https://alpha.editor.p5js.org/projects/HJCGRV0n)
-
Hayley(Hayeon) -- Blog post(http://www.hhayley.com/2016/09/22/icm-weaving/), [Plain Weaving Generator] (https://alpha.editor.p5js.org/projects/BkuWkoWT)
-
Dorothy -- [Blog Post] (http://www.dorothylamzihong.com/single-post/2016/09/22/Zooooooming-Out-or-trying-to), [Zooming Out] (https://alpha.editor.p5js.org/projects/SkAOGWJp)
-
Grant -- [Blog Post] (http://www.grantalanhenry.com/2016/09/22/weektwo-whatdidimake/), [whatDidiMake] (https://alpha.editor.p5js.org/projects/SJYN1Dg6)
-
Ji Young -- [Blog Post] (http://www.jiyoungchun.com/2016/09/22/bubble-pop/), Bubble Pop
-
Alexia -- [pong game] (https://alpha.editor.p5js.org/projects/HkmmS9gT)
-
SET UP:
- Sign up for a p5.js web editor account
- Sign up for the ITP ICM Google Group
- Sign up for our ICM Section's Announcement List
- Sign up for a Github Account. You need it to edit this wiki page.
- If you would like to be a member of my Coding Rainbow slack channel, where there is a #help channel for questions, let me know via e-mail.
-
DO:
- Here is an optional "take-home" quiz to test your knowledge. We'll be releasing one of these each week for self-study. We'll discuss answers next week in class.
- Create your own screen drawing: self-portrait, alien, monster, etc. Use 2D primitive shapes –
arc()
,curve()
,ellipse()
,line()
,point()
,quad()
,rect()
,triangle()
– and basic color functions –background()
,colorMode()
,fill()
,noFill()
,noStroke()
,stroke()
. Remember to usecreateCanvas()
to specify the dimensions of your window and wrap all of your code inside asetup()
function. Here's a sample example: Zoog - Write a blog post about how computation applies to your interests. This could be a subject you've studied, a job you've worked, a personal hobby, or a cause you care about. What projects do you imagine making this term? What projects do you love? (Review and contribute to the ICM Inspiration Wiki page. In the same post (or a new one), document the process of creating your sketches. What pitfalls did you run into? What could you not figure out how to do? How was the experience of using the web editor? Did you post any issues to github?
-
READ AND WATCH:
- Videos 1.1 - 1.3 -- note these were recorded last year and reference the desktop editor which we are no longer using this semester.
- After you do your homework, watch 2.1 - 2.3 to preview next week's discussion.
- If the YouTube ads / format bother you, please contact [email protected] for a link to a shared google drive folder.
- If you prefer books, I suggest Chapters 1-3 of Getting Started with p5.js. If you are logged into the NYU network you can read it via safari books online.
-
ASK QUESTIONS: Contribute at least 1 question below. (Name optional.)
Questions | Examples
- Or Fleisher - While working with P5.sound.js I wasn't able to run it on a local server due to Navigator.getUserMedia() requiring an https server on Chrome. Is there anyway I can fix this issue?
- Katie Takacs - Can we talk about arcs? I think I get what each value is doing - but if we're being honest, it's a 50/50 chance that the value I change actually changes the thing I thought it would in the way I thought it would.
- Dorothy Lam; ZiHong - How does P5.js as a library work with websites, or how do websites interpret the library? I remember from last class that P5 animations won't run if the site wasn't loaded with the library? Can you explain more how a library, a browser and javascript work together?
- Kenzo - Is it possible to have the background change without having it "erase" the painting?
- Daniel Shiffman -- documentation, zoog -- any other comments
- Ishaan Chaudhary -- documentation, zoog
- Eric Wenqi Li -- documentation, Full Moon Portrait
- Or Fleisher -- documentation, [Modo] (https://juniorxsound.github.io/Modo/)
- Katie Takacs -- [documentation] (http://www.katattakacs.com/itp/2016/09/15/icm-and-self-portraits-week-1/), [Portrait] (https://alpha.editor.p5js.org/projects/B1f3-FP2)
- Hayeon(Hayley)Hwang -- [documentation] (http://www.hhayley.com/2016/09/15/icm/), [My (Hair) Portrait] (https://alpha.editor.p5js.org/projects/ByhyLjw3)
- Dorothy Lam; ZiHong -- [documentation] (http://www.dorothylamzihong.com/single-post/2016/09/15/Drawing-in-P5js-Life-as-Computation), [self-portrait] (https://alpha.editor.p5js.org/projects/BkylEGu3)
- Patrick Presto -- [Blog] (http://www.letspresto.com/2016/09/15/icm-me-myself-and-computation/) [-] The smiling-freckled-mustache-thing
- Yun Ho Choi -- [documantation] (http://www.seetheunseen.xyz/2016/09/15/p5-js-2/), [Apple Guitar] (https://alpha.editor.p5js.org/projects/rykTNjZa)
- Grant Henry -- [documentation] (http://www.grantalanhenry.com/2016/09/15/p5/), [fitz] (https://alpha.editor.p5js.org/projects/SklMWtPh)
- Jingfei Lin (Jade) -- [Smile, please] (https://alpha.editor.p5js.org/projects/Skkz3hD3)'
- Ji Young Chun -- Self Portrait , documentation, Blog Post
- Jenny Lim -- [documentation] (http://jlimetc.tumblr.com/tagged/icm), [Comic] (https://alpha.editor.p5js.org/projects/r1cX7d-n)
- Woraya (Mint) Boonyapanachoti -- Bubbles
- Roxanne Kim -- [Self-portrait] (https://alpha.editor.p5js.org/projects/Sk7vOSO2), [Post] (https://roxannekimblog.wordpress.com/category/icm/)
- Alexia Kyriakopoulos [Butterfly] (https://alpha.editor.p5js.org/projects/r1-MZYd3), http://www.alexiak.com/