Ir ao conteúdo
  • Cadastre-se
Entre para seguir isso  
Edy Junior

Bioskey

Recommended Posts

Estou tendo dificuldades para usar a função bioskey, que não funciona como pretendido. Alguém tem uma maneira bem fácil de explicar como usá-la?

É que preciso usá-la em um trabalho, e não funciona muito bem. Tem algum material na internet que possa eu possa ler, ou alguém conhece um tutorial bem simples da bioskey?

Não me peçam pra dar uma olhada na função bioskey que tem como exemplo no próprio C. Uso Turbo C 3.0.

Desde já agradeço!

Compartilhar este post


Link para o post
Compartilhar em outros sites

Hm... a bioskey...


Sintaxe:
#include <bios.h>
int bioskey(int cmd);

Realiza operações com o teclado, usando a interrupção 0x16 da BIOS. O parâmetro cmd determina qual a função a ser executada.

O valor de retorno depende de qual tarefa foi realizada, determinada pelo parâmetro cmd.

Pelo menos é isso que tem no manual da Borland.

Não vejo nada de especial nessa função... ela serve prá detectar o pressionamento das teclas do teclado (inclusive o SHIFT, NumLock, Insert, etc).

Se quiser, compila esse programa no Turbo C (não reparem no modo como tá digitado, foi feito às pressas, acho que ainda dá prá otimizar o código; espero que tenha ficado claro o funcionamento dele :) ) :


#include <conio.h>
#include <time.h>
#include <stdlib.h>
#include <bios.h>

typedef unsigned char far * tmem;
typedef unsigned int far * tmemw;

void setrgb(char c, char r, char g, char {
    outp(0x3c8,c);
    outp(0x3c9,r);
    outp(0x3c9,g);
    outp(0x3c9,;
}

int main(void) {

   unsigned c, x, y, z;
   tmem m1, m2, m3, m4;
   tmemw mw;

   randomize();
   asm {
mov ax, 13h
int 10h
   }
   for (x=1; x<=32;x++) {
setrgb(x,   x*2-1, 0,     0    );
setrgb(x+32, 63,   x*2-1, 0    );
setrgb(x+64, 63,   63,    x*2-1);
setrgb(x+96, 63,   63,    63   );
   }

   do {
      x = 0;
      do {
  y = 60;
  do {
     m1=(tmem)(0xa0000000 | (y * 320 + x));
     m2=(tmem)(0xa0000000 | (y * 320 + x + 2));
     m3=(tmem)(0xa0000000 | (y * 320 + x - 2));
     m4=(tmem)(0xa0000000 | ((y-2) * 320 + x + 1));
     c = (*m1 + *m2 + *m3 + *m4) / 4;
     if (c!=0) c--;

     mw=(tmemw)(0xa0000000 | ((y-2) * 320 + x));
     *mw = (c << 8) + c;

     mw=(tmemw)(0xa0000000 | ((y-1) * 320 + x));
     *mw = (c << 8) + c;
     y+=2;
  } while (y <= 202);
  y-=2;
  *m1 = random(2) * 160;
  x+=2;
      } while (x < 320);
   } while (!bioskey(1));

   asm {
mov ax, 3
int 10h
   }
   return 0;
}

Vê? No último do while eu tô usando a função bioskey com o parâmetro 1, que retorna 0 se não há nenhuma tecla pressionada (nem existe nada esperando no buffer); se for pressionado Ctrl+Break, ela retorna -1; se for pressionada qualquer outra tecla, retorna o valor dela, mas sem removê-la do buffer do teclado.

Se o parâmetro for 0, ela espera aparecer algo no buffer do teclado e retorna o valor da tecla.

Não sei se tem algo mais complicado ainda... se precisar, posso fazer outro exemplinho com a bioskey, ok?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Obrigado Sr. Daniel seu post foi bem interessante, mas o que me ajudou mesmo foi a descoberta que a bioskey é um getch bem mais poderoso...

Compartilhar este post


Link para o post
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisar ser um membro para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora
Entre para seguir isso  





Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×