Presentación de HipHop PHP

Los rumores se han confirmado y finalmente facebook ha hecho publico el vídeo de presentación de este compilador para PHP.

La compañía lleva cerca de 6 meses usando el proyecto en sus servidores de producción con cerca de el 90% de su contenido corriendo con HipHop.

Para facilitar su uso en proyectos de terceros, futuras versiones incluirán compatibilidad con PHP 5.3 (actualmente solo 5.2) y una extensión para ser ejecuto sobre apache además del server propio sobre el que corre actualmente.

Los resultados hablan por si solos:

  • Web: 50% menos en consumo de CPU con el mismo tráfico
  • API: 30% menos de consumo de CPU con el doble de tráfico

Las mas de 300.000 líneas de código del proyecto serán publicadas proximamente en el canal de Facebook en Github

Reproductor de vídeo HTML5

Sublime Video es un reproductor HTML5 con un diseño muy cuidado (estilo mac) y permite la reproducción de vídeos sin recurrir a flash.

Aún se encuentra en desarrollo pero ya cuenta con las siguientes funcionalidades:

  • No requiere plugins
  • Permite pulsar en cualquier punto del timeline y comenzar a guardar el buffer a partir de ahí
  • Animación zoom in/out a pasar a pantalla completa
  • Capaz de readaptar el tamaño del vídeo a pantalla completa si cambia el tamaño de la ventana
  • Acceso rápido a play/pause con la barra espaciadora

Por ahora solo es compatible con Safari, Chrome e Internet Explorer con Chrome frame instalado, pero ya están trabajando en la compatibilidad con firefox. Otras de las funcionalidades programadas son la inclusión de un control de volumen y la compatibilidad con IE (reemplazando el reproductor por uno flash).

El reproductor será lanzado pronto de manera gratuita (al menos para usos no comerciales).

vía webappers

Funcionalidades HTML5/CSS3 en IE

HTML5 y CSS3 toma cada día mas fuerza pero aún esta muy limitado en cuanto a soporte por parte de los browsers. Como no podía ser de otra forma, Internet Explorer se lleva la palma aunque algunos desarrolladores parecen negarse a esperar un nuevo navegador de MS compatible con los últimos estándares.

A continuación os dejo algunas técnicas con las que añadir/simular funcionalidades propias de los browsers más punteros en el navegador de microsoft (Extraído de un estupendo post de catswhocode).

Compatibilidad con los nuevos tags HTML5

El siguiente script debe ser incluido dentro del head del documento para que IE sea capaz de interpretar los elementos antes de renderizar la página.

<!--[if IE]>
<script src="http://html5shiv.googlecode.com/svn/trunk/html5.js">
<![endif]-->

Text-shadow

p.shadowed {
  text-shadow: #0000ff 0px 0px 3px; /* Navegadores modernos */
  filter: glow(color=#0000ff,strength=3); /* IE */
}

box-shadow

.shadowed{
    box-shadow: 10px 10px 5px #888;
}

.shadowed {
    filter:
        progid:DXImageTransform.Microsoft.DropShadow(color=#969696, offx=1, offy=1)
        progid:DXImageTransform.Microsoft.DropShadow(color=#C2C2C2, offx=1, offy=1)
        progid:DXImageTransform.Microsoft.DropShadow(color=#EFEFEF, offx=1, offy=1);
}

Rounded corners

.round{
    border-radius:5px;
    -moz-border-radius:5px;
    -webkit-border-radius:5px;
}

Para IE:

<script type="text/javascript" src="DD_roundies.js">
<script type="text/javascript">
  DD_roundies.addRule('.roundify', '10px');
</script>

Opacity

.element{
    opacity:.7; /* Standard CSS */
    filter:alpha(opacity=70); /* IE patch */
}

Soporte RGBa

 .color-block {
    width: 50%;
    background-color: rgba(0, 0, 255, 0.2); /* Modern browsers */
}
/*IE*/
.color-block {
    background:transparent;
    filter:progid:DXImageTransform.Microsoft.gradient( startColorstr=#99000050,endColorstr=#99000050);
    zoom: 1;
}

Ver más

A vueltas con el iPad

Las expectativas eran enormes, el hype desmedido y cualquier rumor se convertía en noticia con el fin de saciar el apetito de aquellos que esperaban ansiosos el lanzamiento del gadget del que Steve Jobs aseguro sería lo mejor que ha hecho.

Llego el esperado día. Jobs reaparecía en público tras una prolongada baja por enfermedad y el iPad (bautizado en la red como el ipod gigante) se mostraba al mundo en una conferencia cuidada hasta el último detalle.

Y los aplausos no llegaron… De hecho, las expectativas eran tan altas que buena parte del hype se ha vuelto en contra de un producto de apple por primera vez en mucho tiempo. Apenas han hecho falta un par de días para que empiecen a circular vídeos en la red tan simpáticos como el siguiente

Portales como xataka empezaban a hacerse eco de alternativas al tablet de apple, destacando el ExoPC: Un dispositivo con pantalla multitáctil de 8.9 pulgadas a 1024×600, Windows 7 (flash y multitarea incluidos).

Me sumo a la gente que ve el ipad bastante flojo. El diseño no convence, sigue sin ser multitarea (nada de realizar descargas en safari), no incorpora finder, flash no llega (ni llegará), etc. El iphoneOS no cumple con las expectativas de aquellos que esperaban un mac OS X adaptado.

De todas formas, tampoco pienso que OSX, Win7 o Linux sean mejores sistemas operativos para este tipo de dispositivos. Me resulta difícil imaginarme navegando entre los distintos menus de una aplicación (firefox, openoffice, etc) en una tablet sin stylus. Y es ahí donde radica el grandeza del iphoneOS, esta concebido para ser manejado única y exclusivamente mediante una pantalla multitouch. Este lanzamiento ha sido un gran FAIL pero a futuro veo en iPad bastante potencial si se animan a incorporarle un SO menos limitado.

P.D: No se si a raíz de esto, pero Steve anda bastante calentado y ha lanzado algunas declaraciones bastante ácidas a google y adobe:

P.D.2: Circula por internet un vídeo que muestra como editar la apariencia de un iTouch/iPhone para que luzca estilo ipad (Queda bastante bien, probablemente me anime a cambiar el dock del mio). Requiere jailbreak.

Mr. Ballmer, ¿Firmarías mi mac?

Tras una charla impartida en la Universidad de Trevecca Nazarene, Nashville, uno de los estudiantes preguntó a Steve Ballmer si podía firmar su laptop, una MacBook, a lo que CEO de microsoft accedio entre risas.

Vía alt1040

P.D.:
Soy consciente de que últimamente tengo un poco abandonado el blog. Estoy trabajando en nuevo portal y un framework php open source (basado en codeigniter) que me gustaría publicar a mediados del mes que viene y claro, el tiempo no da para todo. Espero recuperar el ritmo habitual de posts en un par de semanas.

Instalar firefox 3.6 en ubuntu

Serán muchos los usuarios de linux que deseen actualizar a la última versión de mozilla firefox sin esperar una nueva release de su distro favorita. A continuación os dejo las instrucciones para añadir el repositorio que contiene la versión 3.6 del navegador (estable, no daily-build) en ubuntu.

Karmix (9.10) / Lucid (10.4) ejecutar en terminal

sudo add-apt-repository ppa:mozillateam/firefox-stable

Jaunty, Intrepid o Hardy (Asegurarse de reemplazar “VERSION_DE_UBUNTU” por la versión de vuestra distro)

sudo bash -c "echo 'deb http://ppa.launchpad.net/mozillateam/firefox-stable/ubuntu VERSION_DE_UBUNTU main' >> /etc/apt/sources.list"
sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys CE49EC21

Y ya solo queda actualizar los repos e instalar el programa:

sudo apt-get update && sudo apt-get install firefox-3.6

Si lo preferís también es posible optar por Swiftfox 3.6, una versión optimizada del navegador para distintos procesadores (disponibles paquetes .deb optimizados para AMD64, AMD anteriores, Intel Prescott y anteriores).

Vía webupd8

Firefox 3.6

Hoy, 21 de enero, es la fecha elegida por mozilla para el lanzamiento de Firefox 3.6. A partir de las 9:30 PST (Pacific Standard Time) podrá descargarse esta nueva versión que promete mejorar la velocidad,estabilidad y experiencia del usuario respecto a versiones anteriores.

Firefox 3.6 cuenta con numerosas mejoras y novedades entre las que destacan:

  • Compatibilidad con la HTML5 File API mediante la cual ya es posible subir ficheros con javascript. También se han añadido eventos Drag and Drop.
  • Se han introducido cambios en el modo en el que se integran las extensiones/software de terceros con firefox que mejoran la estabilidad
  • CSS Gradients-Backgrounds y Web Open Font Format para desarrolladores
  • Nuevos temas visuales (Personas): Más rápido y ofrece previsualización de la nueva apariencia
  • Capacidad de correr script asincrónicamente para mejorar la velocidad de carga de las páginas
  • Firefox 3.6 avisará de plugins desactualizados para mejorar la seguridad
  • Ahora es posible reproducir a pantalla completa los vídeos html5
    fullscreen
  • Mejoras en rendimiento javascript, respuesta general del browser y tiempos de arranque
  • Añadidos mecanismos para evitar que software no compatible cuelgue el navegador
  • Compatible con nuevas técnicas CSS, DOM y HTML5

Hace algún tiempo compare firefox 3.6 beta 4 y 3.5 en un benchmark javascript, la mejora fue muy notable:
firefox_benchmark

Para terminar os dejo un vídeo donde el jefe de desarrollo de mozilla hace un repaso de las novedades incorporadas en esta nueva versión:

Links: página oficial de mozilla firefox

Killer Bean Forever

Después de haber sido el responsable de animación de Matrix Reloaded, Jeff Lew decidió crear su propia película de animación. Durante 5 años, ha estado trabajando 14 horas al día, 7 días a la semana, delante de su ordenador. Afirma haber invertido todos sus ahorros y haberse endeudado al máximo para lograr su sueño, pero finalmente, después de todo este esfuerzo y sacrificio la película ya esta la venta en internet : Killer Bean Forever.

Aquí tenéis la primera escena al completo

Todo un ejemplo de emprendedor

Novedades de jQuery 1.4

El framework javascript más laureado llega con importantes mejoras de rendimiento y nuevas funcionalidades en su reciente versión 1.4.

Lanzado el 14 de enero, coincidiendo con el cuarto aniversario del proyecto, esta versión supone la reescritura de buena parte de las funciones más populares con el objetivo de simplificar el mantenimiento del core y aumentar la velocidad de respuesta del framework.

Setters

Las funciones .attr(),.css(), .attr(), .val(), .html(), .text(), .append(), .prepend(), .before(), .after(), .replaceWith(), .wrap(), .wrapInner(), .offset(), .addClass(), .removeClass(), y .toggleClass() ya aceptan funciones como parámetro facilitando la modificación de los elementos.

// find all ampersands in A's and wrap with a span
$('a').html(function(i,html){
  return html.replace(/&/gi,'&');
});

// Add some information to the title of the anchors
$('a[target]').attr("title", function(i,title){
  return title + " (Opens in External Window)";
});

Serializar parámetros anidados

En jQuery 1.3 {foo: ["bar", "baz"]} era serializado como foo=bar&foo=baz, ahora el resultado quedaría en foo[]=bar&foo[]=baz

De todas formas, aún es posible volver a el comportamiento tradicional:

// Enables for all serialization
jQuery.ajaxSettings.traditional = true;

// Enables for a single serialization
jQuery.param( stuff, true );

// Enables for a single Ajax requeset
$.ajax({ data: stuff, traditional: true });

El método serialize() también reconoce ahora elementos html5 como `datetime` o `range`.

Contexto en llamadas ajax

Seguir leyendo

No al cierre de páginas webs


Madrid, 4 de diciembre:

El presidente del Gobierno, José Luis Rodríguez Zapatero, ha garantizado hoy en la rueda de prensa tras la reunión con el presidente del Parlamento Europeo, que el Gobierno no se ha planteado en ningún momento cerrar ninguna página web por la vía administrativa y dijo que el Ministerio de Cultura introducirá «las aclaraciones oportunas» en la futura ley de economía sostenible

Pues bien, «las aclaraciones oportunas» se traducen en que las garantías del presidente del gobierno no valen nada hoy. Tras un lavado de cara mínimo de la disposición final primera de la Ley de Economía Sostenible las cosas están igual que estaban y ahora nos toca a los distintos agentes sociales y colectivos afectados hacernos oír y exigir la retirada de esta, o será tarde para arrepentimientos.

Una vez más desde proyecto-f nos unimos a el colectivo de internautas bajo el lema A partir de hoy, Red y Libertad de la campaña Internet no sera otra tele publicado originalmente en red-sostenible.net.

La Red Sostenible somos todos/as. Si quieres adherirte a este texto, cópialo, blogguéalo, difúndelo.

A partir de hoy, Red y Libertad

Consideramos imprescindible la retirada de la disposición final primera de la Ley de Economía Sostenible por los siguientes motivos:

1 -Viola los derechos constitucionales en los que se ha de basar un estado democrático en especial la presunción de inocencia, libertad de expresión, privacidad, inviolabilidad domiciliaria, tutela judicial efectiva, libertad de mercado, protección de consumidoras y consumidores, entre otros.

2 – Genera para la Internet un estado de excepción en el cual la ciudadanía será tratada mediante procedimientos administrativos sumarísimos reservados por la Audiencia Nacional a narcotraficantes y terroristas.

3 – Establece un procedimiento punitivo “a la carta” para casos en los que los tribunales ya han manifestado que no constituían delito, implicando incluso la necesidad de modificar al menos 4 leyes, una de ellas orgánica. Esto conlleva un cambio radical en el sistema jurídico y una fuente de inseguridad para el sector de las TIC (Tecnología de la Información y la Comunicación). Recordamos, en este sentido, que el intercambio de conocimiento y cultura en la red es un motor económico importante para salir de la crisis como se ha demostrado ampliamente
Seguir leyendo

Contenido relacionado con mysql

Implementar links a post/vídeos/contenido relacionado es, al contrario de lo que pueda parecer, una tarea bastante sencilla.

Para el siguiente ejemplo imaginemos que partimos de una web estilo youtube sobre una base de datos mysql, cada pagina contiene 5 tags, una descripción y titulo. El objetivo será lanzar una consulta a base de datos que devuelva los vídeos relacionados ordenador por su relevancia/parecido.

Antes de nada vamos a tener que añadir indices fulltext a los campos de la bd sobre los que queremos lanzar la consulta (estos indices solo son compatibles con el motor MyIsam y no con InnoDB).

ALTER TABLE videos ADD FULLTEXT(title, description, keywords);

A partir de aquí ya solo queda dividir los tags/descripción/titulo en tokens y lanzar la siguiente consulta:

select * from videos where match(title, description, keywords)
against (‘word1 word2 word3 word4′ in boolean mode)
order by relevance desc

El modificador boolean mode también permite descartar los resultados que contengas ‘xxxx’ palabras. El siguiente ejemplo devuelve los resultados que contengas katrina pero no se refieran al huracán.

select * from videos where match(title, description, keywords)
against (‘+Hurricane -Katrina’ IN BOOLEAN MODE);

Más información sobre búsquedas fulltext mysql

Pantalla AMOLED transparente de samsung

Presentada en CES, las pantallas amoled transparentes de samsung se han convertido en una de las novedades más interesantes del año.

No hay intención de comercializar el prototipo a corto plazo, aunque el modelo mostrado es plenamente funcional, debido al aún altísimo precio de las mismas, pero la tecnología parece tener un futuro prometedor aplicado a conceptos como la realidad aumentada.

Cuenta con una resolución de 1000×600 píxels, tiene 14 pulgadas y un nivel de transparencia del 40%.

Fuente e imagen: gizmodo