<?xml version="1.0" encoding="UTF-8"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="pl-pl">
<link rel="self" type="application/atom+xml" href="https://forum.atnel.pl/feed.php?f=4&amp;t=12284&amp;mode" />

<title>ATNEL tech-forum</title>
<link href="https://forum.atnel.pl/index.php" />
<updated>2015-09-01T06:25:29+01:00</updated>

<author><name><![CDATA[ATNEL tech-forum]]></name></author>
<id>https://forum.atnel.pl/feed.php?f=4&amp;t=12284&amp;mode</id>
<entry>
<author><name><![CDATA[LukasKL]]></name></author>
<updated>2015-09-01T06:25:29+01:00</updated>
<published>2015-09-01T06:25:29+01:00</published>
<id>https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=138781#p138781</id>
<link href="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=138781#p138781"/>
<title type="html"><![CDATA[Re: Kod w C do obsługi AT42QT1070]]></title>

<content type="html" xml:base="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=138781#p138781"><![CDATA[
W jaki sposób można wyeliminować wpływ wody na takim czujniku? Jest to możliwe?<p>Statystyki: Napisane przez <a href="https://forum.atnel.pl/memberlist.php?mode=viewprofile&amp;u=10258">LukasKL</a> — 1 wrz 2015, o 06:25</p><hr />
]]></content>
</entry>
<entry>
<author><name><![CDATA[LukasKL]]></name></author>
<updated>2015-07-16T21:57:24+01:00</updated>
<published>2015-07-16T21:57:24+01:00</published>
<id>https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134760#p134760</id>
<link href="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134760#p134760"/>
<title type="html"><![CDATA[Re: Kod w C do obsługi AT42QT1070]]></title>

<content type="html" xml:base="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134760#p134760"><![CDATA[
Wkońcu przyszedł moduł. Niestety dziwnie się zachowuje i nie wiem dlaczego. <br />Moduł wygląda tak.<br /><!-- m --><a class="postlink" href="http://www.tme.eu/pl/Document/f7fbc3ec4cec4c9b1c499c612fe65628/MOD-42.pdf" >http://www.tme.eu/pl/Document/f7fbc3ec4 ... MOD-42.pdf</a><!-- m --><br /><br />Sprawdzam Stan na Pinie change:<br /><br />[syntax=c]int main(void)<br />{<br /> DDRD |=(1&lt;&lt;PD3);   //wyjscie dla diody<br /> DDRD &amp;=~(1&lt;&lt;PD2);  //pin na ktorym sprawdzam stan change<br />while(1)<br />{<br />if (!(PIND &amp; (1 &lt;&lt; 2)))<br />{<br /><br />        PORTD|=(1&lt;&lt;PD3);<br />}<br />else<br />{<br />       <br />PORTD &amp;= ~(1&lt;&lt;PD3);<br />}<br />}<br />}[/syntax]<br /><br />Dioda świeci tylko gdy nacisnę pole na KEY5. Co jest nie tak?<p>Statystyki: Napisane przez <a href="https://forum.atnel.pl/memberlist.php?mode=viewprofile&amp;u=10258">LukasKL</a> — 16 lip 2015, o 21:57</p><hr />
]]></content>
</entry>
<entry>
<author><name><![CDATA[LukasKL]]></name></author>
<updated>2015-07-12T12:28:43+01:00</updated>
<published>2015-07-12T12:28:43+01:00</published>
<id>https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134283#p134283</id>
<link href="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134283#p134283"/>
<title type="html"><![CDATA[Re: Kod w C do obsługi AT42QT1070]]></title>

<content type="html" xml:base="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134283#p134283"><![CDATA[
Nie mam jeszcze kontrolera pod ręką, ale wstępnie kod wyglądał by w taki sposób. W tym momencie nie jestem pewien czy prawidłowo napisałem funkcję odczytu dla QT (Read_QT). Jeżeli ktoś mógłby sprawdzić to wklejam również sekwencję odczytu z AT42QT1070. Zastanawiam się obecnie nad dwoma kwestiami. Sposobem odczytywania stanu przycisków oraz wyborem Resetu. <br />1. Czy używać Software Reset czy tak jak @RafPe Hardware. Software może sprawić problem pewnie w dalszej części programu, bo inicjalizuję go raz wysyłając pod adres 57 same jedynki i w taki sposób uruchamiam wewnętrzny watchdog kontrolera. A Hardwarowo mogę sterować nim kiedy chcę. <br /><br />2. W jaki sposób odczytać stan przycisków. Może dodam że chcę użyć przycisków w następujący sposób. Naciśnięcie jednego z przycisków przez jakiś dłuższy czas zaświeci odpowiednią diodę która będzie sygnalizowała włączenie urządzenia. Następnie kolejne włączenie tego samego przycisku zgasi tą diodę. Włączenie innych przycisków, ale już nie zależnie od długości trzymania wciśniętego przycisku zapali odpowiednią diodę i zgasi gdy przycisk zostanie zwolniony. I teraz czy użyć zewnętrznego przerwania, czy wewnętrznego (timer w trybie CTC i co 1 ms sprawdzać PIN Change?)<br /><br />3. Czy funkcja Read_QT jest napisana odpowiednio.<br /><a href="http://forum.atnel.pl/_obrazki/o/10258/9a43aa5f668d86d1d028756dd3898a65.png"  class="postlink"><img src="http://forum.atnel.pl/_obrazki/o/thumb/10258/9a43aa5f668d86d1d028756dd3898a65.png" alt="Obrazek" /></a><br />[syntax=c]#include &lt;avr/io.h&gt;//definicje rejestrów I/O<br />#include &lt;util/delay.h&gt;//definicje rejestrów i przerwań<br />#include &lt;stdint.h&gt;//definicje pochodnych typów całkowitych<br />#include &lt;avr/interrupt.h&gt;//definicje związane z obsługą przerwań<br />#include &lt;stdio.h&gt;  <br />#include &lt;util/twi.h&gt;<br /><br />#define Tadr 0x1b//Adres Slave<br />#define Tadr_W 0x36 //Adres Slave +W<br />#define Tadr_R 0x37////Adres Slave +R<br /><br />void I2C_Init()<br />{<br />TWCR = (1&lt;&lt;TWEA)|(1&lt;&lt;TWEN);<br />TWBR = 0x05;//max f = 400kHz, przy SCLfreq=Fcpu/(16+2(TWBR)*TWSRdla 8Mhz około 300kHz<br />//TWSR = (1&lt;&lt;TWPS1)|(1&lt;&lt;TWPS0);//Preskaler 1 <br />}<br /><br />static inline void I2C_WaitForComplete()<br />{<br />while (!(TWCR &amp; (1&lt;&lt;TWINT)));<br />}<br /><br /><br />void I2C_Start()<br />{<br />TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWSTA)|(1&lt;&lt;TWEN);<br />I2C_WaitForComplete();<br />}<br /><br />void I2C_STOP()<br />{<br />TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWSTO)|(1&lt;&lt;TWEN);<br />}<br /><br />static inline void I2C_WaitTillStopWasSent()<br />{<br />while ((TWCR &amp; (1&lt;&lt;TWSTO)));<br />}<br /><br />void I2C_SentAddr(uint8_t addres)<br />{<br />TWDR = addres;<br />TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWEN);<br />I2C_WaitForComplete();<br />}<br /><br />void I2C_SendByte(uint8_t byte)<br />{<br />TWDR = byte;<br />TWCR= TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWEN);<br />I2C_WaitForComplete();<br />}<br /><br />uint8_t I2C_ReceiveData_NACK()<br />{<br />TWCR= TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWEN);<br />I2C_WaitForComplete();<br />return TWDR;<br />}<br /><br />uint8_t I2C_ReceiveData_ACK()<br />{<br />TWCR=(1&lt;&lt;TWINT)|(1&lt;&lt;TWEN)|(1&lt;&lt;TWEA);<br />I2C_WaitForComplete();<br />return TWDR;<br />}<br /><br />void Write_QT(uint8_t adr,uint8_t value)<br />{<br />I2C_Start();//wysłanie bitu start<br />I2C_SentAddr(Tadr_W);//wysłanie adresu urzadzenia+W (0)<br />I2C_SendByte(adr);<br />I2C_SendByte(value);<br />I2C_STOP();<br />I2C_WaitTillStopWasSent();<br /><br />}<br /><br />uint8_t Read_QT(uint8_t adr)<br />{<br />uint8_t data;//zmienna zwracana z funkcji<br />I2C_Start();//wysłanie bitu START<br />I2C_SentAddr(Tadr_W);//wysłanie Slave Adres+W (0);<br />I2C_SendByte(adr);//wysłanie MEMAdress<br />I2C_STOP();//wysłanie bitu STOP<br />I2C_WaitTillStopWasSent();//Czekam <br />I2C_Start();//wysłanie bitu START<br />I2C_SentAddr(Tadr_R);//wysłanie Slave Adres+R (1)<br />data = I2C_ReceiveData_ACK();<br />I2C_STOP();<br />I2C_WaitTillStopWasSent();<br />return data;<br />}<br /><br />void Threshold_Level_Key()//współczynniki narazie wybieram domyślnie na połowę czułości<br />{<br />Write_QT(32,128);//Key 0<br />Write_QT(33,128);//Key 1<br />Write_QT(34,128);//Key 2<br />Write_QT(35,128);//Key 3<br />Write_QT(36,128);//Key 4<br />Write_QT(37,128);//Key 5<br />Write_QT(38,128);//Key 6<br />}<br /><br />int main(void)<br />{<br />Write_QT(57,0xff);//Reset<br />_delay_ms(350);//nie wiem jaki czas ale bezpiecznie wybieram większy<br />Threshold_Level_Key();//Inicjazlizacja nacisku klawiszy<br /><br />}[/syntax]<p>Statystyki: Napisane przez <a href="https://forum.atnel.pl/memberlist.php?mode=viewprofile&amp;u=10258">LukasKL</a> — 12 lip 2015, o 12:28</p><hr />
]]></content>
</entry>
<entry>
<author><name><![CDATA[RafPe]]></name></author>
<updated>2015-07-12T12:11:37+01:00</updated>
<published>2015-07-12T12:11:37+01:00</published>
<id>https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134282#p134282</id>
<link href="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134282#p134282"/>
<title type="html"><![CDATA[Re: Kod w C do obsługi AT42QT1070]]></title>

<content type="html" xml:base="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134282#p134282"><![CDATA[
Tak zeby inni tez mogli skorzystac <img src="https://forum.atnel.pl/images/smilies/icon_e_biggrin.gif" alt=":D" title="Bardzo szczęśliwy" /> udziele Ci odpowiedzi w tym temacie :<br />1) Ja podciagalem i uzywalem hardware resetu byl dla mnie po prostu niezawodny<br /><br />2) JEsli chodzi o obsluge kodu zrodlowego to mialem cos w stylu :<br /><br />Dla inicjalizacji : <br />[syntax=c]i2cSetBitrate( 100 );         // USTAWIAMY prędkość 100 kHz na magistrali I2C<br /><br />sei();// Globalne wlaczenie przerwan<br /><br />QT1070_Init();// Inicjalizacja[/syntax]<br /><br />enum dla dostepu do rejestrow<br /><br />[syntax=c]enum { // Qtouch memory address registers<br />QT_CHIP_ID = 0,<br />QT_FIRMWARE_VERSION,<br />QT_DETECTION_STATUS,<br />QT_KEY_STATUS,<br />QT_KEY0_SIGNAL,<br />QT_KEY1_SIGNAL = 6,<br />QT_KEY2_SIGNAL = 8,<br />QT_KEY3_SIGNAL = 10,<br />QT_KEY4_SIGNAL = 12,<br />QT_KEY5_SIGNAL = 14,<br />QT_KEY6_SIGNAL = 16,<br />QT_KEY0_REFERENCE = 18,<br />QT_KEY1_REFERENCE = 20,<br />QT_KEY2_REFERENCE = 22,<br />QT_KEY3_REFERENCE = 24,<br />QT_KEY4_REFERENCE = 26,<br />QT_KEY5_REFERENCE = 28,<br />QT_KEY6_REFERENCE = 30,<br />QT_KEY0_NTHR = 32,<br />QT_KEY1_NTHR,<br />QT_KEY2_NTHR,<br />QT_KEY3_NTHR,<br />QT_KEY4_NTHR,<br />QT_KEY5_NTHR,<br />QT_KEY6_NTHR,<br />QT_KEY0_AVE_AKS = 39,<br />QT_KEY1_AVE_AKS,<br />QT_KEY2_AVE_AKS,<br />QT_KEY3_AVE_AKS,<br />QT_KEY4_AVE_AKS,<br />QT_KEY5_AVE_AKS,<br />QT_KEY6_AVE_AKS,<br />QT_KEY0_DI = 46,<br />QT_KEY1_DI,<br />QT_KEY2_DI,<br />QT_KEY3_DI,<br />QT_KEY4_DI,<br />QT_KEY5_DI,<br />QT_KEY6_DI,<br />QT_FO_MO_GDNO=53,<br />QT_LP,<br />QT_MAX_ON_DURATION,<br />QT_CALIBRATE,<br />QT_RESET,<br />};[/syntax]<br /><br />Jako ze w ukladzie mialem Guard button to konfigurowalem go sobie - ale ze nie zrobilem komentarzy to mussiz zobacyc w DS co dokladnie ustawialem <img src="https://forum.atnel.pl/images/smilies/icon_e_biggrin.gif" alt=":D" title="Bardzo szczęśliwy" /> <br /><br />[syntax=c]QT1070_WriteI2C(QT_FO_MO_GDNO, 0x07);<br />QT1070_WriteI2C(QT_KEY6_NTHR, 23);[/syntax]<br /><br /><br />Nastepnie realizujesz wykrycie dotkniecia guzika (po zmianie stanu na pinie change) i odczytujesz sobie ktory guzk zostal nacisniety - ja mialem taka funkcje <br /><br />[syntax=c]/*<br /> * Funkcja odpowiedzialna za zdarzenie jakim jest dotkniecie guzika<br /> * Jako parametr podajemy wskaznik do uint8_t ktory bedzie przechowywal wartosci<br /> * klawiszy<br /> */<br />void ATQ1070_TOUCH_EVENT(uint8_t * ptrKeyStatus)<br />{<br />#if QT_USE_FLAG// Jesli uzywamy flagi do sygnalizacji ze nastpial &quot;dotyk&quot;<br /><br /><br />if(change_flag)<br /><br /><br />#else// Jesli uzywamy portu<br />if( QT_STATUS_CHANGE )// Jesli<br /><br />#endif<br /><br />{<br /><br />if (!config_flag) QT1070_ReadI2C(QT_KEY_STATUS ,ptrKeyStatus);// Musimy odczytac rejestr aby flaga przerwania w QTouch'u byla zresetowana<br /><br />if( ATQ1070_touch_event_callback )// Zarejestrowany Call Back ?<br />{<br />(*ATQ1070_touch_event_callback)( ptrKeyStatus );// Przekazujemy dalej do analizy<br /><br />#if QT_USE_FLAG// Jesli uzywamy flagi do sygnalizacji ze nastpial &quot;dotyk&quot;<br />change_flag= 0;// zerujemy flage<br />#endif<br />}<br /><br />}<br /><br />}[/syntax]<br /><br /><br />Dla Ciebie najbardziej interesujacy powinien byc watek tu <br /><br />[syntax=c]QT1070_ReadI2C(QT_KEY_STATUS ,ptrKeyStatus);[/syntax]<br /><br />Bo to wlasnie tutaj odczytasz rejestr i zadecydujesz co dalej <img src="https://forum.atnel.pl/images/smilies/icon_e_biggrin.gif" alt=":D" title="Bardzo szczęśliwy" /><br /><br /><br />Mam nadzieje , ze to Co pomoze dalej<p>Statystyki: Napisane przez <a href="https://forum.atnel.pl/memberlist.php?mode=viewprofile&amp;u=4344">RafPe</a> — 12 lip 2015, o 12:11</p><hr />
]]></content>
</entry>
<entry>
<author><name><![CDATA[RafPe]]></name></author>
<updated>2015-07-11T21:44:21+01:00</updated>
<published>2015-07-11T21:44:21+01:00</published>
<id>https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134230#p134230</id>
<link href="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134230#p134230"/>
<title type="html"><![CDATA[Re: Kod w C do obsługi AT42QT1070]]></title>

<content type="html" xml:base="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134230#p134230"><![CDATA[
@LukasKL : ja sie nad chipem dluuuuugo glowilem i pomagal mi nasz guru Mirek. <br /><br />Ogolnie zdefiniowalem sobie kilka &quot;pomocnikow&quot; <img src="https://forum.atnel.pl/images/smilies/icon_e_biggrin.gif" alt=":D" title="Bardzo szczęśliwy" /> <br /><br />[syntax=c]#define QT_PORT_RESET D// Definicja PORTU na ktorym jest PIN do resetu<br />#define QT_REGISTER_RESET  7// Definicja na ktorym PINIE jest RESET<br /><br />#define QT_USE_FLAG 0// Zdefiniowanie czy uzywamy FLAGI czy bedziemy uzywac zdefiniowanego PORTU<br /><br />#if  QT_USE_FLAG == 0<br />#define QT_PIN_CHANGE C<br />#define QT_REGISTER_CHANGE  7<br />#define QT_STATUS_CHANGE        !(PIN(QT_PIN_CHANGE) &amp; (1 &lt;&lt; QT_REGISTER_CHANGE))// Makro sprawdzajace stan niski dla naszej lini CHANGE<br />#endif<br /><br />#define QT_DEVICE_ID0x2E    // Chip ID (read from device-address 0)<br />#define QT_I2C_ADDRESS0x1B// Qtouch device ID<br />#define QT_I2C_ADDRESS_W (QT_I2C_ADDRESS &lt;&lt; 1)// Definicja adresu I2C tzw SLA+W<br />#define QT_I2C_ADDRESS_R    ((QT_I2C_ADDRESS &lt;&lt;1)|1) // Definicja adresu I2C tzw SLA+R<br />#define QT_CONFIG_ADDR32// Adres od ktorego mozemy uzyc struktury do konfiguracji do odczytu z I2C[/syntax]<br /><br />W taki oto sposob mialem pod reka adresy R/W . Dodatkowo mialem enum dla wszystkich rejestrow ale to jest w pliku co wrzucilem wiec nie bede dublowac.<br /> <br />Nastepnie to co jest wazne - RESET musial byc koniecznie dobrze podlaczony. Ten kawalek sprawil mi duzo problemow w komunikacji. <br /><br />Pozniej mialem funkcje do resetu oraz inicjalizacji <br /><br />[syntax=c]/*<br /> * Funkcja odpowiedzialna za zresetowanie urzadzenia uzywajac PINU zdefiniowanego<br /> * w naglowku<br /> */<br />void QT1070_Hardware_Reset( void )<br />{<br />DDR(QT_PORT_RESET) |= (1 &lt;&lt; QT_REGISTER_RESET);// Ustawiamy port jako wyjscia<br /><br />    PORT(QT_PORT_RESET) &amp;= ~(1 &lt;&lt; QT_REGISTER_RESET); // RESET LOW<br /><br />    _delay_us(15); // Reset musi byc aktywny conajmniej 15us<br /><br />PORT(QT_PORT_RESET) |= (1 &lt;&lt; QT_REGISTER_RESET);  // RESET High<br /><br />_delay_ms(200);// Taki czas znalazlem ze jest dobrze poczekac na inicjalizacje<br />}[/syntax]<br /><br /><br />Do komunikacji uzylem Mirkowych bibilotek do I2C z nastepujacymi zasadami - *z oczywistych powodow nie publikuje kodow <img src="https://forum.atnel.pl/images/smilies/icon_e_biggrin.gif" alt=":D" title="Bardzo szczęśliwy" /><br /><br />[syntax=c]Start<br />write -&gt; SLA+W<br />write -&gt; Address<br />write -&gt; Stop<br />Start<br />write-&gt; SLA+R<br />Odczytanie wartosci dokopoki nie ma ACK<br />odczytanie -&gt; NACK<br />STOP[/syntax]<br /><br />A do zapisu <br /><br />[syntax=c]Start<br />write-&gt;SLA+W<br />write-&gt;Address<br />write-&gt;Zapisujemy nasze dane<br />STOP[/syntax]<br /><br />Obsluge momentu dotknieca poprzez przerwania i callbacki. Mam nadzieje , ze to Ci pomoze!<p>Statystyki: Napisane przez <a href="https://forum.atnel.pl/memberlist.php?mode=viewprofile&amp;u=4344">RafPe</a> — 11 lip 2015, o 21:44</p><hr />
]]></content>
</entry>
<entry>
<author><name><![CDATA[Zaba]]></name></author>
<updated>2015-07-11T18:55:25+01:00</updated>
<published>2015-07-11T18:55:25+01:00</published>
<id>https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134210#p134210</id>
<link href="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134210#p134210"/>
<title type="html"><![CDATA[Re: Kod w C do obsługi AT42QT1070]]></title>

<content type="html" xml:base="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134210#p134210"><![CDATA[
Kod umieszczaj w znacznikach 'syntax=c'<br /><br /><br />A jeśli chodzi o odbiór kilku danych to musiałbyś mieć jakiś bufor i do niego odczytać<br />wartość danego rejestru/rejestrów tylko do funkcji Read_QT oprócz adresu trzeba by było<br />dodać jeszcze argument mówiący ile danych ma odczytać .<br /><br /> Jeśli dane byłyby tylko ośmiobitowe<br />to można zwrócić przez wartość funkcji<br /><br />[syntax=c]uint8_t Read_QT(uint8_t adr){<br /><br />.....<br />.....<br /><br />return I2C_ReceiveData_ACK()    // lub I2C_ReceiveData_NACK()<br /><br />}[/syntax]<br /><br />Nie znam protokołu komunikacji z tym scalakiem, ale szczegóły znajdziesz w DS<p>Statystyki: Napisane przez <a href="https://forum.atnel.pl/memberlist.php?mode=viewprofile&amp;u=1044">Zaba</a> — 11 lip 2015, o 18:55</p><hr />
]]></content>
</entry>
<entry>
<author><name><![CDATA[LukasKL]]></name></author>
<updated>2015-07-11T17:59:13+01:00</updated>
<published>2015-07-11T17:59:13+01:00</published>
<id>https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134208#p134208</id>
<link href="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134208#p134208"/>
<title type="html"><![CDATA[Kod w C do obsługi AT42QT1070]]></title>

<content type="html" xml:base="https://forum.atnel.pl/viewtopic.php?t=12284&amp;p=134208#p134208"><![CDATA[
Witam czy mógłby ktoś sprawdzić mój kod do obsługi kontrolera AT42QT1070. Napisałem na podstawie książki funkcje wysyłające bit Startu Stopu, wysyłające bajt danych i odczytujące bajt danych. Proszę o sprawdzenie czy poprawnie napisałem Funkcję wysyłającą do kontrolera (Write_QT) i podpowiedź jak dokończyć funkcję odczytującą (Read_QT). Zastanawiam się jeszcze nad adresem urządzenia w trybie zapisu i odczytu. Adres kontrolera wynosi 0x1b czy dobrze zdefiniowałem adres przy zapisie (Tadr_W) i odczycie (Tadr_R)? Pozdrawiam<br />Link do AT42QT1070<br /><!-- m --><a class="postlink" href="http://www.atmel.com/images/atmel-9596-at42-qtouch-bsw-at42qt1070_datasheet.pdf" >http://www.atmel.com/images/atmel-9596- ... asheet.pdf</a><!-- m --><br /><div class="codetitle"><b>Code:</b></div><div class="codecontent">#include &lt;avr/io.h&gt;         //definicje rejestrów I/O<br />#include &lt;util/delay.h&gt;         //definicje rejestrów i przerwań<br />#include &lt;stdint.h&gt;         //definicje pochodnych typów całkowitych<br />#include &lt;avr/interrupt.h&gt;      //definicje związane z obsługą przerwań<br />#include &lt;stdio.h&gt;  <br />#include &lt;util/twi.h&gt;<br /><br />#define Tadr_W 0x36 <br />#define Tadr_R 0x37<br /><br />void I2C_Init()<br />{<br />   TWCR = (1&lt;&lt;TWEA)|(1&lt;&lt;TWEN);   <br />   TWBR = 0x05;   //max f = 400kHz, przy SCLfreq=Fcpu/(16+2(TWBR)*TWSR   dla 8Mhz około 300kHz<br />//   TWSR = (1&lt;&lt;TWPS1)|(1&lt;&lt;TWPS0);   //Preskaler 1 <br />}<br /><br />static inline void I2C_WaitForComplete()<br />{<br />   while (!(TWCR &amp; (1&lt;&lt;TWINT)));<br />}<br /><br /><br />void I2C_Start()<br />{<br />   TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWSTA)|(1&lt;&lt;TWEN);<br />   I2C_WaitForComplete();         <br />}<br /><br />void I2C_STOP()<br />{<br />   TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWSTO)|(1&lt;&lt;TWEN);<br />}<br /><br />static inline void I2C_WaitTillStopWasSent()<br />{<br />   while ((TWCR &amp; (1&lt;&lt;TWSTO)));<br />}<br /><br />void I2C_SentAddr(uint8_t addres)<br />{<br />   TWDR = addres;<br />   TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWEN);<br />   I2C_WaitForComplete();<br />}<br /><br />void I2C_SendByte(uint8_t byte)<br />{<br />   TWDR = byte;<br />   TWCR= TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWEN);<br />   I2C_WaitForComplete();<br />}<br /><br />uint8_t I2C_ReceiveData_NACK()<br />{<br />   TWCR= TWCR = (1&lt;&lt;TWINT)|(1&lt;&lt;TWEN);<br />   I2C_WaitForComplete();<br />   return TWDR;<br />}<br /><br />uint8_t I2C_ReceiveData_ACK()<br />{<br />   TWCR=(1&lt;&lt;TWINT)|(1&lt;&lt;TWEN)|(1&lt;&lt;TWEA);<br />   I2C_WaitForComplete();<br />   return TWDR;<br />}<br /><br />void Write_QT(uint8_t adr,uint8_t value)<br />{<br />   I2C_Start();      //wysłanie bitu start<br />   I2C_SentAddr(Tadr_W);   //wysłanie adresu urzadzenia+W (0)<br />   I2C_SendByte(adr);<br />   I2C_SendByte(value);<br />   I2C_STOP();<br />   I2C_WaitTillStopWasSent();<br />}<br /><br />uint8_t Read_QT(uint8_t adr)<br />{<br />   I2C_Start();      //wysłanie bitu start<br />   I2C_SentAddr(Tadr_W);   //wysłanie adresu urzadzenia+W (0);<br />   I2C_SendByte(adr);<br />   I2C_STOP();<br />   I2C_WaitTillStopWasSent();<br />   I2C_Start();<br />   I2C_SentAddr(Tadr_R);   //i co dalej??<br />}<br />int main(void)<br />{<br /><br />}<br /></div><p>Statystyki: Napisane przez <a href="https://forum.atnel.pl/memberlist.php?mode=viewprofile&amp;u=10258">LukasKL</a> — 11 lip 2015, o 17:59</p><hr />
]]></content>
</entry>
</feed>