Ya estoy inscrito ¿Todavía no tienes acceso? Nuestros Planes
Ya estoy inscrito ¿Todavía no tienes acceso? Nuestros Planes
1
respuesta

[Proyecto] Diseñando con el mouse

<canvas width="600" height="400"></canvas>

<script>
    var pantalla = document.querySelector('canvas');
    var pincel = pantalla.getContext('2d');

    pincel.fillStyle = 'grey';
    pincel.fillRect(0, 0, 600, 400);

    var puedoDibujar = false;
    var colorPredeterminado = "blue";

    function dibujarCirculo(x,y,colorPredeterminado) {
        if(puedoDibujar) {

        pincel.fillStyle = colorPredeterminado;
        pincel.beginPath();
        pincel.arc(x, y, 5, 0, 2 * 3.14);
        pincel.fill();
        }
    }

    function dibujarCuadrado(x,y,color){
        pincel.fillStyle = color;
        pincel.fillRect(x,y,50,50);
        pincel.fill();
    }

    function dibujarPaleta() {
        dibujarCuadrado(0,0,"red");
        dibujarCuadrado(50,0,"green");
        dibujarCuadrado(100,0,"blue");
    }

    function habilitarDibujar () {
        puedoDibujar = true;
    }

    function deshabilitarDibujar() {
        puedoDibujar = false;
    }

    function delimitarEspacio(xCoordenada, yCoordenada) {
  // Tamaño del área de la paleta
  var anchoPaleta = 150;
  var altoPaleta = 50;

  if (
    (xCoordenada >= 0 && xCoordenada < (3*50+5)) &&
    (yCoordenada >= 0 && yCoordenada > (altoPaleta + 5)) &&
    (xCoordenada < anchoPaleta || yCoordenada < altoPaleta)
  ) {
    return false;
  } else {
    return true;
  }
}

    function movimientoMouse(evento) {

        var x = evento.pageX - pantalla.offsetLeft;
        var y = evento.pageY - pantalla.offsetTop;

            if (delimitarEspacio(x,y)) {
                dibujarCirculo(x,y,colorPredeterminado);
            }
    }

    function escogeColor(evento) {
        var x = evento.pageX - pantalla.offsetLeft;
        var y = evento.pageY - pantalla.offsetTop;

            if(x > 0 && x < (0+50)) {
                colorPredeterminado = "red";
                console.log(colorPredeterminado);

            } else if(x > 50 && x < (50+50)) {
                colorPredeterminado = "green";


            } else if (x > 100 && x < (100+50)) {
                colorPredeterminado = "blue";

            }

        }


pantalla.onmousemove = movimientoMouse;

pantalla.onmousedown = habilitarDibujar;

pantalla.onmouseup = deshabilitarDibujar;

dibujarPaleta();

pantalla.onclick = escogeColor;  

</script>
1 respuesta

Hola Hugo, espero que estés bien.

Te felicito por los avances en los estudios en Lógica de programación y deseo que obtengas éxito en todo lo que te propongas.

Para agilizar el tiempo de respuesta en caso de dudas relacionadas con los cursos, estamos priorizando el foro para postear dudas. Por favor, recuerda utilizar las etiquetas para indicarnos si tu consulta es una duda, sugerencia o cualquier otro tema. De esta manera, podremos filtrar y procesar las dudas y consultas de manera más eficiente, mejorando aún más nuestro desempeño y tiempo de respuesta.

En caso de que desees compartir tus ejercicios o comentarios, dispusimos en Discord un canal exclusivo para ese fin.

Te dejo este link que muestra como puedes compartir tus dudas y si necesitas ayuda acerca del contenido de los cursos, aquí estaremos. :)

¡Saludos!

Si este post te ayudó, por favor, marca como solucionado ✓. Continúa con tus estudios