Vítejte na Elektro Bastlírn?
Nuke - Elektro Bastlirna
  Vytvořit účet Hlavní · Fórum · DDump · Profil · Zprávy · Hledat na fóru · Příspěvky na provoz EB

Vlákno na téma KORONAVIRUS - nutná registrace


Nuke - Elektro Bastlirna: Diskuzní fórum

 FAQFAQ   HledatHledat   Uživatelské skupinyUživatelské skupiny   ProfilProfil   Soukromé zprávySoukromé zprávy   PřihlášeníPřihlášení 

Sériová linka - příjem dat BASCOM
Jdi na stránku Předchozí  1, 2
 
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Programování PIC, ATMEL, EEPROM a dalších obvodů
Zobrazit předchozí téma :: Zobrazit následující téma  
Autor Zpráva
radar0101



Založen: Jun 15, 2010
Příspěvky: 20

PříspěvekZaslal: pá červen 25 2010, 18:01    Předmět: Citovat

ale furt je u inputbin problem s ti ze to na ty data ceka...to je taky na prd:(
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
Andrea



Založen: Sep 07, 2007
Příspěvky: 9340

PříspěvekZaslal: pá červen 25 2010, 18:07    Předmět: Citovat

Pokud nechceš na ty data čekat, tak je přijímej asynchronně v přerušení od USARTu.
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
AB1



Založen: Nov 23, 2009
Příspěvky: 312

PříspěvekZaslal: pá červen 25 2010, 20:30    Předmět: Citovat

Asi by bylo dobré vysílat synchronizační bajt, řekněme 255, a za ním vždy 8 hodnot 0-254 pro serva 1-8.
Přijímat pak můžeš třeba takto:
kód:
$hwstack = 128
$swstack = 64
$framesize = 64
$baud = 9600

Config Serialin = Buffered , Size = 40       ' set buffer on the USART input

Dim Servo(8) As Byte          'hodnoty pro serva 1-8
Dim Prijaty_bajt As Byte

   Enable Interrupts          'přijímací bufer používá přerušení

   Do
      If Ischarwaiting() = 1 Then
         Prijaty_bajt = Inkey()

           If Prijaty_bajt = 255 Then
              Inputbin Servo(1) , 8       ' přijmi 8 bajtů a ulož do pole "Servo"
           End If
      End If

   Loop

End
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
radar0101



Založen: Jun 15, 2010
Příspěvky: 20

PříspěvekZaslal: pá červen 25 2010, 21:04    Předmět: Citovat

Moc děkuju ale bohuzel bych to potreboval jeste trosicku upravit...ja mam synchronizační 255 potom mezera a hodnota 0 az 8 to je cislo serva pak zas mezera a je tu 3 byt a tem ma hodnotu 0 až 254...Tak jsem myslel že bych moh takhle upravit ten tvuj kod ale bohuzel to takhle nefaka..asi to bude tou mezerou mezi cislem serva a jeho nastavovaci hodnotou.
Jinak moc dik i za tohle řešeni.
kód:

If Ischarwaiting() = 1 Then
         Prijaty_bajt = Inkey()

           If Prijaty_bajt = 255 Then
              Inputbin Servo(1) , 2                         ' přijmi 8 bajtů a ulož do pole "Servo"
           End If
      End If

Select Case Servo(1)
Case 0 : Servo0 = Servo(2)
Case 1 : Servo1 = Servo(2)
Case 2 : Servo2 = Servo(2)
Case 3 : Servo3 = Servo(2)
End Select
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
radar0101



Založen: Jun 15, 2010
Příspěvky: 20

PříspěvekZaslal: pá červen 25 2010, 21:48    Předmět: Citovat

tak zase ja.. pokusil jsem se pro ten muj pripad vymyslet dalsi reseni ale zas nic _ nejde to:(
kód:

If Krok = 1 And Ischarwaiting() = 1 Then

    B = Inkey()
    If B = 255 Then Krok = 2

End If


If Krok = 2 And Ischarwaiting() = 1 Then

    C = Inkey()
    Krok = 3

End If


If Krok = 3 And Ischarwaiting() = 1 Then

    D = Inkey()

    Select Case C
    Case 0 : Servo0 = D
    Case 1 : Servo1 = D
    Case 2 : Servo2 = D
    End Select

    Krok = 0

End If
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
AB1



Založen: Nov 23, 2009
Příspěvky: 312

PříspěvekZaslal: so červen 26 2010, 6:19    Předmět: Citovat

Zdá se že kód zbytečně komplikuješ.
Předpokládám, že "mezera" při vysílání je časová prodleva, ne znak mezery (ascii 32).
Data tedy vypadají takto:
255 - cislo_serva - hodnota_serva - 255 - cislo_serva - hodnota_serva........
kód:
Dim Servo(8) As Byte
Dim Temp As Byte
Dim Cislo As Byte
Dim Hodnota As Byte

   Enable Interrupts
   Do
      If Ischarwaiting() = 1 Then
         Temp = Inkey()

           If Temp = 255 Then
              Inputbin Cislo
              Inputbin Hodnota
              Servo(cislo) = Hodnota
           End If

      End If

   Loop

End

Pro časování serv použij hodnoty z pole "Servo()".
Návrat nahoru
Zobrazit informace o autorovi Odeslat soukromou zprávu
Zobrazit příspěvky z předchozích:   
Přidat nové téma   Zaslat odpověď       Obsah fóra Diskuzní fórum Elektro Bastlírny -> Programování PIC, ATMEL, EEPROM a dalších obvodů Časy uváděny v GMT + 1 hodina
Jdi na stránku Předchozí  1, 2
Strana 2 z 2

 
Přejdi na:  
Nemůžete odesílat nové téma do tohoto fóra.
Nemůžete odpovídat na témata v tomto fóru.
Nemůžete upravovat své příspěvky v tomto fóru.
Nemůžete mazat své příspěvky v tomto fóru.
Nemůžete hlasovat v tomto fóru.
Nemůžete připojovat soubory k příspěvkům
Můžete stahovat a prohlížet přiložené soubory

Powered by phpBB © 2001, 2005 phpBB Group
Forums ©
Nuke - Elektro Bastlirna

Informace na portálu Elektro bastlírny jsou prezentovány za účelem vzdělání čtenářů a rozšíření zájmu o elektroniku. Autoři článků na serveru neberou žádnou zodpovědnost za škody vzniklé těmito zapojeními. Rovněž neberou žádnou odpovědnost za případnou újmu na zdraví vzniklou úrazem elektrickým proudem. Autoři a správci těchto stránek nepřejímají záruku za správnost zveřejněných materiálů. Předkládané informace a zapojení jsou zveřejněny bez ohledu na případné patenty třetích osob. Nároky na odškodnění na základě změn, chyb nebo vynechání jsou zásadně vyloučeny. Všechny registrované nebo jiné obchodní známky zde použité jsou majetkem jejich vlastníků. Uvedením nejsou zpochybněna z toho vyplývající vlastnická práva. Použití konstrukcí v rozporu se zákonem je přísně zakázáno. Vzhledem k tomu, že původ předkládaných materiálů nelze žádným způsobem dohledat, nelze je použít pro komerční účely! Tento nekomerční server nemá z uvedených zapojení či konstrukcí žádný zisk. Nezodpovídáme za pravost předkládaných materiálů třetími osobami a jejich původ. V případě, že zjistíte porušení autorského práva či jiné nesrovnalosti, kontaktujte administrátory na diskuzním fóru EB.


PHP-Nuke Copyright © 2005 by Francisco Burzi. This is free software, and you may redistribute it under the GPL. PHP-Nuke comes with absolutely no warranty, for details, see the license.
Čas potřebný ke zpracování stránky 0.14 sekund