Created
April 19, 2011 01:58
-
-
Save frostney/926660 to your computer and use it in GitHub Desktop.
This is a code snippet on how to implement achievements (as seen on Steam or XBox Live) in JavaScript games using DOM. It utilizes jQuery, HTML5 LocalStorage and some CSS3. This runs completely client-side, but it could easily be integrated into a Node.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
/* You may want to style this to your personal need */ | |
#status.achievement { | |
display: none; | |
position: absolute; | |
left: 50%; | |
bottom: -120px; | |
margin-left: -160px; | |
} | |
.achievement { | |
opacity: 1; | |
-moz-opacity: 1; | |
-webkit-opacity: 1; | |
-khtml-opacity: 1; | |
filter: alpha(opacity=100); | |
-ms-filter: "alpha(opacity=100)"; | |
border: 1px solid #fff; | |
background-color: #000; | |
color: #ddd; | |
border-radius: 18px 18px 18px 18px; | |
-moz-border-radius: 18px; | |
-webkit-border-radius: 18px; | |
-moz-box-shadow: 0px 0px 8px #cccccc; | |
-webkit-box-shadow: 0px 0px 8px #cccccc; | |
-ms-box-shadow: 0px 0px 8px #cccccc; | |
box-shadow: 0px 0px 8px #cccccc; | |
background-image: url(); | |
background-size: 64px; | |
background-repeat: no-repeat; | |
background-position: 6px 6px; | |
margin-left: 0px; | |
width: 320px; | |
height: 64px; | |
padding-left: 80px; | |
padding-bottom: 8px; | |
padding-right: 12px; | |
padding-top: 8px; | |
z-index: 30000001; | |
} | |
.achievement.locked { | |
background-color: #ccc; | |
color: #444; | |
} | |
.achievement .title { | |
color: #fff; | |
font-weight: bold; | |
text-shadow: 0px 0px 8px #eee; | |
} | |
.achievement.locked .title { | |
color: #444; | |
font-weight: bold; | |
text-shadow: 0px 0px 4px #888; | |
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
// Achievement "Singleton": Revealing module pattern | |
Achievements = function() | |
{ | |
//Private object "array" stores all achievements | |
var array = {}, | |
_localStorageKey, | |
initialize = function(localStorageKey) | |
{ | |
// Saves localStorage key internally | |
_localStorageKey = localStorageKey; | |
// Loads achievements from local storage if any | |
if (window.localStorage) | |
if ((typeof(window.localStorage[_localStorageKey]) != "undefined") && (window.localStorage[_localStorageKey] != null) && (window.localStorage[_localStorageKey] != "")) array = JSON.parse(window.localStorage[_localStorageKey]); | |
}, | |
register = function(text, description, icon) | |
{ | |
if ((typeof(text) !== "string") || (text === "")) return; | |
array[text] = { active: false }; | |
if (typeof(description) !== "undefined") array[text]["description"] = description; | |
if (typeof(icon) !== "undefined") array[text]["icon"] = icon; | |
}, | |
getCount = function() | |
{ | |
var count = 0; | |
for (var i in array) count++; | |
return count; | |
}, | |
getUnlockedCount = function() | |
{ | |
var count = 0; | |
for (var i in array) | |
{ | |
if (array[i]["active"]) count++; | |
} | |
return count; | |
}, | |
clear = function() | |
{ | |
// Reset active achievements | |
for (var i in array) | |
{ | |
if (array[i]["active"]) array[i]["active"] = false; | |
} | |
}, | |
list = function() | |
{ | |
// Locked achievements will be shown in a grey-ish color | |
var result = ""; | |
for (var i in array) | |
{ | |
if (array[i]["active"]) result += '<div class="achievement"><span class="title">' + i + '</span><br /><span class="details">' + array[i]["description"] + '</span></div><br /><br />'; | |
else result += '<div class="achievement locked"><span class="title">' + i + '</span><br /><span class="details">' + array[i]["description"] + '</span></div><br /><br />'; | |
} | |
return result; | |
}, | |
show = function(text) | |
{ | |
if ((typeof(text) !== "string") || (text === "")) return; | |
// If someone forget to register an achievement | |
if (array[text] === "undefined") register(text); | |
if (!array[text]["active"]) | |
{ | |
if ((typeof(array[text].icon) != "undefined") && (array[text].icon != "")) $('#achievement_box').css("background-image", "url(" + array[text].icon + ")"); | |
$('#status.achievement #text').html(text); | |
$('#status.achievement').show(); | |
$('#status.achievement').css({opacity: 0.0}); | |
$('#status.achievement').animate({opacity: 1.0, bottom: '8px'}, 750); | |
setTimeout(function() | |
{ | |
$('#status.achievement').animate({opacity: 0.0, bottom: '-120px'}, 750, "linear", function() { $('#status.achievement').hide(); }); | |
}, 5000); | |
array[text].active = true; | |
} | |
if (window.localStorage) window.localStorage[_localStorageKey] = JSON.stringify(array); | |
}; | |
return { | |
initialize: initialize, | |
getCount: getCount, | |
getUnlockedCount: getUnlockedCount, | |
clear: clear, | |
list: list, | |
register: register, | |
show: show | |
}; | |
}(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!doctype html> | |
<head> | |
<title>Achievement example</title> | |
<link rel="stylesheet" type="text/css" href="achievements.css" /> | |
<style> | |
html { overflow: hidden;} | |
body { font-family: Verdana,Arial,Helvetica; } | |
#list { | |
display: none; | |
background-color: #eee; | |
height: 240px; | |
width: 100%; | |
} | |
</style> | |
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.5.1/jquery.min.js"></script> | |
<script src="achievements.js"></script> | |
<script> | |
$(document).ready(function() | |
{ | |
Achievements.initialize('myGame'); | |
Achievements.register('I clicked a button', '...and I liked it'); | |
Achievements.register('Second button', 'This button is just for show.'); | |
}); | |
function toggleList() | |
{ | |
$('#list').toggle('slow'); | |
$('#list').html(Achievements.list); | |
} | |
</script> | |
</head> | |
<body> | |
<div id="content"> | |
<input name="Button1" type="button" value="Click for Achievement One" onclick="Achievements.show('I clicked a button');"><br /> | |
<input name="Button2" type="button" value="Click for Achievement Two" onclick="Achievements.show('Second button');"><br /> | |
<input name="Button3" type="button" value="Clear achievements" onclick="Achievements.clear();"><br /> | |
<br /> | |
<input name="Button4" type="button" value="List achievements" onclick="toggleList();"><br /> | |
<div id="list"> | |
</div> | |
</div> | |
<div id="status" class="achievement"><span class="title">Achievement unlocked</span><br/><span id="text">Some text</span></div> | |
</body> |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
You're a good man.