- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
In the end getting this live was a nightmare as I missed out some basic steps due to my unfamiliarity with server side programming but by slowly taking apart examples and experimenting with my code I was able to track down my bugs and get it live, which I'm really pleased with. so its now live on my openshift account with the name Twit Twock.
This visualisation works as a clock which shows a universal time unconnected to any real sense of time. the top row of circles represent the volume of tweet containing the word 'late' within 6 seconds, so the 10 of them make up 1min. The bottom row is the same but each circle represents 1 hour, there are 24 of them in total making up 1 day. The idea is that you are unable to use the clock to time the events in your life which feeds back into people communicating their frustration. And if no one feels late then the clock dose not display as no information is coming in. Given time you could learn to read a relative time from the clock by watching for trends which appear at different times of day, though thats not really the point. The whole thing is kind of pointless and self mocking
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I've now got it all working! but that's on my local machine. As i've been doing some research into how to get it online I think the easiest way is going to be by using some cloud based hosting. There is a large amount of different cloud hosts available but the one which stood out to me was OpenShift. This is a free service and I've found an article about using this in connection with Cloud9, a cloud ide. By using these two services my project will be fully cloud based!
- One comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I have found a Twitter api client for node called Twit this will allow me to access the Streaming api. As this is on the going to work on the sever side I need to have it talking to my client side js to do this I've been doing some reading (Manipulating JSON and XML with node.js, JSON Round Trip with node.js) and I'm going to use GET to pull a json file with the current amount of tweets from the sever. I will then be able to parse this file and set by count variable equal to it.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I wanted to get my Tweet faker working in node before I tried pulling in live information. Node.js has the ability to install little programs and libraries into your code which allow you to easily do a whole host of different things. One of these is called File System, or fs. With this you can do a load of different functions with your files what I was interested in though was the ability to alter the section of my server which controlled what to deliver to the user so that It would give a file instead of text.
I managed to figure out how to do this by changing the string which was delivered to a variable which was loaded with the file information from fs, here is an example of the code;
fs.readFile('./index.html', function (error, data) {
if (error) {
throw error;
}
index = data;
});
function start(response) {
console.log("Request handler 'start' was called.");
response.writeHead(200, {"Content-Type": "text/html"});
response.write(index);
response.end();
}
This is just the small section which delivers the html file to the rest of the code. Using this method I was able to get my sever delivering the html and js files so I had my fake tweet visualisation running. This method however runs multiple versions of my twitter api key so if I where to go live with this I would get banned. To stop this I need to migrate my code to the server then use JSON to request the variables
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
When it came to installing node I got a bit confused at first as something went wrong in the installation and it was not working like it was meant to. This lead me to trying to emulate Linix on my pc so that I could use the large amount of user documentation for it. However I final managed to get it installed on my pc after reading this tutorial.
Node.js is controlled through the CLI, command line interface, which looked scary at first but turn out to be very logical and simple to use. I came across and online book Node Beginner which was incrediably helpful, I ended up reading all of it. This book clearly explained how Node.js worked and how to build for it. Through reading that book and this article on Writing for node and the browser I was able to begin to understand the aims of server side programming.
I started off building a simple hello world server which simply writes hello world in the browser. I then worked through the examples in the node beginners book seeing how everything worked. Once I'd built its simple server which would communicate between pages I re wrote the whole thing myself to see if I could remember the correct structure and how to link everything. Doing this really helped me understand what I was writing.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
The code for my processing twitter counter was pretty simple so I decided that I could have a go at building a fake version using js. I chose to make it fake because I did not want to get into any of the complications for needing to access the Twitter api as I'm not sure what they will be and would like to know I can get the underlying structure working first.
Again I made strong use of comments in this project so that I could easily refer to it and understand what was going on. For the tweets I just made a simple random number generating function which I used inplace of a real number of tweets.
/*current bugs
- suspected memory leak with currentTime function, animates even outside of the loop
-growth is not smooth. potentially something with how Im looping through my draw.
*/
//global variables
var countDuration = 10, //seconds. However js dose use millis.
globalCount = 0,
pGlobalCount = 0,
cp = 0,
time = 0, //this will return a value in seconds
context,
SCREEN_HEIGHT,
counterAmount = 10,
nodeDistance = 0,
nTweets = 0,
timeReset = 0,
s = 0,
//create builder
Counter = (function() {
//builder variables
var countDisplays = [],
canvas,
SCREEN_WIDTH;
//initiate
function init() {
measureScreen();
currentTime();
//sets up DOM elements
canvas = document.createElement('canvas');
context = canvas.getContext('2d');
setCanvasSize();
document.body.appendChild(canvas);
//loads counters elements
createDisplays();
//Starts Loop
update();
}
function measureScreen() {
SCREEN_WIDTH = window.innerWidth;
SCREEN_HEIGHT = window.innerHeight;
}
function setCanvasSize() {
canvas.width = SCREEN_WIDTH;
canvas.height = SCREEN_HEIGHT;
}
function clearContext() {
context.fillStyle = "rgb(0,0,0)";
context.fillRect(0,0,SCREEN_WIDTH,SCREEN_HEIGHT);
}
//Tweet facker
function fakeTweets(frequency) {
var random = (Math.random()*10)+1;
nTweets++;
if( nTweets === frequency) {
globalCount += random;
nTweets = 0;
}
}
//caluculates which counter should be counting
function countPosition() {
if (currentTime() - timeReset === countDuration) {
//if (currentTime() % countDuration === 0) { //THIS IS BUGGED STICKS ON 4
timeReset = currentTime();
cp++;
pGlobalCount = globalCount;
}
if (cp === counterAmount) cp = 0;
}
//recursive function which increase time by 1 every second.
function currentTime() {
time++;
return (time/60).toFixed(0); //toFixed lets you round to X decimal places. in this case 0.
//setTimeout(startTime,1000);
}
///////////////////////////////////////////////////////
// COUNTERS
//renders the counters
function drawCountDisplays() {
//runs through all the counters in the array
for(i = 0; i < countDisplays.length; i++) {
var current = countDisplays[i];
// checks if the current array should be counting
if(i === cp) {
current.counting();
current.size = current.counting();
current.countRender();
} else {
current.countRender();
}
}
}
//populates an array with count displayers
function createDisplays() {
for(i = 0; i < counterAmount; i++ ) {
//xpos: {SCREEN_WIDTH / (counterAmount - i)};
//xpos++;
nodeDistance = SCREEN_WIDTH / counterAmount;
countDisplays.push(
new CountDisplay((i+0.5) * nodeDistance, 0));
}
}
// end of counters
///////////////////////////////////////////////////////
//DEBUG PRINTER
function debug() {
document.getElementById("globalcount").innerHTML= "Global Count = " + globalCount;
document.getElementById("pglobalcount").innerHTML= "Previous Global Count = " + pGlobalCount;
document.getElementById("countposition").innerHTML= "Counter Position = " + cp;
document.getElementById("timereset").innerHTML= "Time reset = " + timeReset + "sec";
document.getElementById("time").innerHTML= "Time = " + currentTime() + "sec";
}
function render() {
currentTime();
fakeTweets(25);
//createDisplays();
countPosition();
drawCountDisplays();
debug();
}
//the loop - I think This is a recursive function.
function update() {
clearContext();
requestAnimFrame(update);
render();
//fakeTweets(25);
//countPosition();
//drawCountDisplays();
}
//api
return {
init: init
};
})();
// Constructer for Count Display Objects
function CountDisplay(xpos, size) {
this.size = size;
count = 0;
//counts the amount of tweets
this.counting = function() {
count = globalCount-pGlobalCount;
return count;
}
//draws the counter based on the amount of tweets
this.countRender = function(){
context.fillStyle = 'rgba(255,255,255,0.5)';
context.beginPath();
context.arc(xpos, SCREEN_HEIGHT/2, this.size, 0, Math.PI * 2, true);
//context.arc(xpos, 200, 50, 0, Math.PI * 2, true);
context.closePath();
context.fill();
}
};
//starts code
window.onload = function() {
Counter.init();
};
Its steadily getting more and more complicated! and I've not even started on the web sever. This took a little more work as I had a few simple bugs which due to how new I am to JS I couldn't spot. There are still some bugs in this any way, as you can see from the top line. I have not put this online but here is a screen grab of it in action
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I've never done any JS before for I decided a good way to start was to do some of the examples from the website Codecademy so that I could see how the structure of things such as arrays and variables where in JS. In total I did a little over 100 exercises on the site covering the basics and object oriented programming.
Alongside this I also downloaded some example projects from CreativeJS by Paul Lewis and Seb Lee-Delisle. I thought it would be a good idea to look at Seb's coding as he taught me everything I know about programming so far so it might have similarities in the structure and approach to it. I looked thought these projects and tried to look for the various section that appear in processing such as the draw loop and the setup, by doing this I was able to understand the structure of JS. Through doing this I was introduced to some new concepts such as DOM, Document Object Model, and a better understanding of API, application programming interface.
I wanted to start off really simple, so instead of building twitter counter straight away I build a simple bouncing ball in js. I made sure that I hand wrote everything so that I would be able to spot when I made mistakes and would actually be learning. I also made sure to comment my code so that I would understand what every section was doing.
//load up my bounce class
var Bounce = (function() {
var canvas = null,
context = null,
SCREEN_WIDTH = 0,
SCREEN_HEIGHT = 0,
//ball variables
xPos = 500,
yPos = 500,
xVel = 10,
yVel = 9,
radi = 50;
// init the code
function init() {
measureScreen();
//creates DOM elements
canvas = document.createElement('canvas');
context = canvas.getContext('2d');
setCanvasSize();
document.body.appendChild(canvas);
//StartsLoop
update();
}
function measureScreen() {
SCREEN_WIDTH = window.innerWidth;
SCREEN_HEIGHT = window.innerHeight;
}
function setCanvasSize() {
canvas.width = SCREEN_WIDTH;
canvas.height = SCREEN_HEIGHT;
}
function clearContext() {
context.fillStyle = "rgba(255,255,255,1)";
context.fillRect(0, 0, SCREEN_WIDTH, SCREEN_HEIGHT);
}
// draws bouncing ball
function draw() {
xPos += xVel;
yPos += yVel;
// x cordinate bounce
if (xPos > SCREEN_WIDTH - radi) {
xVel *= -1;
xPos = SCREEN_WIDTH - radi;
}
if (xPos < radi) {
xVel *= -1;
xPos = radi;
}
// y cordinate bounce
if (yPos > SCREEN_HEIGHT - radi) {
yVel *= -1;
yPos = SCREEN_HEIGHT - radi;
}
if (yPos < radi) {
yVel *= -1;
yPos = radi;
}
context.fillStyle = 'rgb(200,255,200)';
context.beginPath();
context.arc( xPos, yPos, radi*2, 0, Math.PI * 2, true );
context.closePath();
context.fill();
}
//Loop
function update() {
clearContext();
requestAnimFrame(update);
draw();
}
//api
return {init: init};
})();
//start my code when window opens
window.onload = function() {
Bounce.init();
};
I have put a live version on my site. As you can see its a little buggy but I'm pretty happy with how it turned out and learn a lot writing it. The project runs in html5 using the jS to put the canvas element in the html when the page loads, this is so it will be full screen regardless of screen size.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I was quite keen with this project to use it to enable me to learn JavaScript. It had been my intention to recreate my processing project in JavaScript before I found out about the repeat api use issue. Now however I have found out about Node.js which is defined on their site as,
Node.js is a platform built on Chrome's JavaScript runtime for easily building fast, scalable network applications. Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and efficient, perfect for data-intensive real-time applications that run across distributed devices.
This is perfect for what I want to do as it will all be in JS so that I can spend more time learning it and it will enable me to have my api section running server side.
Node.js looks really advanced however so I'm going to start by learning some JS and then porting my existing processing prototype to JS.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
After doing some more reading about the Twitter streaming api I came across a paragraph which I had not noticed before.
Each account may create only one standing connection to the Streaming API. Subsequent connections from the same account may cause previously established connections to be disconnected. Excessive connection attempts, regardless of success, will result in an automatic ban of the client's IP address. Continually failing connections will result in your IP address being blacklisted from all Twitter access.
The impact of this means that I can not have each user run a version of my code otherwise I would be running multiple connections and would risk an automatic ban. There is the possibility of using a 'site stream' though you have to apply for this and I do not want to waste time waiting to see if I'll get one.
The way around this is to have my code running on a websever which is always active which then users request the information from when they visit the site. I like this as it lets me follow my idea of the site as an object. However I've no idea about server side programming so I need to do some research.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
Currently I know that I want my visualisation to be delivered online but I'm not sure what I'm going to build it with. However to understand the processes involved I've decided to mess around with processing and the Twitter api.
There is a Java Libary which I found on a blog post by Jer Thorpe called Twitter4j which will let me access the twitter api. I created my api key by going to the developer section of twitter then messed around with some code I found so that I could understand what each of the sections did.
The first project uses the twitter search api. It was built by going through this Jer Thorpe tutorial then modding the code slightly.
This project searches a given time period for a random sample of X tweets containing Y, in this example X is 10 and Y is "Sleep".
The search api is good but it only gives you access to existing tweets not ones which are coming in live for this I need to use the streaming api.
I found an example by Michael Zick Doherty of using Twitter4j to access the streaming api and display images when they come in on a chosen subject. By looking at this and decompiling the Twitter4j library so I could understand its structure and how the classes worked.
With this knowledge I was able to write a prototype that I could increment a variable when ever a tweet came in. Once I had this I was able to create a display which would show this amount over time. One thing which was really useful while building it was to create a little debug panel which I could look at the amounts in my current variables and spot if there where any errors.
//Search term
String keywords[] = {"breakfast"};
//Global variables
int countDuration = 60000; //how long before the counter moves on (in miliseconds)
int globalCount;
int pGlobalCount; //previous global count value
int cp = 0; //counter position
float time = 0;
TweetCount[] tweetCount = new TweetCount[59]; //amount of bits of data to collect
TwitterStream twitter = new TwitterStreamFactory().getInstance();
// Twitter API variables
static String OAuthConsumerKey = "XXXXXXXXXXXXX";
static String OAuthConsumerSecret = "XXXXXXXXXXXX";
static String AccessToken = "XXXXXXXXXXXXXX";
static String AccessTokenSecret = "XXXXXXXXXXXXXXXXXXXXX";
//////////////////
//////////////////
void setup() {
size(1000, 400);
noStroke();
imageMode(CENTER);
smooth();
connectTwitter();
twitter.addListener(listener);
twitter.filter(new FilterQuery().track(keywords)); // This is where my filters come into the code
for(int i=0; itweetCount[i] = new TweetCount();
}
}
void draw() {
background(0);
debug();
CountPosition();
for(int i=0; ifloat xpos = map(i, 0, tweetCount.length, 0, width);
tweetCount[i].render(xpos);
}
tweetCount[cp].counting();
}
// Initial connection
void connectTwitter() {
twitter.setOAuthConsumer(OAuthConsumerKey, OAuthConsumerSecret);
AccessToken accessToken = loadAccessToken();
twitter.setOAuthAccessToken(accessToken);
}
// Loading up the access token
private static AccessToken loadAccessToken() {
return new AccessToken(AccessToken, AccessTokenSecret);
}
// This listens for new tweet
StatusListener listener = new StatusListener(){
public void onStatus(Status status) {
//println("@" + status.getUser().getScreenName() + " - " + status.getText());
globalCount++;
}
public void onDeletionNotice(StatusDeletionNotice statusDeletionNotice) {
//System.out.println("Got a status deletion notice id:" + statusDeletionNotice.getStatusId());
}
public void onTrackLimitationNotice(int numberOfLimitedStatuses) {
// System.out.println("Got track limitation notice:" + numberOfLimitedStatuses);
}
public void onScrubGeo(long userId, long upToStatusId) {
System.out.println("Got scrub_geo event userId:" + userId + " upToStatusId:" + upToStatusId);
}
public void onException(Exception ex) {
ex.printStackTrace();
}
};
void CountPosition() {
if(millis()-time >= countDuration) {
time = millis();
cp++;
pGlobalCount = globalCount;
}
if (cp==tweetCount.length) cp = 0; //counter postion reset
}
void debug() {
text("globalCount =" + globalCount, 20, 20);
text("pGlobalCount =" + pGlobalCount, 200, 20);
text("CountPosition =" + cp, 20, 40);
text("time =" + millis()/1000, 20, 60);
}
class TweetCount {
int count;
int countreset;
TweetCount() {
}
void render(float xpos) {
fill(255,100);
ellipse(xpos, height/2,count,count);
fill(255);
text(count, xpos, height/2+70);
}
void counting() {
count = 0;
count = globalCount-pGlobalCount;
//println("count =" + count + " globalCount =" + globalCount + " pGlobalCount =" + pGlobalCount);
}
}
At this stage I am happy with my knowledge of how the code side of it works I just need to look into how I will make this available online
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I've now settled on a new idea. I got a little lost thinking about interesting ways in which I could use images from Instgram. I did want to create a site which would show images of what people are eating in real time based on the images coming in from Instgram (I may still try build this sometime as it sounds like a fun project). Now though I've decided that I'm just going to draw my data from twitter.
The basic idea is that I want to create an abstracted real time clock based on people talking about lateness on twitter. Hopefully this will produce an interesting clash of ideas. I am still keen on it being created for a gallery space but I also want it to be accessible online so that, like the data its based on, it's not spatially limited.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
Glitchhiker was the winner of the 2011 Global Game Jam NL. Its a simple game with a fantastic mechanic, the game can die. Infact it is already dead. The game works by having a global life count, starting the game uses a life and collecting 100 coins gains a life. Once the lifes reach 0 the game is no longer playable or downloadable so it dies!
This is quite a similar concept to what I picked up from Iain M banks. I think it would be really interesting to build a world from data which only develops based on if people are using it. I can picture this in a few forms;
- A virtual world which grows over time as it is viewed at a speed based on the amount of people viewing it. If no one or a limited number of users are viewing it then it will degenerate with time until its being watched again.
- A generative narrative animation which progresses when ever someone is viewing it so that if you come back to it you will miss parts of it. This would work really well if it was a 24 hour loop so it would encourage people who are interested in the story to visit regularly so that they can know where they are within the story and then catch up. This would need a story which did not depend on traditional narrative structures, such as the Golden Notebook by Dorris Lessing
This kind of approach also in this idea I was talking about previously in my blog about treating the website like a real thing which has a life away from the user. This contrasts with the classic view of it being a portal to dispense information.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
Well I have written a few notes in my sketch book based on a new idea of displaying some form of life data online. As they are in my personal sketchbook like before I'm going to upload them here as I will still need to use my sketchbook! I also played around with some different ideas here as well.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
After talking to my tutors about my idea they did not think that I would be able to get enough data to realise my idea in a worthwhile way. They suggested that I use my strong interest in data and switch to using a data set which I do not have to create myself such as Twitter or Instagram to base my idea on. They also think that I should draw on some of the ideas from my dissertation, which talks about lifelogging and the increase of data about a users life which is being gathered and made available online.
I was quite excited about building this visualisation but I do agree with my tutors about this idea not being something which I have the resources to create at the moment. So now I've got to think of a new idea!
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
As I would like to build some form of device to feed data to my visualisation I have order myself an Arduino Uno. But until that arrieves I throught it would be a good idea to see if I could build a quick prototype in processing which would graphically display the volume of a mic input. I decided to ignore the web limitations for now as I had no idea how easy it would be to put together.
I used Minium, a sound library for processing. Which I discovered records the volume from the left and right channel with a value between 0 and 1. This meant that with a very small amount of code I was able to create a simple visualisation which changed the colour of a circle based on the volume.
// load libaries
import ddf.minim.*;
// minium vars
Minim minim;
AudioInput input;
void setup(){
size(500,500);
smooth();
noStroke();
colorMode(HSB);
minim = new Minim(this);
input = minim.getLineIn();
}
void draw() {
background(0);
fill(volume(),255,255);
ellipse(width/2,height/2,100,100);
println(input);
}
float volume() {
return(input.mix.get(1)*1000);
}
void stop(){
input.close();
minim.stop();
super.stop();
}
even with something simple like this if you where to have a large amount of them positioned relative to there location you would get a really interesting image
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
When looking for inspiration on the potential forms which my sound data could be displayed in I came across these abstracted literal tube maps at Line Posters.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I found an example of a great little web based visualisation. Color Forecast shows what people are wearing in key fashion capitals around the world in real time. Its has been made by an online clothes retailer and will suggest what clothes you should wear to go with the city. It also shows a little bit of the history of the data and shows its process.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I was not under the impression that my idea was completely new but I was not aware of any examples. That was until I read a line In Emotional Geographies, a book I've been reading because I think I'm aiming to visualise an emotional geography of the noise of life. The line was about the desire to "decouple diological and military concers" which made me think of a machine they build in The Dark knight which make a large sonar real time map of the city from the sound provided through mobile devices... pretty much a literal visual version of what I wanted to build. Incase you have not seen the film here is a clip
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
When I was imagining how a visualisation of location mapped sound might look the work of Aaron Koblin came to mind. In particular one project which he creates a visualisation tool for SMS messages in Amsterdam,
The video really shows the patterns which appear in this style of data. It looks almost like bar charts but they are mapped in 3d space. I would like to create a 3D space within the website which could be explored by the user so that they can focus on the section of the data they are personally interested in
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
At this point I thought it would be a good idea to review my idea and try and finally settle on a project which I can start creating. So I discussed the ideas through with my mum, Sarah Scaife. We go to the point that pushing on with the idea of data was my best bet as I already have some of the skills needed to do this and would not be starting from scratch like I might where I to build a physical object manipulated by the internet.
Like how the hint.fm wind map using pubicaly available data I thought it would be a good idea if I used data which as already accessible as that brings its own potential interpretations to the piece. So I had a look on the Uk open goverment data. However I looking at what was available nothing jumped out at me as being a really interesting direction to go with.
When Thinking of the variables available to me I got quite interested in sound. So at this point I decided that I would like to create something similar to the wind map but using sound data from specially build devices. The idea being that with ubiquity of devices which record sound you would be able to tell a large amount of things from this data. One example would be that you could find out how busy a cue for a club was from the amount of volume coming from outside it.
I really like this Idea and I'm going to go with it. I think that with clever application of what I'm displaying and recording this could produce a nice piece.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I am still interested in the uses of data so decided to look more into data visualisation to see how those ideas could spread through into my work. While doing this I came across a visualisation of the wind in the USA by Hint.fm. I This this is a great idea and is really nicely executed.
I can really imagine the map being displayed in a gallery space. It scrapes its information every 30mins but stays dynamic and engaging with this way in which it displays its data. They also show information about visualisation alongside it which I think works well when seen over a website but if this were in a gallery I would like to only see the map.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I have had quite a few idea on different things which I would like to produce so far which you can see in the pages on my sketch books. They mainly revolve around creating a digitally controlled object. My ideas so far are:
- To create a gallery piece where two crt monitors displaying faces are set facing each other. People would be able to visit a website and take control of one of the monitors in order to have a conversation with people using the other monitor. The aim would be to create a way in which people can engage in "real" conversation digitally. It would try to explore ideas around privacy and our concepts on communicating over time. I could sum it up really basically by saying its annomous skyping with random people while others watch in a real location.
- To hack a type writer so that it would create a physical copy of digital tweets.
- To create a multiplayer web game where the course which the players act within is controlled by a physical object presented in a public or gallery space. A quick way in which I though of this working was to make a version of Astroids where instead of destroying Astroids the players work together to destroy objects which people using the physical gameworld controls are creating.
- As above but instead of generating a game it would create some form of dynamic art piece which could be both projected within the space and viewed online.
- I also thought of reversing the roles between online and physical space by creating some form of projection which online players could attack and distort, therefore having a direct impact on the work on display.
With this ideas I am quite worried that after looking at some Arduino tutorials and thinking about how I could go about creating them that I might be very technically challenging.
I spoke with one of my tutors about the first Idea and he was interested in the direction it was going but felt like it could be pushed even further. He suggested that I could play on the idea of control and dominance by altering the size and positions of the displays so to users it feels like one of them is "stronger".
Alot of these ideas have a common theme of a tangible web based element which is the same to all who are viewing it. I think this is really interesting and I plan to explore this idea more.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I want to look at this project from a nostalgic sci-fi perspective. With that in mind I thought a good way to build up more of an opinion on my perceptions of this would be to read some old sci-fi literature. I got 3 books from my local 2nd hand book store,
- Ender's Game by Orson Scott Card
- Burning Chrome by William Gibson
- The State of the Art by Iain M. Banks
Burning Chrome
This was the first book I got. I chose it because I have previously read Neuromancer and it had just the sort of feel I was going for. Also as Gibson invented the word cyberspace I thought he was bound to have the sort of ideas I was thinking of.
The book is a collection of short stories covering a wide range of topics. They have strong cowboy like male characters and the worlds come across as being really rough. There are a lot of dark themes throughout the stories and you can see that I wrote in my sketch book DOUBT in big letters and this was a recurring emotion I thought was coming from the characters.
As for the Technology It was all pretty advanced. There where some interesting descriptions about the UX of the users,
"A silver tide of phosphenes boiled across my field of vision as the matrix began to unfold in my head, a 3-D chessboard, infinite and perfectly transparent. The Russian program seemed to lurch as we entered the grid."
The description all seem really physical and as if you could feel them using words such as 'boiled' to explain movement. He also uses the acronym ICE which brings more feelings to mind when you imagine it. By talking about the physical effects on the users, such as sweating, it really sounds like an intense experience. While it would be very hard brining in this sense of something digital being felt and having an impact on your real world experience would be a really nice quality to build into my project.
Enders Game
I got Enders Game as it was a book which I had hear good things about but never read. I didn't really know what to expect but I ended up really enjoying it. *Spoliers* It's basically an account of how a future society groom a young boy to be able to wipe out a whole race of intelligent aliens. Parts of the book talk about Enders siblings who use the anonymity of the internet to influence political ideas of peoples and nations.
The technology was not a massive part of this book. Though I may think this because the visions of the technology are slightly more extreme versions of devices we have now. One of the main pieces if a 'Desk' which is essentially a large iPad with an app on it which is based on the users brain signal. I quite like its method of punishing the user for failing tasks. On each progressive fail the game sets you further back within the level (its more like a continuos world). This would be really irritating to play and think it would be interesting making a very difficult game designed to frustrate the user which makes use of this.
The State of the Art
This was defiantly the most surreal of the books I read, with stories such as an astronaut landing on a planet which has intelligent plant based lifeforms who then pluck his limbs off! It is another collection of short stories. At first I didn't like them as they have odd amounts of non human lifeforms in them, and some have weird structures.
The stories point out alot of pointless self destruction. Which I think is quite an interesting thing to highlight it would be nice if my project could deliberately damage itself. Again I don't think the technology is key in these stories, its about the conscious effect of the power they bring and the relationship which build up between the user and the device. These are powerful themes when it comes to trying to explore new areas within digital design but they do no themselves suggest a device or object to be created.
From reading these books I've learn't that whats going to make my project work is keeping it grounded in human experience and emotions. Doing so will allow people to empathise with what I create.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I have been using my personal note book as a sketch book for this project so far so I decided that I would upload the notes and ideas I have had so far.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I've found some interesting methods of repetitive drawing. I was drawn to these by there mechanical process and the idea that this is something which could make use of an Arduino. Found on Brain pickings
I Think it would be really interesting to produce something physical in real time from digital information and building a device or adopting mechanical processes would allow me to explore this.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
Makego is an interesting iPhone app which is a step on the way towards blurring the boundaries between physical and digital play.
While I don't think this takes it very far It is an interesting idea and one which I know I would have loved when I was a kid. I also think its quite significant that something which is design for potential rough play from younger kids has been make for iPhone an expensive piece of kit which potential has a large impact on its owner if its broken. I also like that it creates yet another potential use for a mobile far beyond the original ability to talk on the phone while away from a landline.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
As I've already laid out I'm interested in looking at digital technologies from a sci-fi perspective, so I thought I may as well listen to sci-fi music while I work as well. So I've been listening to the Bladerunner soundtrack online, Its pretty good! If my piece ends up using audio I can draw inspiration from this as it really communicates the scenes and emotions both in the film and within sci-fi literature.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
While looking for interesting angles I can take on this project I have still been keeping an eye on interesting new technologies. One which really excited me was a bbc article explaining using conductive ink to produce paper posters which can play music!
While this sort of technology is out of my reach in terms of something which I could produce for this project I really like the concept of combining traditional means of communication in a way which either doesn't alter the appearance of the one of original projects or takes it into a new object.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I first heard of Hellicar & Lewis in the elevator pitch at flash on the beach. They make really interesting interactive digital pieces. There work gets displayed in galleries and shows good foundations for the future possibilities of digital art. One of there pieces The Hello Wall was a large outdoor projection which should change in response to users tweets.
The piece is very simplified in this form but due to the user interaction has an endless amount of outcomes. They did develop the concept further with The Hello Cube which was at the Tate Modern at the end of march.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
A few years ago I went to OFFF in paris. The theme for that years conference was "Nostalgia for a Past Future" which I though was a really interesting idea. By looking at this project from a sci-fi prospective I hope to bring is a feeling of this past vision of the future. Recently The Guardian posted an image which sums up some of utopian thinking which used to happen in reguards to the future.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
Some one was tweeting about the flash game You Have to Burn the Rope. I played it through and its really great I suggest you go and play it now before you carry on reading.
The game is more of a comment about current flash game development than a game. Its a bout the process of playing to the end of something with a majority of the enjoyment coming from the ending credits of the game. The game takes 3 mins and only one of those is gameplay.
I felt this was relevant to post as it manages to communicate its message and stay engaging while still being very short. I want my piece to be able to communicate its purpose very quickly.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
Niklas Roy is a digital artist I came across who makes a wide range of strange digital objects. His work play with a mix of traditional technologies and futuristic ideas. One of my favorite works by him is the Electronic Instant Camera.
My ‘Electronic Instant Camera’, is a combination of an analog b/w videocamera and a thermal receipt printer. The device is something in between a Polaroid camera and a digital camera. The camera doesn’t store the pictures on film or digital medium, but prints a photo directly on a roll of cheap receipt paper while it is taking it. As this all happens very slow, people have to stay still for about three minutes until a full portrait photo is taken.
This piece reminds me lots of a modernday version of a dry plate camera. I really like how it takes a long time to generate the image and its not stored so that unlike how I would use a camera with my friends, by taking a load of photos and picking the best, you have to think much more about the composition and just be content with the image if there are imperfections.
The way it builds up in lines also makes me think about the possibilities for collaborating and having multiple people each take one line each like the drawing game children play.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
While looking for more information about what is possible with an Arduino I found this series of tutorials by electrical engineering major Jeremy Blum, which has 5 hours worth of videos!
This first video of the series is a good introduction and he links to some of the projects he has made which has some really exciting examples. The interesting thing about the linked projects being Arduino based is that they will always produce a real object.
one of his examples he linked up web data to a LED which it self is not that impressive but it has the same principle of the remote control cafe. I could for example make some moving sculpture which changes state bases on online information.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
A few months Kauko came up in my rss reader and it was what sparked my interest with the ability for digital technologies to have a direct impact on real world spaces.
One of the things that stuck out about this is that you could move objects through the internet. It changed the concept of the internet as being for consumption as to something which could be used for direct physical action. While it was active I had a go with it and it feels really funny being able to see live reactions to your actions, knowing that you are completely anonymous to those involved.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
The Raspberry Pi has recently been released. It is a working computer which can run linux, is very very small, and very cheap. This is a very popular piece of equipment and with only a limited number available and demand spiking at 700per second it may be quite hard to get my hands on one.
This piece of technology is really exciting as it would allow me to have computational power within an object. It is able to run of battery power so using this I would be able to have a wireless object which could communicate with a web based service.
Another micro computer is the Arduino. This is not a fully working computer but a device which lets you have real world inputs and outputs.
Connecting an Arduino with a raspberry pi quickly opens up a large amount of possibilities for creating interactive objects. You can control an Arduino with processing which has a good community for support. I also found Element 14 which is a community of people interested in computer science. I am anxious that building an interactive object of this sort requires quite a few skills which I do not have so it seems quite ambitious.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
As part of our project we are required to create a document outlining out intentions on what we will produce, its pretty much a brief.
I have intentionally kept my brief really open. I'm interested in the ideas and processes of digital technology and want to explore the possibilities some more before I decide exactly what I will produce. That said I have limited myself to producing an object. I want to look at the boundaries between a physical and digital reality. This is potentially a bad idea as when I'm doing research and thinking of idea I already have a desired outcome so they have to be able to fit that.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
Initially I wanted to do do the completely separate project but after reading them a few timing I was really draw to the Donner Haraway quote,
"By the late twentieth century, our time, a mythic time, we are all chimeras, theorized and fabricated hybrids of machine and organism; in short, we are cyborgs"
This quote express a thought which I have had while doing the reading for me dissertation. Our increasing reliance on digital technologies is changing what it means to a human and it can be argued that we are or will soon be cyborgs.
A quote I picked up from my dissertation readings from a book titled Bioethics in the age of new media by Joanna Zylinska
""Organisms respond to their environment in ways determined by their internal self-organization. Their one and only goal is continually to produce and reproduce the organization that defines them as a system. hence, they not only are self-organizing but also are autopoietic or self-making... In a sense, autopoiesis turns the cybernetic paradigm inside out. It’s central premise - that systems are infomationally closed- radically alters the idea of information feedback loop, for the loop no longer functions to connect a system to its environment. in the autopoietic view, no information crosses the boundary separating the system from its environment. We do not see a world “out there” that exists apart from us. Rather, we see only what our systemic organizations allows us to see that environment merely triggers changes determined by the system’s own structural properties. Thus the center of interest for autopoiesis shifts from the cybernetics of the observed system to the cybernetics of the observer. Autopoiesis also changes the explanation of what circulates through the system to make it work as a system. The emphasis now is on the mutually constitutive interactions between the components of a system rather than on message, signals or information." (Katherine Hayles)"
what I like about this is the idea of the roles of observation, and the selfish self replicating existence which can not look beyond its means. Though this is missing the point and it's not at all doing so, I like the idea that digital technologies are extending our existence and allowing us to do things that we cannot do unaided.
The initial quote has also inspired me to go and read some more science fiction as they are concerned with cultures where technology or external situation have altered human experience.
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
We have now been given our brief for the final project of our degree. This one makes up 1/3 of our total mark so the pressure is on. Here is the brief:
Students are asked to choose one of the quotes as a starting point, or to do an independent project totally of their own choice, and formulate a brief, indicating possible avenues they may wish to explore.
This is registered with the Course Leader and constitutes ‘Part One – Proposal’ form (300 words + reading list), which must include a reading list submitted by you.
‘Part Two – Project Review’ (500 words) is submitted by the students at the end of the module. This review document is self-evaluative in nature and is intended as a tool for you to review the final projects’ intentions and conclusions, alongside all research work and the final project execution. Please choose from one of the following options
- “It is a truism to day that we live in a “remix culture.” Today, many of cultural and lifestyle arenas - music, fashion, design, art, web applications, user created media, food - are governed by remixes, fusions, collages, or mash-ups. If post-modernism defined 1980s, remix definitely dominates 2000s, and it will probably continue to rule the next decade as well. Manovich, Lev. What comes after Remix?
-
“We live in a world where there is more and more information, and less and less meaning.”
Jean Baudrillard, Simulacra and Simulation -
“To practice space is thus to repeat the joyful and silent experience of childhood; it is, in a place, to be other and to move toward the other...Kandinsky dreamed of: 'a great city built according to all the rules of architecture and then suddenly shaken by a force that defies all calculation."
Michel de Certeau, The Practice of Everyday Life -
“...Fan fiction is a way of the culture repairing the damage done in a system where contemporary myths are owned by corporations instead of owned by the folk.”
Henry Jenkins -
“This is the postmodern desert inhabited by people who are, in effect, consuming themselves in the form of images and abstractions through which their desires, sense of identity, and memories are replicated and then sold back to them as products”
Larry McCaffrey -
“Do stuff. be clenched, curious. Not waiting for inspiration's shove or society's kiss on your forehead. Pay attention. It's all about paying attention. attention is vitality. It connects you with others. It makes you eager. stay eager.”
Susan Sontag -
“By the late twentieth century, our time, a mythic time, we are all chimeras, theorized and fabricated hybrids of machine and organism; in short, we are cyborgs.”
Donna J. Haraway - A project of your choice (you may want to use a different quote as a starting point, or it could be something completely different).
- Leave your comment • Category: Project 5: Independent Project
- Share on Twitter, Facebook, Delicious, Digg, Reddit
After the feedback that I should have another Squib in here I decided to go and get a more cultured quote. I chose to use this one "Music is about listening, the more you play, the more the magic spreads." Maynard James Keenan, I think this expresses what Spotify on Facebook aims to do. Below is the version which I submitted to D&AD
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
you can find the final submission video here. My tutor watched this and suggested that I have a squib playing right at beginning so I will make these changes before the D&AD submission there are also a few bugs in the video which I didn't get change to change.
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
For the backing music to my video Simon linked me to a site he had found which had links to royalty free music. (http://www.weave-creative.co.uk/general/royalty-free-music-for-showreels/) after looking around I managed to find a neutral song which was not overpowering.
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I wrote the script and storyborded by homepage video then started building it. But I was not happy with how it was looking for decided to shelf it for a few days until I had a clear vision in my mind of how it would fit into the final video. however when I came to writing the script for my final video I found that it was going to take me around 2 mins to demo the product and thats the time limit that my video has so I've decided to drop the homepage animation from my submission. you can see my initial steps here
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I've posted a load of step by step designs of my pages so far and I've not done the designs for my 2nd and 3rd pages however I had a much clearer picture in my head when I approached these pages so it didn't develop that much from my initial sketches as I created them. I'm just going to point out a few key features and show the designs.
Page 2
This is the section where you create your squib. I tried to keep it clean and clear by splitting it into clear steps. For the icons I adapted ones currently used within Spotify in order to tie the design in with the brand. the content box and buttons have the rounded corners which Spotify uses on there websites. The squib entry box also has the familiar corner extension design to show that you can increase the size of the box. there is a character count down as well to show how many characters you have remaining.
Page 3
I've just got a placeholder image in for the youtube video at the moment. The enjoy text will only appear once the user has clicked share. This is to enable the site to have a call to action after engaging with its main function. I chose to link back to the friend activity section I had seen on the Spotify Facebook page as that is a nice place to see how your friends are also engaging with the app.
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
Here I have adapted the home page to display on a Facebook tab. I also created a little icon for the app. On the Facebook page I have chosen to no display the video and just have it go straight to begin as users will only access the app through the Facebook page once they have already created a squib.
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
Having looked at some more inspiration and gotten feedback on my home page I decided to do a slight re-design of my home page. Below is my design process;
All the type was hand drawn by me and I would quite like to turn it into a full font to publish for free if I can find time
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
For the text of my squib I wanted to have a popular or funny tweet but when I looked in a few places, such as top tweets and funny status I could not find anything suitable. Instead I decided to take insperation from the videos I've watched which talk about the situation you would be in when you use the app. So I'm going to make a squib that someone would send if they where actually using Squibify.
After trying to think something up I came across this status update which I think would be great,
Do you realize that in about 40 years, we’ll have thousands of old ladies running around with tattoos?
in order to make it work I changed it to the following:
In 40 years, you'll be a little old lady running around with tattoos
To make the squib I used Lyricfinder and seatched for the words I needed.
Here are the song I took the words from.
- alicia keys fallin 0:14
- the phoenix foundation 40 years 1:33
- neild dimond girl, you'll be a woman soon 0:03
- beach boys little old lady 0:12
- superstars & madvilli running around with another 1:13
- warren tattoos and cigaretts 0:14
Here is what it sounds like when I stitch them all together.
My coursemate Simon suggested that I use a more cultured quote which I think is a good idea and if I have time to make another I will hunt brainyquotes like he suggested.
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
I got some feedback that my character was needed some work, in the teeth and hat! so I decided to go and look for some more inspiration.
One key place is a blog I follow called Ten Paces and Draw where they post some great examples of illustration.
I also looked at some other app sites for inspiration. Go Live! really inspired my design they use a really minimal design so you can go straight into using the app.
I also noticed Spotify currently has an character illustration style which is visible in these two videos.
I've decided that I am going to completely ditch my character and instead use the Spotify style. Also these have rounded corners like I had already decided to have on my home page video
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
For the video on my home page I have been looking for some inspiration at other online app and sites which have a welcome video.
There are some nice examples of these two pages. One of the key things with animation is that you can do interesting transitions which explain the story.
http://www.spotify.com/uk/about/what/
http://wufoo.com/
This animation explains creative commons
I really like the motion graphics in this piece and I find it very inspiring, I would like to try and capture lots of little details in my animation.
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit
After getting feedback from my class and tutors and doing some sketches I decided that my idea for the logo was too complicated so I have chosen to go with a static design which encorporates part of the existing Spotify logo and colours. I built this in Illustrator by hand starting from sketches I had done in my sketch book. Here are the steps I took to design it.
- Leave your comment • Category: Project 4: D and AD
- Share on Twitter, Facebook, Delicious, Digg, Reddit