Ah, cierto que tenía un blog! Más de 2 años después de la última publicación escribo para contar que actualicé después de casi 3 años sin modificaciones una aplicación que hice en PyQT y que tiene una ínfima cantidad de usuarios que cada tanto me contactan.
Se trata de una aplicación para grabar TV usando mencoder. Una GUI que permite configurar los parámetros principales para generar el comando para capturar. No es nada de otro mundo pero a veces para lograr capturar con mencoder hay que recorrer varios foros y leer la man page hasta encontrar lo que se necesita.
En este caso me contactó un italiano para agregar algunos parámetros de configuración para capturar con xvid y x264. Además, como él usa un dispositivo diferente al mío, la lista de normas soportadas es diferente, y eso venía hardcodeado. Ahora se obtiene a través de mplayer, al igual que la lista de inputs y los codecs soportados.
Aproveché el intercambio de mails para pedirle que me ayude con la traducción a italiano así que eso también está incluido.
Son varios cambios, así que pasó de la versión 0.31 a la 1.0. Pero no era mi idea original. Quería que fuera la 0.4 pero cuando quise hacer un ebuild de esto para Gentoo, vi que la 0.4 no la tomaba como una versión posterior, y claro, 31 es mayor que 4, idiota. Había hecho todo mal, tendría que haber sido la 0.3.1.
Si bien el programa es en python y bastante simple, por lo tanto anda descomprimiendo el .tgz en cualquier lado, aproveché para generar un par de paquetes para otras distros. Hice un .rpm bastante rústico y generé un .deb a partir de ese usando alien.
Si alguien con conocimientos de empaquetado se ofrece para ayudarme a hacerlo bien, se lo agradecería. Sobre todo si sabe como hacer distribuible correctamente una aplicación en Python. En este caso simplemente copié todo a /opt/mtvcgui, aunque sé que no es lo mejor. De hecho algunas guías de empaquetado decían en negrita que no había que hacerlo. Viva la anarquía (?)
La aplicación está acá: http://code.google.com/p/mtvcgui/
lunes, 18 de junio de 2012
jueves, 29 de abril de 2010
Pedalera de guitarra con una distro live
Un amigo empezó hace unos días a armar una distro live con el propósito de usarla como pedalera de efectos para guitarra. La idea es proveer los programas necesarios, configurados, e instalados sobre un sistema preparado para ofrecer una baja latencia, que con la configuración por defecto de la mayoría de las distribuciones actuales no se logra.
Esta distro está basada en Debian Squeeze, con un kernel real-time y los programas necesarios para aplicarle efectos a la entrada de audio: Jack y Rackarrack.
Ya existe una primer versión de GNUGuitarINUX (geekismo y marketing no van de la mano :P), en estado prealpha en Sourceforge para los curiosos que quieran rockear un poco y ver de que se trata.
Hay que ejecutar algunos pasos manuales antes de usarla.
Luego de bootear y aparecer la consola para el usuario guitar:
Sigan el avance del proyecto que pinta muy interesante!
Esta distro está basada en Debian Squeeze, con un kernel real-time y los programas necesarios para aplicarle efectos a la entrada de audio: Jack y Rackarrack.
Ya existe una primer versión de GNUGuitarINUX (geekismo y marketing no van de la mano :P), en estado prealpha en Sourceforge para los curiosos que quieran rockear un poco y ver de que se trata.
Hay que ejecutar algunos pasos manuales antes de usarla.
Luego de bootear y aparecer la consola para el usuario guitar:
- Iniciar X manualmente, tipeando desde la consola el comando startx. Esto inicia Fluxbox. Este manejador de ventanas no tiene íconos ni barra de tareas. Para iniciar los programas se los tiene que seleccionar desde el menú que aparece al hacer click derecho con el mouse.
- Abrir JACK Control
- Opcionalmente configurarlo para obtener una mejor latencia (en mi caso lo dejé por default. Con chunks más chicos obtuve mejor latencia pero los datos eran muy pocos y el sonido generado no tenía sentido. Más cosas no probé)
- Abrir Rakarrack
- Volver al JACK Control, elegir el botón Conexiones y conectar las capturas del sistema con las entradas de Rackarrack.
- Prender el botón de iniciar del JACK Control
- Volver a Rackarrack y prender el botón para iniciar los efectos.
Sigan el avance del proyecto que pinta muy interesante!
viernes, 5 de febrero de 2010
¿Se puede leer sin subvocalizar?
Estas vacaciones después de mucho tiempo volví a agarrar un libro, leerlo y terminarlo. Mientras lo leía, y sin haberme fumado nada, me puse a pensar en por qué uno tiene que pronunciar mentalmente cada palabra que lee. Seguía leyendo y me reía porque escuchaba esa voz constantemente y nunca me había puesto a pensar en si había alguna forma de callarla y poder entender el texto igual.
Fue como a veces me pasa, que me pongo a pensar en por qué para llamar algún objeto se usa una palabra en particular, al punto que me resulta graciosa la palabra, caso de "garrafa" o "palangana", por ejemplo.
Lo que yo pensaba es que si puedo mirar el reloj y ver que las agujas marcan las nueve y cuarto, y puedo darme cuenta que son las nueve y cuarto sin decir "nueve y cuarto", algo similar debería pasar al mirar palabras.
La cuestión es que no sabía ni cómo buscar para encontrar alguna respuesta (el título de este post lo escribí después de haber buscado), y finalmente dí con un par de páginas que tratan el tema. Cómo eliminar la subvocalización.
Todavía no intenté ninguna de estas técnicas locas como tararear mientras se lee, pero aparentemente son todas técnicas de lectura rápida. Obvio :P, pero me refiero a esa lectura para estudiar mucho y sacar la idea principal. No se si uno logrará apreciar todo el texto, o sea que no me parece que sea para lectura placentera. Yo diría que comparándolo con el reloj sería como cuando uno mira rápido el reloj y le sirve para darse cuenta que está a horario, pero si alguien le pregunta en ese mismo momento qué hora es, tiene que mirar de nuevo el reloj y decodificar la hora... ¿Alguien tuvo alguna experiencia con esto?
domingo, 30 de agosto de 2009
Graphjam
Me pasaron una página que no conocía: graphjam.com. Un sitio donde los usuarios suben gráficos que tratan de ser graciosos, al estilo del famoso gráfico de la división de tiempos en el desarrollo web, pero no tan nerds. Los votan y comentan. Hay algunos muy buenos.
El sitio está junto con otros más populares como fail blog o lolcatz, pero nunca lo había visto.
Acá dejo algunos gráficos que me gustaron:
Temas tratados en una reunión:
Las últimas palabras:
Contenido de una pileta pública:
Miembros de la banda que consiguen chicas:
Qué se necesita según Los Beatles:
Contenido musical de MTV a lo largo del tiempo:
El calendario según The Cure:
Política:
Relevancia de los comentarios en sitios web:
Conocimientos de computación que tengo vs lo que piensa mi familia de ellos.
El sitio está junto con otros más populares como fail blog o lolcatz, pero nunca lo había visto.
Acá dejo algunos gráficos que me gustaron:
Temas tratados en una reunión:
Las últimas palabras:
Contenido de una pileta pública:
Miembros de la banda que consiguen chicas:
Qué se necesita según Los Beatles:
Contenido musical de MTV a lo largo del tiempo:
El calendario según The Cure:
Política:
Relevancia de los comentarios en sitios web:
Conocimientos de computación que tengo vs lo que piensa mi familia de ellos.
miércoles, 5 de agosto de 2009
Whitest Kids U' Know subtitulado
Here I go again de nuevo otra vez nuevamente. Ya le recomendé a medio mundo estos videos por mail, chat, facebook, etc. Así que ahora los recomiendo en el blog para llegar a la otra mitad del planeta :D
Los videos son de una serie de sketchs que se llama Whitest Kids U'Know y que estuve viendo a partir del video The Grapist, que encontré en el mensaje de estado de un contacto (¡grande flecox por el descubrimiento!)
Tienen 3 temporadas y están filmando la 4ta. De la primera hay un DVD.
El tipo de humor, no se... puede que no le guste a muchos. Tiene algo de humor negro, absurdo, etc. Yo diría que si les gusta Padre de familia, les va a gustar.
Acá dejo los que están subtitulados en youtube. En la página oficial se pueden ver muchos más.
The grapist
La compra de Billy
Call of Duty
Fake Puke
Clase de teatro
Reunión de trabajo
Slow Jerk (sin subtítulos)
Esta era la versión con subtítulos pero no anda en Argentina
Cubicle guy
Can't stop peeing
Test de embarazo
Los videos son de una serie de sketchs que se llama Whitest Kids U'Know y que estuve viendo a partir del video The Grapist, que encontré en el mensaje de estado de un contacto (¡grande flecox por el descubrimiento!)
Tienen 3 temporadas y están filmando la 4ta. De la primera hay un DVD.
El tipo de humor, no se... puede que no le guste a muchos. Tiene algo de humor negro, absurdo, etc. Yo diría que si les gusta Padre de familia, les va a gustar.
Acá dejo los que están subtitulados en youtube. En la página oficial se pueden ver muchos más.
The grapist
La compra de Billy
Call of Duty
Fake Puke
Clase de teatro
Reunión de trabajo
Slow Jerk (sin subtítulos)
Esta era la versión con subtítulos pero no anda en Argentina
Cubicle guy
Can't stop peeing
Test de embarazo
jueves, 2 de julio de 2009
Más hardware vintage
Como cada vez que vuelvo para mis pagos a la casa de mis viejos, aparte de socializar siempre hay algún rato para nerdear. Sobre todo porque allá tengo una buena cantidad de cachivaches como mi primera PC, que cada tanto saco a descarbonizar.
Esta vez puse de nuevo en marcha mi primer scanner. Un Witty Scan de mano, de 16 tonos de grises, con su plaquita ISA de 8 bits. Y quise dejarlo documentado a continuación:
Este tenía un programa para hacer gráficos muy simples desde el cual se escaneaba, que se llamaba Image 72.
Y un programa de reconocimiento óptico de caracteres que se llamaba AIOCR.
Y para terminar, siguiendo con el tema de los programas de imágenes viejos, un par de imágenes del Newsmaster II. Un programa con el que se podían hacer documentos muy llamativos, con gráficos y varias columnas muy fácilmente.
Y del inolvidable Banner Manía. Con el que las LX-810 pasaban horas chillando para imprimir carteles de varias páginas con las más diversas formas.
Y los que tuvimos alguna impresora matriz de punto con cinta color tardábamos hasta 4 veces más (subía y bajaba la cinta en cada línea para combinar los colores) pero teníamos unos hermosos carteles en color:
Por último, y nada que ver con nada, esta imagen del placón Sound Blaster que tuve que sacar de la máquina que usé, para que no conflictúe con el scanner, y ahora debe ser equivalente a un integrado en una placa madre. Y la calco de Playing Food es un detalle que sólo pueden apreciar los que tuvieron su infancia en los 80's rafaelinos :D
Update:
Un video escaneando. Para que Joaco vea que lo usé.
Esta vez puse de nuevo en marcha mi primer scanner. Un Witty Scan de mano, de 16 tonos de grises, con su plaquita ISA de 8 bits. Y quise dejarlo documentado a continuación:
Este tenía un programa para hacer gráficos muy simples desde el cual se escaneaba, que se llamaba Image 72.
Y un programa de reconocimiento óptico de caracteres que se llamaba AIOCR.
Y para terminar, siguiendo con el tema de los programas de imágenes viejos, un par de imágenes del Newsmaster II. Un programa con el que se podían hacer documentos muy llamativos, con gráficos y varias columnas muy fácilmente.
Y del inolvidable Banner Manía. Con el que las LX-810 pasaban horas chillando para imprimir carteles de varias páginas con las más diversas formas.
Y los que tuvimos alguna impresora matriz de punto con cinta color tardábamos hasta 4 veces más (subía y bajaba la cinta en cada línea para combinar los colores) pero teníamos unos hermosos carteles en color:
Por último, y nada que ver con nada, esta imagen del placón Sound Blaster que tuve que sacar de la máquina que usé, para que no conflictúe con el scanner, y ahora debe ser equivalente a un integrado en una placa madre. Y la calco de Playing Food es un detalle que sólo pueden apreciar los que tuvieron su infancia en los 80's rafaelinos :D
Update:
Un video escaneando. Para que Joaco vea que lo usé.
lunes, 22 de junio de 2009
mtvcgui 0.31
Retomé el experimento con PyQT y QTDesigner que había abandonado hace cerca de 6 meses, motivado por los mails con comentarios y sugerencias (¡y problemas!) de ¡3! personas que lo usaron. Además noté que aparece en ¡una página y un foro! :P
Corregí un par de problemas menores y le agregué la funcionalidad de ajustar brillo, contraste, matiz y saturación, y de ver esos cambios en la previsualización del canal a medida que se realizan. También, ahora se puede cambiar de canal y norma mientras se previsualiza.
Esto lo hago usando mplayer en modo esclavo (-slave). De esa manera recibe comandos desde la entrada estándar.
Por ejemplo, para seleccionar un canal, lo hago con
self.mplayer_instance.stdin.write('tv_set_channel %s\n' % str(channel))
donde mplayer_instance es un objeto creado con subprocess.Popen y el comando mplayer con sus argumentos.
En la página dice que hay que usar communicate() en lugar de stdin.write(), pero a mi no me sirvió, porque communicate se queda esperando que el proceso termine y leyendo su stdout, y no es lo que necesito hacer.
A lo mejor podría hacerlo desde un thread, pero... ¡bah!
Igual, no anda demasiado bien y no sé como solucionarlo. El video generado cada tanto se pone más lento y después se arregla solo, sin embargo no se reportan cuadros perdidos. Codifico con lavc(mpeg4) y le aplico los filtros de desentrelazado, etc, todo al vuelo. Podría ser que no da el CPU, pero no supera el 50%... Capaz que mencoder no es la mejor herramienta para capturar TV... :(
La GUI no debería consumir muchos recursos como para molestar en la codificación, salvo que esté haciendo algo muy mal (es posible). En teoría, lo único que se ejecuta mientras se captura es un timer cada 1 segundo, que hace un poll a la instancia de mencoder para ver si sigue viva.
El programa está en google code, github y kde-apps. ¿Para qué? :D
Corregí un par de problemas menores y le agregué la funcionalidad de ajustar brillo, contraste, matiz y saturación, y de ver esos cambios en la previsualización del canal a medida que se realizan. También, ahora se puede cambiar de canal y norma mientras se previsualiza.
Esto lo hago usando mplayer en modo esclavo (-slave). De esa manera recibe comandos desde la entrada estándar.
Por ejemplo, para seleccionar un canal, lo hago con
self.mplayer_instance.stdin.write('tv_set_channel %s\n' % str(channel))
donde mplayer_instance es un objeto creado con subprocess.Popen y el comando mplayer con sus argumentos.
En la página dice que hay que usar communicate() en lugar de stdin.write(), pero a mi no me sirvió, porque communicate se queda esperando que el proceso termine y leyendo su stdout, y no es lo que necesito hacer.
A lo mejor podría hacerlo desde un thread, pero... ¡bah!
Igual, no anda demasiado bien y no sé como solucionarlo. El video generado cada tanto se pone más lento y después se arregla solo, sin embargo no se reportan cuadros perdidos. Codifico con lavc(mpeg4) y le aplico los filtros de desentrelazado, etc, todo al vuelo. Podría ser que no da el CPU, pero no supera el 50%... Capaz que mencoder no es la mejor herramienta para capturar TV... :(
La GUI no debería consumir muchos recursos como para molestar en la codificación, salvo que esté haciendo algo muy mal (es posible). En teoría, lo único que se ejecuta mientras se captura es un timer cada 1 segundo, que hace un poll a la instancia de mencoder para ver si sigue viva.
El programa está en google code, github y kde-apps. ¿Para qué? :D
Suscribirse a:
Entradas (Atom)