Nos informe porque este programa é inadequado. Por favor, não envie várias vezes.

Razão
Mensagem

Enviar    Cancelar

  • Use o bom senso
  • Seja educado. Trate os outros como você gostaria de ser tratado
  • Você só pode usar até 3.000 caracteres por comentário
  • Você não pode comentar o mesmo programa dentro do período de 60 segundos
  • Você não pode postar o mesmo comentário em vários programas.
  • Existe um limite de 100 comentários por usuário no período de 24 horas.

Fechar

N3DohmsProf2000

de C2C00588 |  v2 |  0 |  0 |  1933 |  7 
Acesse sua conta para comentar e baixar este programa.

Compartilhado há 7 anos e 8 meses atrás - Última modificação em 08/08/2016
Alguns direitos reservados
// n3dohmsprof2000.c - Criado pelo studio UNO 2.3
// 8 August 2016 7:28:49 pm
 
#include <uno.h>
 
 
// Defines
#define VariaGarra 5
#define tempo 10
 
// Declaracao das Variaveis
unsigned char AceX;
unsigned char AceY;
unsigned char AceZ;
unsigned char BtC;
unsigned char BtZ;
unsigned char Garra;
unsigned int Graus;
unsigned char Ir1Limite;
unsigned char Ir5Limite;
unsigned char JoyX;
unsigned char JoyY;
int Motor_D;
int Motor_E;
unsigned int Pulsos;
unsigned int dir_ultrasson;
int eixo_x;
int eixo_y;
unsigned int esq_ultrasson;
 
// Prototipos
void ControleRF(void); 
void ControleJoy(void); 
void AjusteLimites(void); 
void GiraDireita(void); 
void Freio(void); 
void GiraEsquerda(void); 
void sumo(void); 
void ZeraEncoders(void); 
void LeRF(void); 
void ControleMotores(void); 
 
//Funcoes do Usuario
void ControleRF(void) 
{
     eixo_x = ((JoyX - 128) * 8);
     eixo_y = ((JoyY - 128) * 8);
     Motor_E = (eixo_x + eixo_y);
     Motor_D = (eixo_y - eixo_x);
     AjusteLimites();
     ControleMotores();
}
 
void ControleJoy(void) 
{
     if ((JoyX < 126)) {
         Graus = 5;
         GiraEsquerda();
     }
     if ((JoyX > 130)) {
         Graus = 5;
         GiraDireita();
     }
     if ((JoyY < 126)) {
         __motor_curso(__BACKWARD);
     }
     if ((JoyY > 130)) {
         if (((__SeguidorGetAnalog(1, 2) > 20) || (__SeguidorGetAnalog(1, 4) > 20))) {
             __motor_curso(__FORWARD);
         }
         else {
             Freio();
         }
     }
     if (((JoyX == 128) && (JoyY == 128))) {
         __motor_curso(__STOP);
     }
     if ((BtC == 1)) {
         __PWM1 = 180;
     }
     if ((BtZ == 1)) {
         __PWM1 = 40;
     }
 
}
 
void AjusteLimites(void) 
{
     if ((Motor_E < -1023)) {
         Motor_E = -1023;
     }
     if ((Motor_E > 1023)) {
         Motor_E = 1023;
     }
     if ((Motor_D < -1023)) {
         Motor_D = -1023;
     }
     if ((Motor_D > 1023)) {
         Motor_D = 1023;
     }
 
}
 
void GiraDireita(void) 
{
     ZeraEncoders();
     Pulsos = (Graus / 4.9);
     __motor_curso(__RIGHT_ROTATE);
     while((__EncoderGetValue(1) < Pulsos)) {
         while(!(__EncoderGetValue(1) >= Pulsos)) { __delay(10); }
         __lcd_goto(0xbf, 9);
         __lcd_puts("%d", __EncoderGetValue(1));
         __delay(tempo);
     }
 
}
 
void Freio(void) 
{
     __motor_curso(__REVERSE);
     __delay(30);
     __motor_curso(__STOP);
}
 
void GiraEsquerda(void) 
{
     ZeraEncoders();
     Pulsos = (Graus / 4.9);
     __motor_curso(__LEFT_ROTATE);
     while((__EncoderGetValue(2) < Pulsos)) {
         while(!(__EncoderGetValue(2) >= Pulsos)) { __delay(10); }
         __lcd_goto(0xbf, 1);
         __lcd_puts("%d", __EncoderGetValue(2));
         __delay(tempo);
     }
 
}
 
void sumo(void) 
{
     Garra = 180;
}
 
void ZeraEncoders(void) 
{
     __SmartSensorCmd(1, 1, 9, 0);
     __delay(tempo);
     __SmartSensorCmd(1, 2, 9, 0);
     __delay(tempo);
}
 
void LeRF(void) 
{
     JoyX = __ControllerGetJoystick_X(1);
     __delay(tempo);
     JoyY = __ControllerGetJoystick_Y(1);
     __delay(tempo);
     AceX = __ControllerGetAccelerometer_X(1);
     __delay(tempo);
     AceY = __ControllerGetAccelerometer_Y(1);
     __delay(tempo);
     AceZ = __ControllerGetAccelerometer_Z(1);
     __delay(tempo);
     BtC = __ControllerGetButton_C(1);
     __delay(tempo);
     BtZ = __ControllerGetButton_Z(1);
     __delay(tempo);
}
 
void ControleMotores(void) 
{
     __motor(1, Motor_E);
     __motor(2, Motor_D);
     if (((BtC == 1) && (Garra < 180))) {
         Garra += VariaGarra;
     }
     if (((BtZ == 1) && (Garra > 0))) {
         Garra -= VariaGarra;
     }
     __PWM1 = Garra;
}
 
//Funcao Principal
void main(void)
{
     __inicializa;
     __SmartSensorCmd(1, 1, 8, 0);
     bitset(__TRIS_PWM, __DIGITAL3);
     bitset(__TRIS_PWM, __DIGITAL2);
     __delay(1000);
     while(TRUE) {
         __PWM3 = 20;
         __PWM2 = 89;
         __motor_curso(__FORWARD);
         if ((__UltrasonicGetValueMM(1) < 300)) {
             Freio();
             __PWM2 = 180;
             dir_ultrasson = __UltrasonicGetValueMM(1);
             __delay(1000);
             __PWM2 = 0;
             esq_ultrasson = __UltrasonicGetValueMM(1);
             __delay(1000);
             __motor_curso(__BACKWARD);
             __delay(1000);
             if ((dir_ultrasson < esq_ultrasson)) {
                 __motor_curso(__LEFT_TURN);
                 __delay(800);
             }
             else {
                 __motor_curso(__LEFT_TURN);
                 __delay(800);
             }
         }
     }
 
     while(TRUE) { }
}

Descrição

ultrasson lokao

Nenhum Comentário

Download


Entre para Baixar

Favorito de


Ninguém marcou este projeto como favorito ainda.

Projetos de C2C00588


 0    2102   7 
 0    2195   0 
 0    2077   1 
 1    1958   2 
 4    2090   3