Skip to content

JulianDuque97/Trivia-time

Repository files navigation

Trivia time

Descripcion:

El proyecto fue inspirado en el juego llamado Preguntados, se desarrollo principalmente en python, el desarrollo de la interfaz se hizo en Qt y como base de datos se utilizo MySQL.

Alcance:

El proyecto no se logro terminar en su totalidad, por falta de tiempo no se logro mandar a llamar las respuesas de la base de datos pero se deja el planteamiento de que se iba a hacer mediante la relacion de IDs de las preguntas, para entender un poco mejor es necesario ver las tablas implementadas en la base de datos, se crearon 3 tablas.

  • Questions
  • Players
  • Answers

Planteamiento de logica:

Descripcion de las tablas:

Para la tabla Questions se crearon como lo pide el ejercicio 25 preguntas, cada pregunta tendria asociado un Id y un nivel de complejidad que va del 1 al 5, llamando a cualquiera de las preguntas dependiendo de su nivel de forma aleatoria.

En la tabla Players se podra encontrar que existe una columna llamada player_score la cual iba a guardar el puntaje del usuario, si el usuario se retiraba despues de haber contestado bien la pregunta previa asi mismo si el decidia regresar a jugar despues se incrementaria en uno el score que dejo al momento de irse para asi comenzar con la siguiente pregunta donde el dejo si por el contrario el jugador no contesta de forma correcta la pregunta se le asignara un cero, y ya para la columna llamada highest score se planeba almacenar ahi los puntajes que hacian los jugadores para luego hacer un sort y mostrar al inicio del juego los tres primero jugadores.

Para la tabla Answers se crearon para cada pregunta 3 respuestas malas y solo una buena para un total de 100 respuestas, podemos observar que la relacion entre la pregunta y la respuesta se iba a implementar mediante la columna llamada idquestion la cual tiene el mismo id que las de la tabla de preguntas, ademas de esto podemos observar que la ultima columna llamada t_f es igual a verdadero o falso mediante variable booleana la cual se planeaba llamar y mediante condicionales se sabria cual es la respuesta correcta siendo 1 verdadero y 0 falso.

Explicacion de los archivos

  • Los archivos con extension Ui son los correspondientes a la interfaz desarrollada en Qt
  • El archivo con extension qrc corresponde a las imagenes que se utilizaron para la interfaz
  • Archivo main.py, como su nombre lo indica es el archivo principal de la actividad
  • Archivo logos.py, es el mismo logos.qrc pero convertido a python para asi poder importarlo
  • Archivo db.py, es donde se hace la conexion con la base de datos y se hacen los queries para pedirle a la bd.

Explicacion de las carpetas

  • Imagenes, en esta carpeta podra encontrar todas las imagenes que fueron utilizadas en la interfaz
  • db, Adentro podran encontrar un export de las tablas utilizadas en la base de datos
  • img_interfaz, En esta carpeta podran encontrar imagenes del diseño de la interfaz enumeradas segun el ordern natural del juego.
    • Start_1: Se inicia la aplicacion, el juego pide un nombre para comenzar.
    • Instructions_2: Muestra en pantalla las intrucciones del juego y saluda al usuario.
    • Instructions_2: Muestra en pantalla las intrucciones del juego y saluda al usuario.
    • Question_3.0: Muestra en pantalla la primera pregunta, ahi podemos ver de que nivel es y las 4 posibles respuestas.
    • Point_3.1: Si el jugador contesta de manera correcta el juego lo felicita y le da una estrella que es el equivalente a un punto en el juego.
    • Lost_3.2: Si el jugador contesta de manera equivocada el juego le dice que a perdido y que es necesario volver a comenzar desde cero.
    • Exit_4: Si el jugador decide terminar de manera voluntaria el juego le muestra una alerta al respecto.
    • Winner_5: Si el jugador contesta de manera exitosa las 5 rondas el juego le muestra que a ganado.

Librerias que son necesarias descargar utilizando pip

  • PyQt5, esta libreria permite conectar con la interfaz
  • MySQL-python, esta libreria permite conectar con la base de datos

Librerias adicionales que no son necesarias descargar utilizando pip

  • db, esta libreria hace llamado al programa creado para hacer los llamados a la base de datos
  • logos_rc, esta libreria manda a traer las imagenes usadas en la interfaz

About

Trivia time

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages