Índice:
Código Utilizado¶
Servidor
import socket from robot import robot server = socket.socket() PORT = 8800 server.bind(('', PORT)) server.listen(1) connection, adress = server.accept() robot = Robot()[[]] actions = { "w" : robot.move_front, "a" : robot.move_left, "d" : robot.move_right, "s" : robot.move_back, "e" : robot.move_punch, } while True: data = connection.recv(1) keyword = data.decode("utf-8") if keyword in actions: actions[keyword]() elif keyword == "q": break
Funciones del Robot
from ev3dev2.motor import (LargeMotor, MoveTank, MediumMotor, OUTPUT_A, OUTPUT_B, OUTPUT_C, OUTPUT_D) from time import sleep class Robot: eje = 0 base = -0.58 MAX_VALUE_EJE = 140 MIN_VALUE_EJE = -140 MAX_VALUE_BASE = 0 MIN_VALUE_BASE = -0.58 SPEED = 100 contaux1 = 0 contaux2 = 0 cont = 1 def __init__(self): self.out_a = LargeMotor(OUTPUT_A) # movimiento pelota self.out_b = LargeMotor(OUTPUT_B) # ruedas de atras, movimiento self.out_c = MediumMotor(OUTPUT_C) # ruedas de rotacion, giro izquierda/derecha self.out_d = MediumMotor(OUTPUT_D) # lanzamiento de pelota # Función para desactivar completamente el robot def off_robot(self): self.out_a.stop() self.out_b.stop() self.out_c.stop() self.out_d.stop() # Función para mover el robot hacia adelante def move_front(self): self.out_b.on_for_rotations(speed = 100, rotations= -2, brake = True, block = True) self.out_b.stop() # Función para mover el robot hacia atras def move_back(self): self.out_b.on_for_rotations(speed = 100, rotations= 2, brake = True, block = True) self.out_b.stop() # Función para mover las ruedas del robot hacia la derecha def move_right(self): if(self.MIN_VALUE_EJE < self.eje): # Se comprueba el eje de las ruedas para no provocar una falla en el robot / para que no se queden pegadas self.out_c.on_for_degrees(speed = 100, degrees = -1.4, brake = True, block = True) self.eje-=1.4 self.contaux1-=1 print(self.eje) self.out_c.stop() # Función para mover las ruedas del robot hacia la izquierda def move_left(self): if(self.MAX_VALUE_EJE > self.eje): # Se comprueba el eje de las ruedas para no provocar una falla en el robot / para que no se queden pegadas self.out_c.on_for_degrees(speed = 100, degrees = 1.4, brake = True, block = True) self.eje+=1.4 self.contaux2+=1 print(self.eje) self.out_c.stop() # Función para ingresar los grados para hacer el golpe def move_punch(self, vel, grad): self.vel = vel self.grad = grad self.out_d.on_for_degrees(speed = 100, degrees=grad) self.out_d.stop() # Función para mover la base de la pelota, hacia adelante def mov_adel(self): if(self.MAX_VALUE_BASE>self.base): # Se comprueba la base de la pelota para que no falle el robot / en este caso para que no se golpee hacia atras self.out_a.on_for_rotations(speed = 100, rotations=-0.0116, brake = True, block = True) self.base += 0.0116 self.out_a.stop() # Función para mover la base de la pelota, hacia atras def mov_atras(self): if(self.MIN_VALUE_BASE<self.base): # Se comprueba la base de la pelota para que no falle el robot / en este caso es para que no se pase hacia adelante self.out_a.on_for_rotations(speed = 100, rotations=0.0116, brake = True, block = True) self.base -= 0.0116 self.out_a.stop() def off(self): if(self.base>-0.58): # Se comprueba si esta en la posicion original la base de la pelota while(True): if(50 == self.cont): return False # Se rompe el ciclo solo si la base tiene 4, donde estara en posicion original else: self.out_a.on_for_rotations(speed = 100, rotations = 0.0116, brake = True, block = True) self.base+=0.0116 self.cont = self.cont + 1 print(self.cont) self.out_a.stop()
Interfaz Gráfica
import tkinter as tk from tkinter import ttk import socket class App(tk.Tk): STATUS_CONNECTION = False PORT = 8800 def __init__(self): super().__init__() self.title("Princesita") self.config(padx=10, pady=10, bg="#FFC0CB") self.geometry("800x600") self.canvas = tk.Canvas(self, width=800, height=600) self.canvas.pack() self.resizable(width=False, height=False) self.imagen_fondo = tk.PhotoImage(file="fondo.png") self.imagen_fondo = self.imagen_fondo.subsample(5,5) self.canvas.create_image(0, 0, anchor=tk.NW, image=self.imagen_fondo) self.init_images() self.init_elements() def init_images(self): imagenes = ["encendido.png", "deslizador.png"] self.images = [tk.PhotoImage(file=imagen).subsample(12, 12) for imagen in imagenes] self.connect, self.deslizador= self.images imagenes1 = ["flechaFront.png", "flechaBack.png", "flechaLeft.png", "flechaRight.png","punteria.png"] self.images1 = [tk.PhotoImage(file=imagen).subsample(25, 25) for imagen in imagenes1] self.flechaFront, self.flechaBack, self.flechaLeft, self.flechaRight, self.punteria = self.images1 def init_elements(self): self.btn_Front = tk.Button( self, image=self.flechaFront, bd=0, bg="white", highlightbackground='white', width=80, height=80, command=lambda: self.move_front_car(None) ).place(x=545,y=100) self.btn_Back = tk.Button( self, image=self.flechaBack, bd=0, width=80, height=80, command=lambda:self.move_back_car(None) ).place(x=545,y=300) self.btn_Left = tk.Button( self, image = self.flechaLeft, bd=0, width=80, height=80, command=lambda:self.move_left_car(None) ).place(x=450,y=200) self.btn_Right = tk.Button( self, image= self.flechaRight, bd=0, width=80, height=80, command=lambda: self.move_right_car(None) ).place(x=640,y=200) self.btn_Punch = tk.Button( self, image=self.punteria, bd=0, width=80, height=80, command= lambda : self.move_punch(None) ).place(x=545,y=200) self.btn_Connect = tk.Button( self, image=self.connect, bd= 0, bg= "#fff" if self.STATUS_CONNECTION else "#000", width=40, height=40, command=self.ip_connect ).place(x=710,y=500) self.label_deslizador = tk.Label( self, image=self.deslizador, bd=0, bg= "#bcdc8c", highlightthickness=0, width=60, height=40, ) self.label_deslizador.place(x=90, y=500) self.distancia = tk.DoubleVar() style = ttk.Style() style.configure("TScale", troughcolor="#bcdc8c",background="#bcdc8c", sliderthickness=20) def update_image_position(event): value = self.Scala.get() x_position = self.Scala.winfo_x() + value * self.Scala.winfo_width() / self.Scala.cget("to") self.label_deslizador.place(x= 85 + self.Scala.get() * 3, y=490) self.Scala = ttk.Scale( self, orient = "horizontal", from_=1, to=50, style="TScale", length=200 ) self.Scala.place(x=90, y=540) self.Scala.bind("<Motion>", update_image_position) update_image_position(None) def ip_connect(self): if self.STATUS_CONNECTION == False: ventana_conexion = tk.Toplevel(self) ventana_conexion.title("Ventana de Conexión") ventana_conexion.geometry("200x150") ventana_conexion.resizable(width=False, height=False) etiqueta = tk.Label(ventana_conexion, text="Ingrese la dirección IP:") etiqueta.pack(pady=10) self.IP = tk.StringVar() entry_ip = tk.Entry(ventana_conexion, textvariable=self.IP) entry_ip.pack(pady=10) btn_conectar = tk.Button(ventana_conexion, text="Conectar", command= lambda: self.robot_connection(self.IP.get())) btn_conectar.pack(pady=10) else: self.robot_connection(self.IP.get()) def robot_connection(self,IP): if self.STATUS_CONNECTION: self.STATUS_CONNECTION = not self.STATUS_CONNECTION self.init_images() self.init_elements() else: try: self.client = socket.socket() self.client.connect(IP,self.PORT) self.STATUS_CONNECTION = True except socket.error: self.STATUS_CONNECTION = False def move_front_car(self, event): self.client.send(bytes([ord('w')])) def move_left_car(self, event): self.client.send(bytes([ord('a')])) def move_right_car(self, event): self.client.send(bytes([ord('d')])) def move_back_car(self, event): self.client.send(bytes([ord('s')])) def move_punch(self, event): self.client.send(bytes([ord('e')])) if __name__ == "__main__": app = App() app.mainloop()