Manualinux
http://www.nvu.com http://www.gimp.org InicioPresentaciónActualizacionesManualesDescargasNoticiasAgradecimientoEnlaces

Entornos GráficosAplicaciones

DesarrolloEmuladoresInternetJuegosMultimediaSistema

Juegos - FooBillardJuegos - Njam

Juegos - Frozen Bubble




Juegos - Frozen Bubble




Copyright

Copyright © José Luis Lara Carrascal  2008-2023   http://manualinux.es



Sumario

Introducción
Instalación
Opciones de línea de comandos
Iniciamos Frozen Bubble
Enlaces




Introducción  

Frozen Bubble
es un clon del popular juego creado por la compañía Taito para las máquinas recreativas, Puzzle Bobble. Al igual que en la versión original, en Frozen Bubble podemos jugar contra la máquina y contra otro jugador, y además en red (LAN o Internet). Dispone de más de 100 niveles en un jugador contra la máquina, 3 bandas sonoras de acompañamiento del juego, 15 efectos de sonido estéreo, efectos visuales de transición y para terminar, un editor de niveles para poder crear nuestras propias pantallas de juego.



Instalación  

Dependencias

Herramientas de Compilación


Entre paréntesis la versión con la que se ha compilado Frozen Bubble para la elaboración de este documento.

* GCC - (13.1.0)
* Pkg-config - (0.29.2)

Librerías de Desarrollo

* Xorg - (7.7 / xorg-server 21.1.8)
   LibX11 - (1.8.6)
   LibXext - (1.3.5)
   LibXft - (2.3.8)
* Libpng - (1.6.40)
* Libvorbis - (1.3.7)
* SDL - (1.2.15)
* SDL_image - (1.2.12)
* SDL_mixer - (1.2.12)
* SDL_Pango - (0.1.2) [1]

[1] Si tenemos pensado compilar la librería SDL_Pango, tendremos que añadir un parche de compatibilidad con la API de Frozen Bubble, lo descargamos de este enlace, ubicándolo en el mismo directorio donde esté el directorio de las fuentes de SDL_Pango, lo aplicamos y posteriormente ejecutamos el proceso de configuración, compilación e instalación de esta librería.

$ tar zxvf SDL_Pango-0.1.2.tar.gz
$ cd SDL_Pango-0.1.2
$ patch -Np0 -i ../SDL_Pango-0.1.2-API-adds.patch
$ ./configure --prefix=/usr --libdir=/usr/lib64
$ make
$ su -c "make install; ldconfig"

Intérpretes de Lenguaje de Programación

* Perl - (5.38.0)

Módulos de Perl  

Alien::SDL - (1.446)
autodie - (2.36)
Compress::Bzip2 - (2.28)
Data::Dumper - (2.183)
ExtUtils::CBuilder - (0.280236)
ExtUtils::ParseXS - (3.51)
File::Slurp - (9999.32)
File::Spec::Functions - (3.88)
Getopt::Long - (2.54)
IO::Socket - (1.52)
IPC::System::Simple - (1.30)
Locale::Maketext::Extract - (1.00)
Locale::Maketext::Simple - (0.21_01)
Math::Trig - (1.62)
Module::Build - (0.4234)
parent - (0.241)
Time::HiRes - (1.9764)
Tie::Simple - (1.04)
* SDL_Perl - (2.548)

Aplicaciones

* Convert (ImageMagick) - (7.1.1-14) [1]

[1] Requerido para poder crear un icono del archivo desktop.



Descarga

frozen-bubble-2.2.1-beta1.tar.bz2

Optimizaciones

$ export {C,CXX}FLAGS='-O3 -march=znver3 -mtune=znver3'

Donde pone znver3 se indica el procesador respectivo de cada sistema seleccionándolo de la siguiente tabla:
* La opción '-march=' establece el procesador mínimo con el que funcionará el programa compilado, la opción '-mtune=' el procesador específico para el que será optimizado. 

* Los valores separados por comas, son equivalentes, es decir, que lo mismo da poner '-march=k8' que '-march=athlon64'.

* En versiones de GCC 3.2 e inferiores se utiliza la opción '-mcpu=' en lugar de '-mtune='.
Valores CPU
Genéricos
Intel
AMD

Optimizaciones adicionales

Optimizaciones adicionales
Graphite
$ export {C,CXX}FLAGS+=' -ftree-loop-linear -floop-strip-mine -floop-block'
IPA
$ export {C,CXX}FLAGS+=' -fipa-pta'

Parámetros adicionales

Parámetros adicionales de eliminación de errores específicos en el proceso de compilación
$ export CFLAGS+=' -Wno-error'

Establecer la ruta de búsqueda de directorios de librerías en sistemas de 64 bits multiarquitectura
$ export LDFLAGS+=' -L/usr/lib64 -L/usr/local/lib64 -L/opt/gcc13/lib64'
Cada usuario tendrá que establecer la ruta de búsqueda de directorios, en función de la distribución que utilice.

Extracción y Configuración 

$ tar jxvf frozen-bubble-2.2.1-beta1.tar.bz2
$ cd frozen-bubble-2.2.1-beta1
$ perl Build.PL

Compilación

$ ./Build manifest
$ ./Build

Instalación como root  Bloc de Notas Información general sobre el uso de los comandos

$ su
# ./Build install
# for i in /usr/share/icons/hicolor ; do \
install -dm755 $i/{16x16,24x24,32x32,48x48,64x64}/apps ; \
install -m644 share/icons/frozen-bubble-icon-64x64.png $i/64x64/apps/frozen-bubble.png ; \
install -m644 share/icons/frozen-bubble-icon-48x48.png $i/48x48/apps/frozen-bubble.png ; \
install -m644 share/icons/frozen-bubble-icon-32x32.png $i/32x32/apps/frozen-bubble.png ; \
convert -resize 24 $i/64x64/apps/frozen-bubble.png $i/24x24/apps/frozen-bubble.png ; \
install -m644 share/icons/frozen-bubble-icon-16x16.png $i/16x16/apps/frozen-bubble.png ; \
gtk-update-icon-cache -tf $i &> /dev/null ; \
done

Creación del archivo frozen-bubble.desktop

Para que Frozen Bubble sea detectado por los menús de entornos gráficos como XFce 4 o paneles como LXPanel o Fbpanel, creamos el archivo desktop correspondiente con cat o con un editor de texto: 

# cat > frozen-bubble.desktop << "EOF"
[Desktop Entry]
Name=Frozen Bubble
GenericName=Frozen Bubble
Comment=Un clon del popular Puzzle Booble
Exec=frozen-bubble
Icon=frozen-bubble
Categories=Application;Game;ArcadeGame
Type=Application
EOF

Luego lo instalamos en /usr/share/applications. La desinstalación y respaldo de este archivo viene incluida en los scripts correspondientes proporcionados en este manual.

# install -m644 frozen-bubble.desktop /usr/share/applications

Estadísticas de Compilación e Instalación de Frozen Bubble

Estadísticas de Compilación e Instalación de Frozen Bubble
CPU AMD Ryzen 5 5500
MHz 3593.250 (BoostMax=4457.000)
RAM 32 GB
Sistema de archivos XFS
Versión del Kernel 6.4.6-ml SMP PREEMPT_DYNAMIC x86_64
Modo de frecuencia de la CPU powersave (balance performance)
Versión de Glibc 2.37
Enlazador dinámico GNU gold (Binutils 2.40) 1.16
Compilador GCC 13.1.0
Parámetros de optimización -03 -march=znver3 -mtune=znver3 -ftree-loop-linear -floop-strip-mine -floop-block -fipa-pta
Tiempo de compilación 4"
Archivos instalados 3.282
Mostrar/Ocultar la lista de archivos instalados
Ocupación de espacio en disco 30,1 MB

Consumo inicial de CPU y RAM de Frozen Bubble

Consumo inicial de CPU y RAM de Frozen Bubble
Programa
CPU RAM
frozen-bubble 12 % 181,5 MB
Para medir el consumo de CPU se utiliza el programa top, y para medir el consumo de RAM se utiliza el script de Python, ps_mem.py, creado por Pádraig Brady, que podemos encontrar en este enlace.

Directorio de configuración personal

~/.frozen-bubble Es el directorio de configuración personal de Frozen Bubble en nuestro home.

Desinstalación como root

1) MODO TRADICIONAL

************************

2) MODO MANUALINUX

frozen-bubble-2.2.1-beta1-scripts.tar.gz

$ su
# tar zxvf frozen-bubble-2.2.1-beta1-scripts.tar.gz
# cd frozen-bubble-2.2.1-beta1-scripts
# ./Desinstalar_frozen-bubble-2.2.1-beta1

Copia de Seguridad como root

Con este otro script creamos una copia de seguridad de los binarios compilados, recreando la estructura de directorios de los mismos en un directorio de copias de seguridad (copibin) que se crea en el directorio /var. Cuando se haya creado el paquete comprimido de los binarios podemos copiarlo como usuario a nuestro home y borrar el que ha creado el script de respaldo, teniendo en cuenta que si queremos volver a restaurar la copia, tendremos que volver a copiarlo al lugar donde se ha creado.

$ su
# tar zxvf frozen-bubble-2.2.1-beta1-scripts.tar.gz
# cd frozen-bubble-2.2.1-beta1-scripts
# ./Respaldar_frozen-bubble-2.2.1-beta1

Restaurar la Copia de Seguridad como root

Y con este otro script (que se copia de forma automática cuando creamos la copia de respaldo del programa) restauramos la copia de seguridad como root cuando resulte necesario.

$ su
# cd /var/copibin/restaurar_copias
# ./Restaurar_frozen-bubble-2.2.1-beta1




Opciones de línea de comandos de Frozen Bubble  

A continuación pongo las opciones de línea de comandos del juego traducidas al español.

Uso: frozen-bubble [OPCIÓN]...
 --fullscreen           inicia en modo de pantalla completa
 --no-fullscreen        no inicia en modo de pantalla completa
 --no-sound             se inicia sin sonido
 --no-music             desactiva sólo la música 
 --no-sfx               desactiva sólo los efectos de sonido
 --playlist <archivo>      utiliza todos los archivos listados en el archivo indicado como archivos de música a reproducir durante el juego
 --playlist <directorio> utiliza todos los archivos ubicados en el directorio indicado como archivos de música a reproducir durante el juego
 --slow-machine         activa el modo de máquina lenta (desactiva varias animaciones)
 --very-slow-machine    activa el modo de máquina muy lenta (desactiva todo lo que pueda ser desactivado)
 --solo                 inicia de forma directa el modo de 1 jugador contra la máquina (1p), con los niveles aleatorios si no se indica -l<#n> 
 --direct               inicia de forma directa el modo de 2 jugadores (2p)(no muestra el menú)
 --gameserver <máquina[:puerto]> inicia de forma directa el juego en red (NET/LAN) conectando al servidor de juego (si se omite el puerto, se utilizará el predefinido)
 --level <#n>           inicia de forma directa un determinado nivel (ejemplo -l 12) (implica -so)
 --levelset<nombre>     inicia de forma directa con un nombre específico del nivel  
 --no-time-limit        desactiva el límite de tiempo para el disparo (ej. modo niños)
 --chain-reaction       activa la reacción en cadena (cuando sea aplicable)
 --player-malus <#n>    añade un n de malus al jugador izquierdo (puede ser negativo)
 --mp-training-difficulty <#n> ajusta la duración media de receptación de las burbujas malus en 1 jugador multijugador entrenamiento (30 por defecto (= cada 30 segundos de promedio), menos tiempo es más dificil)
 --colour-blind         utiliza burbujas especiales para las personas invidentes
 --joysticks-info       imprime la información de los joysticks detectados en el inicio
 --no-echo              cuando el sonido está activado, desactiva el eco tecleado del caracter con un sonido de máquina de escribir
 --my-nick <nick>       para los juegos en red (net/lan), usa el nick en lugar del nombre de usuario (máximo 10 caracteres, más ASCII alfanumérico y subrayado sólo)
 --private              cuando se inicia un juego en red, no utiliza http://hostip.info/ para recibir su posición geográfica y enviarla a otros jugadores
 --record <dir>         especifica un directorio de registros (normalmente, los registros son guardados en el directorio '~/.frozen-bubble/records')
 --auto-record          registra de forma automática todos los juegos aplicables (normalmente, un registro se activa al presionar la tecla de Imprimir Pantalla durante el juego)
 --comment '...'        añade un comentario incluido entre citas simples a los archivos (no debe contener nada más que ASCII), se mostrará en la consola al reproducir de nuevo el último registro
 --replay <archivo|dirección>    reinicia un juego específico guardado
 --save-frames <dir>    indica un directorio donde serán guardados todos los fotogramas del juego; como se reducirá la velocidad del juego, sólo puede ser utilizado con --replay; Un caso de uso típico es construir un video externo fuera de los fotogramas (vea la página man)



Iniciamos Frozen Bubble  

Sólo nos queda teclear en una terminal o en un lanzador el comando frozen-bubble, y el juego aparecerá en la pantalla.


Captura - Frozen Bubble - 1


Captura - Frozen Bubble - 2


Captura - Frozen Bubble - 3




Enlaces  


http://www.frozen-bubble.org >> La web archivada de Frozen Bubble.


Foro Galería Blog


Actualizado el 26-07-2023

Juegos - Frozen Bubble

Juegos - FooBillardJuegos - Njam