<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Núvols Gratis! &#187; Programació</title>
	<atom:link href="http://nuvolsgratis.cat/category/programacio/feed/" rel="self" type="application/rss+xml" />
	<link>http://nuvolsgratis.cat</link>
	<description>Cumulunimbus, cirrus i altres parides estratosfèriques</description>
	<lastBuildDate>Mon, 20 Dec 2010 17:56:20 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	
		<item>
		<title>Com fer una pàgina amb múltiples idiomes amb PHP i AJAX</title>
		<link>http://nuvolsgratis.cat/com-fer-una-pagina-amb-multiples-idiomes-amb-php-i-ajax/</link>
		<comments>http://nuvolsgratis.cat/com-fer-una-pagina-amb-multiples-idiomes-amb-php-i-ajax/#comments</comments>
		<pubDate>Tue, 28 Sep 2010 16:26:02 +0000</pubDate>
		<dc:creator>Marc</dc:creator>
				<category><![CDATA[Programació]]></category>
		<category><![CDATA[AJAX]]></category>
		<category><![CDATA[PHP]]></category>

		<guid isPermaLink="false">http://nuvolsgratis.cat/?p=325</guid>
		<description><![CDATA[Una visita a la wiki de Foros del Web dóna com a resultat aquesta petita troballa: com fer una web amb múltiples idiomes amb PHP i AJAX.]]></description>
			<content:encoded><![CDATA[<p>Una visita a la wiki de Foros del Web dóna com a resultat aquesta petita troballa: <a href="http://www.forosdelweb.com/wiki/PHP:como_crear_una_pagina_de_varios_idiomas">com fer una web amb múltiples idiomes amb PHP i AJAX</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://nuvolsgratis.cat/com-fer-una-pagina-amb-multiples-idiomes-amb-php-i-ajax/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Com afegir un comptador de reproduccions a jPlayer</title>
		<link>http://nuvolsgratis.cat/com-afegir-un-comptador-de-reproduccions-a-jplayer/</link>
		<comments>http://nuvolsgratis.cat/com-afegir-un-comptador-de-reproduccions-a-jplayer/#comments</comments>
		<pubDate>Sun, 26 Sep 2010 16:07:27 +0000</pubDate>
		<dc:creator>Marc</dc:creator>
				<category><![CDATA[Programació]]></category>
		<category><![CDATA[JavaScript]]></category>
		<category><![CDATA[jPlayer]]></category>
		<category><![CDATA[jQuery]]></category>

		<guid isPermaLink="false">http://nuvolsgratis.cat/?p=321</guid>
		<description><![CDATA[Últimament estic ficat en un projecte d&#8217;una pàgina web per un grup de música. Com que tenen una pàgina al MySpace, volia mantenir la idea del reproductor de música i posar-ne un també a la pàgina web que estic creant. Després de mirar diferents opcions, passant per la de fer-lo jo mateix amb Flash, vaig [...]]]></description>
			<content:encoded><![CDATA[<p>Últimament estic ficat en un projecte d&#8217;una pàgina web per un grup de música. Com que tenen una <a href="http://myspace.com/sensesal">pàgina al MySpace</a>, volia mantenir la idea del reproductor de música i posar-ne un també a la pàgina web que estic creant.</p>
<p>Després de mirar diferents opcions, passant per la de fer-lo jo mateix amb Flash, vaig acabar topant amb <a href="http://www.happyworm.com/jquery/jplayer">jPlayer</a>, un plugin per a <a href="http://jquery.com/">jQuery</a> que permet muntar un reproductor amb retrocés a Flash on no pugui funcionar correctament. </p>
<p>Després de decantar-me per la opció del reproductor amb llista de cançons, he vist que aquest no té una cosa que m&#8217;agradaria molt fer servir: un comptador de reproduccions per a cada cançó, i que les llistes de reproducció són estàtiques. Així doncs, he decidit modificar-ho tot plegat per què funcioni bé.</p>
<p><span id="more-321"></span>Per generar llistes de reproducció dinàmicament tenim dues maneres: Generar-ho amb PHP sobre el codi HTML de la pàgina directament, o bé fer que el jPlayer vagi a buscar la informació en un altre arxiu, extern a l&#8217;HTML de la pàgina. Decideixo fer-ho amb la segona opció, per practicar una mica:</p>
<pre class="brush: jscript; title: ;">$.ajax({
                url: &quot;playlist.json&quot;,
                dataType: &quot;json&quot;,
                success: function( myPlayList ){

                //resta del codi

                }
});</pre>
<p>On posa &#8220;resta del codi&#8221; haurem de posar tot el codi del jPlayer. L&#8217;arxiu playlist.json té el format següent:</p>
<pre class="brush: plain; title: ;">[
        {&quot;id&quot;:0,&quot;name&quot;:&quot;Tempered Song&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-01-Tempered-song.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-01-Tempered-song.ogg&quot;,&quot;plays&quot;:57},
        {&quot;id&quot;:1,&quot;name&quot;:&quot;Hidden&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-02-Hidden.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-02-Hidden.ogg&quot;,&quot;plays&quot;:658},
        {&quot;id&quot;:2,&quot;name&quot;:&quot;Lentement&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-03-Lentement.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-03-Lentement.ogg&quot;,&quot;plays&quot;:32},
        {&quot;id&quot;:3,&quot;name&quot;:&quot;Lismore&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-04-Lismore.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-04-Lismore.ogg&quot;,&quot;plays&quot;:497},
        {&quot;id&quot;:4,&quot;name&quot;:&quot;The Separation&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-05-The-separation.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-05-The-separation.ogg&quot;,&quot;plays&quot;:684},
        {&quot;id&quot;:5,&quot;name&quot;:&quot;Beside Me&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-06-Beside-me.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-06-Beside-me.ogg&quot;,&quot;plays&quot;:1},
        {&quot;id&quot;:6,&quot;name&quot;:&quot;Bubble&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-07-Bubble.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-07-Bubble.ogg&quot;,&quot;plays&quot;:9875},
        {&quot;id&quot;:7,&quot;name&quot;:&quot;Stirring of a Fool&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-08-Stirring-of-a-fool.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-08-Stirring-of-a-fool.ogg&quot;,&quot;plays&quot;:45},
        {&quot;id&quot;:8,&quot;name&quot;:&quot;Partir&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-09-Partir.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-09-Partir.ogg&quot;,&quot;plays&quot;:324},
        {&quot;id&quot;:9,&quot;name&quot;:&quot;Thin Ice&quot;,&quot;mp3&quot;:&quot;http://www.miaowmusic.com/audio/mp3/Miaow-10-Thin-ice.mp3&quot;,&quot;ogg&quot;:&quot;http://www.miaowmusic.com/audio/ogg/Miaow-10-Thin-ice.ogg&quot;,&quot;plays&quot;:199}
    ]</pre>
<p>El codi està tret directament de les demos del jPlayer. Per accedir al nom de la primera cançó, per exemple, farem servir <code>myPlayList[0].name</code>. Per cert, que l&#8217;arxiu <code>playlist.json</code> el podem crear amb PHP (<code>playlist.php</code>), guardar la informació en un <code>array</code> i mostrar-lo per pantalla amb la funció <a href="http://www.php.net/manual/en/function.json-encode.php"><code>json_encode()</code></a>.</p>
<p>Pel comptador de reproduccions, la idea és senzilla: cada cop que fem clic al nom d&#8217;una cançó, aquesta es comença a reproduir. Per tant, es pot aprofitar aquest fet per fer que cada cop que cliquem a una cançó també s&#8217;actualitzi el comptador de reproduccions. </p>
<p>Per fer-ho, he creat una funció pròpia:</p>
<pre class="brush: jscript; title: ;">function updatePlayCount(playItem) {
	        var countURL = &quot;playcount.php?id=&quot; + myPlayList[playItem].id;
		$.post(countURL, {&quot;id&quot;: myPlayList[playItem].id});
		alert(countURL);
        }</pre>
<p>L&#8217;arxiu <code>playcount.php</code> conté el codi necessari per sumar 1 al comptador, ja sigui a través de la base de dades, a través d&#8217;arxius .txt&#8230; Això és el que menys importa. La qüestió és que funcioni.</p>
<p>Llavors, cridem aquesta funció cada cop que comenci una nova cançó:</p>
<pre class="brush: jscript; title: ;">function playListChange( index ) {
		playListConfig( index );
		$(&quot;#jquery_jplayer&quot;).jPlayer(&quot;play&quot;);
		updatePlayCount(playItem);
	}</pre>
<p>Així, el codi funciona cada cop que passem la cançó, o s&#8217;acaba, però no funciona si fem Stop i Play. Per aconseguir-ho, cal afegir aquest trosset de codi:</p>
<pre class="brush: jscript; title: ;">$(&quot;#jplayer_play&quot;).click( function() {
		var config = $(&quot;#jquery_jplayer&quot;).data(&quot;jPlayer.config&quot;);
		if(config.diag.playedTime == 0) {
		        updatePlayCount(playItem);}
		return false;
	});</pre>
<p>I en principi hauria de funcionar. Dubtes, errors, solucions més elegats o altres comentaris&#8230; als comentaris, valgui la repetició <img src='http://nuvolsgratis.cat/wp-includes/images/smilies/icon_smile.gif' alt="icon smile Com afegir un comptador de reproduccions a jPlayer" class='wp-smiley' title="Com afegir un comptador de reproduccions a jPlayer" /> </p>
<p>PD: Porto uns dies escoltant les cançons de la demo i m&#8217;estan agradant força&#8230; <img src='http://nuvolsgratis.cat/wp-includes/images/smilies/icon_smile.gif' alt="icon smile Com afegir un comptador de reproduccions a jPlayer" class='wp-smiley' title="Com afegir un comptador de reproduccions a jPlayer" /> </p>
]]></content:encoded>
			<wfw:commentRss>http://nuvolsgratis.cat/com-afegir-un-comptador-de-reproduccions-a-jplayer/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Spotify + Ubuntu + Wine + notify-osd = Spotify-notify</title>
		<link>http://nuvolsgratis.cat/spotify-ubuntu-wine-notify-osd-spotify-notify/</link>
		<comments>http://nuvolsgratis.cat/spotify-ubuntu-wine-notify-osd-spotify-notify/#comments</comments>
		<pubDate>Tue, 22 Jun 2010 22:11:56 +0000</pubDate>
		<dc:creator>Marc</dc:creator>
				<category><![CDATA[Música]]></category>
		<category><![CDATA[Programació]]></category>
		<category><![CDATA[Ubuntu]]></category>
		<category><![CDATA[Python]]></category>
		<category><![CDATA[Spotify]]></category>
		<category><![CDATA[Wine]]></category>

		<guid isPermaLink="false">http://nuvolsgratis.cat/?p=302</guid>
		<description><![CDATA[Sota aquest títol tan matemàtic s&#8217;amaga una petita joia de la corona. M&#8217;explico: porto un temps buscant alguna manera d&#8217;obtenir el títol de la cançó que escolto des d&#8217;Spotify a Ubuntu (a través de Wine). Avui, gairebé per casualitat, he trobat el programa adequat: spotify-notify. El programa, escrit amb el meu estimadíssim python, fa servir [...]]]></description>
			<content:encoded><![CDATA[<p>Sota aquest títol tan matemàtic s&#8217;amaga una petita joia de la corona. M&#8217;explico: porto un temps buscant alguna manera d&#8217;obtenir el títol de la cançó que escolto des d&#8217;Spotify a Ubuntu (a través de Wine). Avui, gairebé per casualitat, he trobat el programa adequat: <strong><a href="http://code.google.com/p/spotify-notify/">spotify-notify</a></strong>.</p>
<p>El programa, escrit amb el meu estimadíssim python, fa servir el notificador <em>notify-osd</em> per avisar-nos de quan Spotify canvia de cançó. És molt fàcil d&#8217;executar: de fet, només cal descarregar un arxiu, instal·lar unes llibreries i executar el programa:</p>
<p><code>python spotify-notify.py</code></p>
<p>Llavors buscarà a Last.fm el nom de l&#8217;artista i el títol de la cançó i n&#8217;obtindrà la portada del disc del primer resultat. Pot ser que no trobi cap portada, i llavors dóna un error, però l&#8217;avís es mostra igualment. Teniu captures de pantalla a la pàgina del projecte.</p>
<p>L&#8217;únic problema és que fa mig any que no s&#8217;actualitza i em dóna certs problemes, com dic, si no troba la portada de l&#8217;àlbum, però sempre es pot modificar el programa. Unes quantes idees:</p>
<ul>
<li>Si no troba la portada a Last.fm, fer servir l&#8217;API d&#8217;Spotify per aconseguir la URL d&#8217;Spotify de la cançó i agafar la portada de la pàgina de la cançó (per exemple, d&#8217;<a href="http://open.spotify.com/track/4YuGSDJIJYZuWKCQqh96Mo">aquí</a>)</li>
<li>Aconseguir que el programa funcioni des que s&#8217;engegui l&#8217;ordinador o, almenys, des que s&#8217;engegui l&#8217;Spotify</li>
<li>Fer una llista de les cançons més escoltades, o les recentment escoltades&#8230;</li>
<li>La teva idea aquí</li>
</ul>
<p>Com sempre, això del brainstorming pot arribar a ser molt llarg&#8230; Algú s&#8217;hi anima a provar-ho? Segur que no és gaire difícil <img src='http://nuvolsgratis.cat/wp-includes/images/smilies/icon_smile.gif' alt="icon smile Spotify + Ubuntu + Wine + notify osd = Spotify notify" class='wp-smiley' title="Spotify + Ubuntu + Wine + notify osd = Spotify notify" /> </p>
]]></content:encoded>
			<wfw:commentRss>http://nuvolsgratis.cat/spotify-ubuntu-wine-notify-osd-spotify-notify/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Inventem un nou llenguatge?</title>
		<link>http://nuvolsgratis.cat/inventem-un-nou-llenguatge/</link>
		<comments>http://nuvolsgratis.cat/inventem-un-nou-llenguatge/#comments</comments>
		<pubDate>Fri, 14 May 2010 15:04:00 +0000</pubDate>
		<dc:creator>Marc</dc:creator>
				<category><![CDATA[Escrits]]></category>
		<category><![CDATA[Idiomes]]></category>
		<category><![CDATA[Programació]]></category>

		<guid isPermaLink="false">http://nuvolsgratis.cat/?p=294</guid>
		<description><![CDATA[Que sigui tant fàcil que tothom el conegui sense necessitat d&#8217;estudiar-lo. Que les coses bones es puguin dir de moltes maneres i les dolentes només d&#8217;una. Que els verbs siguin més fàcils de conjugar en plural que en singular. Que enlloc de punts, les pauses es marquin amb somriures:) Que les mentides siguin faltes d&#8217;ortografia. [...]]]></description>
			<content:encoded><![CDATA[<blockquote><p>Que sigui tant fàcil que tothom el conegui sense necessitat d&#8217;estudiar-lo. Que les coses bones es puguin dir de moltes maneres i les dolentes només d&#8217;una. Que els verbs siguin més fàcils de conjugar en plural que en singular. Que enlloc de punts, les pauses es marquin amb somriures:) Que les mentides siguin faltes d&#8217;ortografia. Que les frases més sinceres s&#8217;hagin d&#8217;escriure en negreta. Que, com el dels sords, funcioni més amb gestos que amb paraules. I, sobretot, que l&#8217;imprescindible es pugui dir <strong>només amb la mirada</strong>. </p></blockquote>
<p>Vist a <a href="http://siknus.cat/inventem-un-nou-llenguatge">siknus.cat</a></p>
]]></content:encoded>
			<wfw:commentRss>http://nuvolsgratis.cat/inventem-un-nou-llenguatge/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Python: Ous de Pasqua</title>
		<link>http://nuvolsgratis.cat/python-ous-de-pasqua/</link>
		<comments>http://nuvolsgratis.cat/python-ous-de-pasqua/#comments</comments>
		<pubDate>Thu, 18 Mar 2010 11:30:04 +0000</pubDate>
		<dc:creator>Marc</dc:creator>
				<category><![CDATA[Programació]]></category>
		<category><![CDATA[Python]]></category>

		<guid isPermaLink="false">http://nuvolsgratis.cat/?p=244</guid>
		<description><![CDATA[Efectivament, Python fa homenatge als Monty Python (que és d&#8217;on va sortir el nom) i té alguns ous de pasqua ben divertits o curiosos: Per exemple, si estem a Python 3.0 podem cridar al mòdul antigravity: &#62;&#62;&#62; import antigravity I se&#8217;ns obrirà una finestra a una tira còmica de XKCD (que, per cert, recomano moltíssim). [...]]]></description>
			<content:encoded><![CDATA[<p>Efectivament, Python fa homenatge als Monty Python (que és d&#8217;on va sortir el nom) i té alguns ous de pasqua ben divertits o curiosos:</p>
<p>Per exemple, si estem a Python 3.0 podem <a href="http://svn.python.org/view/python/trunk/Lib/antigravity.py?view=markup&#038;pathrev=66902">cridar al mòdul <code>antigravity</code></a>:</p>
<pre class="brush: python; title: ;"> &gt;&gt;&gt; import antigravity </pre>
<p>I se&#8217;ns obrirà una finestra a <a href="http://xkcd.com/353/">una tira còmica de XKCD</a> (que, per cert, recomano moltíssim). Si no estem a Python 3.0, podem fer això:</p>
<pre class="brush: python; title: ;">&gt;&gt;&gt;import webbrowser
&gt;&gt;&gt;webbrowser.open(&quot;http://xkcd.com/353/&quot;)
</pre>
<p>I farà el mateix efecte.</p>
<p><span id="more-244"></span>Un altre seria fer:</p>
<pre class="brush: python; title: ;">
&gt;&gt;&gt; import this
The Zen of Python, by Tim Peters

Beautiful is better than ugly.
Explicit is better than implicit.
Simple is better than complex.
Complex is better than complicated.
Flat is better than nested.
Sparse is better than dense.
Readability counts.
Special cases aren't special enough to break the rules.
Although practicality beats purity.
Errors should never pass silently.
Unless explicitly silenced.
In the face of ambiguity, refuse the temptation to guess.
There should be one-- and preferably only one --obvious way to do it.
Although that way may not be obvious at first unless you're Dutch.
Now is better than never.
Although never is often better than *right* now.
If the implementation is hard to explain, it's a bad idea.
If the implementation is easy to explain, it may be a good idea.
Namespaces are one honking great idea -- let's do more of those!</pre>
<p>Això ens dóna el codi Zen de Python <img src='http://nuvolsgratis.cat/wp-includes/images/smilies/icon_smile.gif' alt="icon smile Python: Ous de Pasqua" class='wp-smiley' title="Python: Ous de Pasqua" />  A més, si ara fem <code>print this.s</code>ens donarà el mateix codi Zen però amb les lletres de les paraules substituides per altres.</p>
<p>Un altre seria:</p>
<pre class="brush: python; title: ;">&gt;&gt;&gt; import __hello__
Hello world...
</pre>
<p>I l&#8217;últim de tots és:</p>
<pre class="brush: python; title: ;">&gt;&gt;&gt; from __future__ import braces
SyntaxError: not a chance (&lt;pyshell#4&gt;, line 1)</pre>
]]></content:encoded>
			<wfw:commentRss>http://nuvolsgratis.cat/python-ous-de-pasqua/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

