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

N3DohmsLimite_q_deu_errado

de C2C00588 |  v1 |  0 |  1 |  1950 |  2 
Acesse sua conta para comentar e baixar este programa.

Compartilhado há 6 anos atrás
Alguns direitos reservados
// n3dohmslimite_q_deu_errado.c - Criado pelo studio UNO 2.3
// 4 July 2016 11:38:05 am
 
#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 JoyX;
unsigned char JoyY;
int Motor_D;
int Motor_E;
unsigned int Pulsos;
int eixo_x;
int eixo_y;
unsigned char ir1_limite;
unsigned char ir5_limite;
 
// Prototipos
void ControleMotores(void); 
void GiraDireita(void); 
void ControleRF(void); 
void ZeraEncoders(void); 
void Freio(void); 
void ControleJoy(void); 
void LeRF(void); 
void GiraEsquerda(void); 
void AjusteLimites(void); 
 
//Funcoes do Usuario
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;
}
 
void GiraDireita(void) 
{
     ZeraEncoders();
     Pulsos = (Graus / 4.9);
     __motor_curso(__RIGHT_ROTATE);
     __lcd_goto(0x7f, 9);
     __lcd_puts("%u", Pulsos);
     while((__EncoderGetValue(1) < Pulsos)) {
         while(!(__EncoderGetValue(1) >= Pulsos)) { __delay(10); }
         __lcd_goto(0xbf, 9);
         __lcd_puts("%d", __EncoderGetValue(2));
         __delay(tempo);
     }
 
}
 
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 ZeraEncoders(void) 
{
     __SmartSensorCmd(1, 1, 9, 0);
     __delay(tempo);
     __SmartSensorCmd(1, 2, 9, 0);
     __delay(tempo);
}
 
void Freio(void) 
{
     __motor_curso(__REVERSE);
     __delay(30);
     __motor_curso(__STOP);
}
 
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 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 GiraEsquerda(void) 
{
     ZeraEncoders();
     Pulsos = (Graus / 4.9);
     __motor_curso(__LEFT_ROTATE);
     __lcd_goto(0x7f, 1);
     __lcd_puts("%u", Pulsos);
     while((__EncoderGetValue(2) < Pulsos)) {
         while(!(__EncoderGetValue(2) >= Pulsos)) { __delay(10); }
         __lcd_goto(0xbf, 1);
         __lcd_puts("%d", __EncoderGetValue(1));
         __delay(tempo);
     }
 
}
 
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;
     }
 
}
 
//Funcao Principal
void main(void)
{
     __inicializa;
     __backlight(__ON);
     __SmartSensorCmd(1, 1, 8, 0);
     bitset(__TRIS_PWM, __DIGITAL1);
     __PWM1 = 180;
     Garra = 180;
     Graus = 90;
     ir1_limite = (__SeguidorGetAnalog(1, 1) - 10);
     ir5_limite = (__SeguidorGetAnalog(1, 5) - 10);
     while(TRUE) {
         __motor_curso(__FORWARD);
         if ((__SeguidorGetAnalog(1, 1) < ir1_limite)) {
             __motor_curso(__BACKWARD);
             __delay(400);
             Freio();
             __delay(400);
             GiraDireita();
         }
         if ((__SeguidorGetAnalog(1, 5) < ir5_limite)) {
             __motor_curso(__BACKWARD);
             __delay(400);
             Freio();
             __delay(400);
             GiraEsquerda();
         }
     }
 
     while(TRUE) { }
}

Descrição

Usando o controle RF dando errado

1 Comentário

Download


Entre para Baixar

Favorito de


Ninguém marcou este projeto como favorito ainda.

Projetos de C2C00588


 0    1823   0 
 0    1933   7 
 0    1879   2 
 0    1989   0 
 0    1919   2