10 4.104 8051 9 Acquy adc pic All datasheet ALTIUM Altium Designer AM-FM Arduino ARM ARM là gì Ấn Tượng Bản tin công nghệ Bản tin Thiết Bị Số Barobo bất động sản biến Binary Bit board lpc2378 Bộ chuyển đổi ADC Bộ Đếm Bộ điều khiển cửa cuốn Bộ Định Thời Buy Khóa Số Điện Tử Buy Mạch đếm sản phẩm Buy Mạch giao thông Buy Mạch nạp Buy Matrix Byte C cho AVR các hàm vào ra các loại lõi arm các mạch DAC cơ bản các ngắt trong pic Cách đọc điện trở Cách Đọc Giá Trị Điện Trở Cách đọc giá trị tụ điện Cách hàn linh kiện dán cách làm mạch khóa số cách tạo linh kiện dán cad/cam Cài Đặt cài đặt proteus 8 cảm biến Cấu Kiện Logic Khả Trình cấu tạo cấu trúc arm cấu trúc lệnh CCS Chân chân Transistor Chip Khả Trình chuyển đổi Chuyển đổi số tương tự Chuyển Đổi Tương Tự/Số - ADC Chuyển động số chương trình City Clip Điện Tử Code 8051 - ASM Code 8051 - C Code 8051-C code ASM code ASM mẫu 8086 Code AVR - C code C Code Lập Trình Code led sao băng code maupic code mẫu 8051 Code Mẫu 8086 Code Mẫu cho ARM - LPC1343 code mẫu pic Code PIC - C codemaupic Counter Cổng Vào Ra Cơ Bản Cuộn Cảm Cửa cuốn DA DAC Debug Decimal Delay8051 Dev-C++ Diode DIY Dò đường Do It Yourself doanh nghiệp Download DTMF Mobile đảo chiều động cơ Điện Trở Điện Tử Điện Tử Cơ Bản điều chế độ rộng xung điều chế xung PWM điều khiển bằng điện thoại Điều khiển cửa cuốn Điều khiển cửa cuốn bằng điện thoại điều khiển động cơ đo điện áp đo nhiệt độ đo nhiệt độ hiển thị lên lcd trên 8051 Đo Nhiệt Độ LM35 + LCD Đo Nhiệt Độ LM35 + Led 7 thanh đọc màu điện trở đồ chơi động cơ chân không Động cơ nhiên liệu Động cơ robo đồng hồ thời gian thực Ebook Đại Học ebook điện tử Ebook đồ án Ebook Tin Học Encoder Encoder là gì Full Giải Thuật Giải thuật PID Giáo Dục giao tiếp i2c pic 16f877a giao tiếp i2c pic16f877a với ic ds1307 giao tiếp máy tính qua rs232 Giao Tiếp Máy Tính VB6 giao tiếp rs232 giao tiếp spi giữa 2 pic giao tiếp spi trong pic Giáo Trình Điện Tử Giới thiệu 8051 Giới thiệu cơ bản GPIO Graphic Design hàm Hàn linh kiện dán Hexadecimal Hệ Hexa Hệ Nhị Phân Hệ Thập Lục Phân Hệ Thập Phân hiển thị lên lcd 16x2 Hoạt Động Học Học 8051 qua các ví dụ đơn giản Học ALtium Designer học AVR Học Corel Draw X3 Học Eagle HỌC LẬP TRÌNH 16F877A Học Lập Trình 8051 Học Lập Trình C Học Orcad Học Protues hoc-lam-robot-do-duong-qua-video Hồng ngoại hướng dẫn hướng dẫn Altium Designer hướng dẫn đo đồng hồ VOM hướng dẫn keil - C lập trình 8051 hướng dẫn làm led sao băng hướng dẫn làm led trái tim hướng dẫn lập trình ARM Hướng Dẫn Lập Trình ARM - LPC1343 hướng dẫn lập trình ARM-LPC2378 hướng dẫn lập trình CCS hướng dẫn lập trình PIC Hướng Dẫn Led Trái Tim hướng dẫn module sim548c hướng dẫn sử dụng keil hướng dẫn sử dụng proteus 8 Hyper Terminal hercules 3.2.4 I/O IC 555 IC 7447 IC 74HC151 IC 74HC154 IC 74HC245 IC 74HC595 IC 74LS138 IC DS1307 IC đồng hồ thời gian thực IC LM324 IC LM342 IC LM7805 IC số IC số opamp LM324 IC Thông Dụng IC555 Interrupt Keil 4 Full keil arm Keil C Keil uVision3 kế toán kiểm toán khái niệm Khái Niệm Cơ Bản Kho Vật Liệu khóa điện tử khóa số dùng 8051 khóa số dùng 89s52 Khóa Số Điện Tử khuếch đại kiểm tra Kinh doanh maketing kinh tế quản lí Kỹ Thuật Kỹ Thuật Vi Xử Lý làm mạch điện lý thú Làm quen AVR Lap Trinh Dieu Khien Robot Lập Trình lập trình 8051 Lập Trình AVR Lập Trình C lập trình c++ Lập Trình Led Quảng Cáo Lập Trình Nhúng Lập trình pic Lập trình Robot Lập Trình Vi Điều Khiển Lập Trình Với AVR Studio LCD 16x2 Lcd16x2 Led Clock Led Quay led sao băng led trai tim Led Trái Tim Lịch sử ra đời Linh Kiện Cơ Bản linh kiện điện tử Loa LPC 2378 LSB lý thú Mã AVR - C Mạch 7seg Mạch Amply.Mạch Loa Mạch Autorobo Mạch bảo vệ Mạch Cảm Biến mạch cảm ứng sờ tay Mạch Cầu H Mạch cube Mạch Đếm Sản Phẩm Mạch điện cơ bản Mạch điện hay Mạch Điện Ứng Dụng Mạch Điều khiển động cơ Mạch Động Cơ Mạch đồng hồ Mạch đồng hồ 4 led Mạch giao thông Mạch IC số Mạch in mạch khóa số mạch khuếch đại thuật toán mạch led chúc mừng năm mới mạch led đẹp Mạch Led đơn Mạch Led Quảng Cáo mach led trai tim mạch led trái tim Mạch Led Vumeter mạch lý thú Mạch Ma trận Phím Mạch Matrix Mạch nạp Mạch nguồn Mạch Nút Bấm mạch sóng rf mạch tăng áp Mạch thu phát Mạch tổ hợp MSI Mạch trái tim Mạch Vi điều khiển Microbicho module module GSM/GPS Module Sim548 Module Sim548 giao tiếp với vi điều khiển PIC Module Sim548C Mosfet Motor Mô Phỏng Phần Cứng Mô Tả Phần Cứng MSB mua led sao băng News Ngắt Ngắt Trong LPC23xx ngân hàng Ngôn Ngữ Ngôn Ngữ C Ngôn Ngữ Tự Học Lập Trình C Ngôn Ngữ VHDL Nguyên Lý nguyên lý ic 555 Nguyên Tắc nháy led Nhập môn C Nhỏ Gọn Nibble opamp People Phần Mềm phần mềm altium Designer Phần mềm điện tử Phần Mềm Điện Tử Phần Mềm Điện Tử Hay Phần Mềm Hay Phần Mềm Led Quảng Cáo phần mềm proteus 8 Phần mềm vi tính Phần Mền Phương pháp hàn linh kiện dán PIC pic16f877a Print Design Proteus Proteus 7.8 SP2 FULL PWM quà tặng bạn gái quà tặng độc đáo quản trị doanh nghiệp quản trị kinh doanh quét led 7 đoạn Relay robocon Robot ROBOT DÒ ĐƯỜNG rút gọn mạch logic tổ hợp Sach Dien Tu Sản Phẩm Thú Vị Sản Phẩm Thương Mại Sáng tạo Short Smart Home SMD sơ đồ nguyên lý spi Sports Sử Dụng Sử Dụng Đồng Hồ sử dụng đồng hồ VOM sử dụng ngắt trong pic sự khác nhau Sức mạnh số Tải tài chính tài chính doanh nghiệp tài chính ngân hàng Tài Khoản Chia Sẻ Tài Liệu Tài Liệu 8051 tài liệu avr Tài liệu Điện Tử Tài Liệu Pic Tài liệu robocon tài liệu về ngân hàng Tài Liệu Vi Điều Khiển tailieuvn Tạo cổng Com ảo Tạo cổng nối tiếp ảo tạo dự án trong keil arm Tạo Project trong Vi Xử Lý ARM tạo thư viện altium designer tạo xung vuông Tạp chí Tạp Chí Hay tăng áp Tập lệnh AT Team Support TEAMPLATE PROTEUS Test thị trường tài chính Thiết Bị Thú Vị Thiết kế robot Thiết lập Fuse Bits Thiết Lập Pin Thuật Toán Thuật Toán Điều Khiển PID Thuật Toán Quine MCCluskey Thư viện Protues Thực Hành Thyristor Timer Timer/Counter Tin Học Chia Sẻ Tổ Chức Bộ Nhớ tổng quan về proteus 8 Transistor Tranzito Tranzitor Trao đổi học tập Travel Trình Biên Dịch Trình Dịch Trong Suốt Truyền Thông Nối Tiếp Không Đồng Bộ- UART truyền thông nối tiếp RS232 Tụ điện TUT - 8051 - ASM TUT - 8051 - KeilC tự hành Tự Học C Tự Học Lập Trình C Tý hon UART Update USB Ứng Dụng Led Quảng Cáo ứng dụng mạch khuếch đại thuật toán vẽ mạch in vẽ mạch nguyên lý VHDL Vi Điều Khiển Vi điều khiển - Ứng dụng vi điều khiển PIC Vi mạch số Vi Xử Lý Vi Xử Lý 8051 Vi Xử Lý 8086 Vi Xử Lý ARM Vi Xử Lý PIC Video Video Mach Điện Virtual Serial Port Driver VOM vxl Web Design xác định góc quay động cơ xử lý chuỗi

Chia sẻ mạch điều khiển quạt bàn dùng Remote TV Sony, mạch dùng IC 89C2051 để lập trình nhận tín hiệu từ Remote TV. Bao gồm các chức năng cơ bản:
- On/Off
- Hẹn giờ (30', 1h, 2h, 4h)
- Đổi tốc độ (Số 1, số 2, số 3)
- Gió liu riu (Nature Wind)

1. Hình ảnh mạch thật:


2. Tìm hiểu cơ chế hoạt động Remote TV

Điều khiển từ xa phát ra các bit 0 va 1. Tuy nhiên nó không thể đưa lên LED hồng ngoại và phát trực tiếp các bit này được (không phát đi xa được). Vì vậy nó cần phải có 1 sóng mang với tần số khoảng 36KHz (giống như trong Radio ấy).


Để làm được bộ phát như trên có 2 cách:
- Tạo ra 1 tần số 36 KHz ổn định làm sóng mang (Dùng NE555) 
(36KHz) AND (Bit 0,1) = Output_Signal 
- Cách 2 đơn giản hơn. Ra chợ mua 1 cái đk về dùng

Bộ thu là 1 con IC 3 chân(VCC--GND--OUTPUT). Nó có nhiệm vụ nhận tín hiệu hồng ngoại yếu ớt từ đk phát ra, khuyêch đại tín hiệu, tách sóng mang để lọc ra những bít 0 và 1.


Mỗi 1 lần phát, đk sẽ phát đi 1 chuỗi các bít 0 và 1. IC nhận cũng sẽ nhận đúng số lượng và đúng thứ tự các bit này.


Sau khi nhân được chuỗi các bit, nhiệm vụ của người lập trình là giải mã chuỗi bit này.
Mỗi loại đktx sẽ tuân theo 1 chuẩn mã khác nhau (RC5 là 1 chuẩn phổ biến). 
Trong chuỗi bit đó người ta sẽ phân ra làm 2 phần:
- phần 1 là địa chỉ để phân biệt các thiết bị khác nhau(cùng là hãng SONY nhưng đktx của TV không làm ảnh hưởng đến đầu DVD chẳng hạn)
- phần 2 là phần lệnh (lúc này sẽ chỉ rõ lệnh phát ra là gì khi ta ấn nút trên đk)


Cuối cùng dựa vào lệnh đã nhận. Ta chỉ việc sử dụng thôi. Ví dụ ấn nút số 1 trên đktx thì sẽ nhận được số 1, ta bật cái quạt. Ấn số 2 ta nhận đc số 2, ta bật cái bóng điện v.v..


Đây là chuẩn SIRC mà đktx SONY sử dụng (ở đây mình sử dụng bộ mã 12 bits)



3. Tìm hiểu sơ đồ nguyên lý:

Sau khi đã hiểu qua về mã truyền và nhận. Ta đi xây dựng phần cứng.

Phần cứng gồm các nút bấm, các đèn LED báo, cách ly quang MOC3020 để điều khiển triac MAC97. Các triac này để đóng/mở việc cấp nguồn cho cuộn dây của quạt (quạt có 3 số --> 3 cuộn dây --> 3 triac)




NGUYÊN LÝ :

- Altium Designer: http://link5s.com/kfJ
Khi nhấn Tải, bạn sẽ vào trang quảng cáo, vui lòng chờ 5 giây. Nút  hiện ra ở góc phải phía trên, nhấn vào để đến trang download

Sau khi tham khảo trên mạng. tôi đã tìm được cách tối ưu mạch điều khiển từ xa sử dụng điều khiển TV. Do sử dụng trực tiếp nguồn 5V được hạ áp từ 220VAC nên bỏ qua được biến áp và opto-triac. 
Đây là 1 mạch đk đa năng, mỗi mạch sẽ điều khiển 1 thiết bị điện trong nhà. Tùy thuộc vào công suất của thiết bị cần điều khiển mà ta sẽ chọn loại triac có công suất phù hợp. Hơn nữa mạch rất nhỏ gọn nên có thể giấu trong các thiết bị (ví dụ điều khiển đèn neon thì giấu trong máng đèn, chỉ lộ con IR receiver ra ngoài)
Đây là nguyên lý của mạch (CHÚ Ý, MẠCH NÀY DO KHÔNG CÓ BIẾN ÁP CÁCH LY NÊN ĐỤNG VÀO PHẦN MẠCH KHI CÓ ĐIỆN LÀ BỊ GIẬT)
Mạch in chỉ bé bằng 2 đầu ngón tay 




4. Lập trình:

Công việc đầu tiên của lập trình là làm sao để thu được 12 bit mà đktx đã phát đi. Chân OUTPUT của con IR receiver nối với chân ngắt ngoài INT0 của 89C2051. 
Khi có ngăt ngoài xảy ra (tức là đã có tín hiệu phát ra từ bộ đktx) chương trình sẽ dừng các việc đang làm và nhảy vào trình phục vụ ngắt. 
Chương trình ngắt sẽ làm gì?
- Việc đầu tiên khi nhảy vào ngắt là chờ cho bit START về 0
- Đọc bít ngay sau đó
- Lưu vào vị trí bit đầu tiên của 2 byte (2 byte nằm trong 1 biến: int receiver;) 
- Dịch bít này sang trái 1 lần
- Đọc bít tiếp theo......
- Nhận đủ 12 bit
- Lọc ra 7 bit đầu để lấy ra lệnh (tức là đktx vừa bấm nút nào?)
- Tra trong bảng lệnh để thực hiện 1 công việc nào đó

Đây là đoạn chương trình ngắt INT0
Khi truyền, đktx sẽ phát ra các bit có frame timing như sau
- bit START gồm 4T mức "1", mỗi T là 600uS
- bit 0 gồm 2T: 1T mức "0" và 1T mức "1"
- bit 1 gồm 3T: 1T mức "0" và 2T mức "1"

Khi nhận, các bit sẽ bị đảo dấu. có frame timing như sau
- bit START gồm 4T mức "0", mỗi T là 600uS
- bit 0 gồm 2T: 1T mức "1" và 1T mức "0"
- bit 1 gồm 3T: 1T mức "1" và 2T mức "0"

Dựa vào frame timing nhận, ta có thể tiến hành lấy mẫu chân P3_2 để xác định được đâu là bit 0 và đâu là bit 1 (từ đây ta chỉ quan tâm đến frame timing nhận thôi)

Chú ý rằng dù bit "0" hay bit "1" thì đều có 1T ở đầu là mức "1". ta tạm gọi 1T đặc biệt này là "X" 

tick2=0; while(tick2<250 100us="" 1="" g="" h="" i="" khi="" l="" m="" n="" ng="" nh="" o="" p="" ra="" t="" th="" tick1="" tick2="" timer1="" tr="" us="" v="" xem="" y="">


------------------------------------------------------------------------------------
void external_ISR (void) interrupt 0
{
tick2=0; //bắt đầu tính trễ
rev_IR = 0x01; // rev_IR = 000 0001 giá trị khởi tạo ban đầu cho rev_IR


bit_1:
if(rev_IR >= 128) {save_rev = rev_IR; goto end_rev;} // Nếu đã nhận đủ 7 bit thì thoát
while( (P3_2 == 0)&&(tick2<250 p="">
// Chờ cho hết bit START (P3_2 về "1"). Nếu vì lý do nào đó, P3_2 không về "1" thì sau (100*250)uS sẽ thoát, nếu không chương trình sẽ bị treo ở đây.


bit_0:
if(rev_IR >= 128) {save_rev = rev_IR; goto end_rev;} // Nếu đã nhận đủ 7 bit thì thoát
while( (P3_2 == 1)&&(tick2<250 p="">
// Chờ cho "X" về "0" và bắt đầu lấy mẫu ở chân P3_2 (đọc bit) 


tick1=0;
while(tick1<7 700us="" o="" p="" t="" tr="">
if(P3_2 == 0) {rev_IR <<= 1; rev_IR |= 0x01; goto bit_1;} // bit_x = 1

//Nếu chân P3_2 = 0 tức là nhận được bit "1". Nếu nhận được bit 1, ta phải chờ cho P3_2 về "1" rồi chờ tiếp cho P3_2 về "0" rồi mới đọc bit tiếp theo, chính vì thế mới "goto bit_1" (xem ảnh dưới)


if(P3_2 == 1) {rev_IR <<= 1; rev_IR |= 0x00; goto bit_0;} // bit_x = 0

//Nếu chân P3_2 = 1 tức là nhận được bit "0". Nếu nhận được bit 0, ta chỉ phải chờ cho P3_2 về "0" rồi mới đọc bit tiếp theo, chính vì thế mới "goto bit_0" (xem ảnh dưới)


 

/* 
| MSB LSB |
--------------------------------------------------
rev_IR = 0 0 0 0 0 0 0 1 
rev_IR = 0 0 0 0 0 0 1 bit1
rev_IR = 0 0 0 0 0 1 bit1 bit2
rev_IR = 0 0 0 0 1 bit1 bit2 bit3
rev_IR = 0 0 0 1 bit1 bit2 bit3 bit4
rev_IR = 0 0 1 bit1 bit2 bit3 bit4 bit5
rev_IR = 0 1 bit1 bit2 bit3 bit4 bit5 bit6
rev_IR = 1 bit1 bit2 bit3 bit4 bit5 bit6 bit7 (rev_IR >= 128 ; stop INT0 va thoat)
*/

end_rev:
EX0=0; //chi lay 7 bit command, bo qua 5 bit address
}



CODE MÃ NGUỒN:

//*****************************
// for Sony remote only

//*****************************

#include
//#include

#define pow P3_1 // in
#define speed P3_0 // in
#define timer P3_3 // in
#define nature P3_4 // in

#define power_IR 212 // IR receiver
#define speed_IR 142 // IR receiver
#define timer_IR 210 // IR receiver
#define nature_IR 244 // IR receiver

#define speed3 P1_0 //out triac
#define speed2 P1_1 //out triac
#define speed1 P1_2 //out triac

#define timer1 P1_4 //timer out led
#define timer2 P1_5 //timer out led
#define timer3 P1_6 //timer out led
#define timer4 P1_7 //timer out led

#define alarm P1_3 //loa chip out

unsigned char tocdo,hengio,kt_hengio,power; 
unsigned char tick,wind,anti_vib,enable_IR;
unsigned int tick1,tick2,current_time,wind_time,time_off;
unsigned char rev_IR,save_rev;



void chip() //tao am thanh 2KHz
unsigned int i,m;
for(m=0;m<250 m="" p="">
{
alarm=0;
for(i=0;i<20 i="" p="">
{;}
alarm=1;
for(i=0;i<20 i="" p="">
{;}
}
}



void timer1_ISR (void) interrupt 3
{
tick1++; tick2++; //100 us
}



void external_ISR (void) interrupt 0
{
tick2=0; 
rev_IR = 0x01; 
bit_1:
if(rev_IR >= 128) {save_rev = rev_IR; goto end_rev;} 
whileP3_2 == 0)&&(tick2<250 p="">
bit_0:
if(rev_IR >= 128) {save_rev = rev_IR; goto end_rev;} 
whileP3_2 == 1)&&(tick2<250 p="">
tick1=0;
while(tick1<7 p="">
if(P3_2 == 0) {rev_IR <<= 1; rev_IR |= 0x01; goto bit_1;}
if(P3_2 == 1) {rev_IR <<= 1; rev_IR |= 0x00; goto bit_0;} 
end_rev:
//tick1=0;
//while(tick1<70 p="">
//_nop_();
EX0=0; //chi lay 7 bit lenh, bo qua 5 bit dia chi
}


void timer0_ISR (void) interrupt 1
{
// with xtal 12.000MHz
// 3CAF(15535) - 50ms
// D8EF(55535) - 10ms

// with xtal 11.0592 MHz
// DC05 - 10ms
// FC17(64535) - 1ms
// FE0B(65035) - 0.5ms
// FF37(65335) - 0.2ms

TH0 = 0xDC; 
TL0 = 0x05;
tick++;
anti_vib++;
enable_IR++;
if (tick >= 100) // 1 sec
{
current_time++; 
wind_time++;
tick = 0;
}
}


void main (void)
{//-------------------------

// init system
TMOD = 0x21; // (TMOD: 0010 0001) Timer_1 8 bits auto reload. Timer_0 16 bits 
TH1 = 255-100;
TL1 = TH1;
ET0 = 1; // Enable Timer 0 Interrupt
ET1 = 1; // Enable Timer 1 Interrupt 
// EX0 = 1; // Enable External 0 Interrupt 
EA = 1; // Global Interrupt Enable
PT1 = 1; // Priority timer_1
TR0 = 1; // Start Timer 0
TR1 = 1; // Start timer 1
P1 = 0x00; // set P1 lam dau ra
P3 = 0xff; // set P3 lam dau vao

save_rev=0xff;
//enable_IR=0;

// main loop
while(1)
{//*
kt_hengio=0;
hengio=0;
wind=0;
power=0;
tocdo=1;
speed1=speed2=speed3=1; 
timer1=timer2=timer3=timer4=1;
alarm=0;
EX0 = 1; // Enable External 0 Interrupt 

//********** ENABLE IR INTERRUPT AGAIN *************
// while(enable_IR > 100)
// { EX0=1; enable_IR=0; }
//**************************************************



//**************** POWER ON ************************
if!pow) || (save_rev==power_IR)) // nut on/off duoc an lan dau
{
chip();
speed1=0; // speed1 is defauled
power++;
while(!pow) {;}
anti_vib=0;
while(anti_vib<20 p="">
{;}
save_rev=0xff;
EX0=1;
}
//*************************************************



//**************************************************
//**************************************************
while(power)
{//** 



//******************* POWER OFF ************************
if!pow) || (save_rev==power_IR)) // nut on/off duoc an lan tiep theo
{
chip();
chip();
chip();
power--;
while(!pow) {;} //anti vibration contact
anti_vib=0;
while(anti_vib<20 p="">
{;}
save_rev=0xff;
EX0=1;

}
//**************************************************



//******************** SPEED ************************
if!speed) || (save_rev==speed_IR)) // button speed
{///***
chip();
tocdo++;
if(tocdo > 3)
{ tocdo=1;}
dungimi:switch(tocdo)
{////
case 1: speed1=0; speed2=1; speed3=1; 
break; 
case 2: speed1=1; speed2=0; speed3=1; 
break;
case 3: speed1=1; speed2=1; speed3=0; 
break;
}////
while(!speed) {;}
anti_vib=0;
while(anti_vib<20 p="">
{;}
save_rev=0xff;
EX0=1;

}///***
//**************************************************



//********** ENABLE IR INTERRUPT AGAIN *************
while(enable_IR > 100)
{ EX0=1; enable_IR=0; }
//**************************************************




//****************** CHECK TIMER *******************
if(kt_hengio == 1)
{
if(current_time > time_off) 
{ chip(); chip(); chip(); power--; goto off; } 
}
//**************************************************




//******************* TIMER ************************
if!timer) || (save_rev==timer_IR)) //timer function
chip();
kt_hengio=1;
current_time=0;
hengio++;
if(hengio > 4)
{ hengio=0; }

switch(hengio)
{
case 0: kt_hengio=0; 
timer1=1; timer2=1; timer3=1; timer4=1; break;
case 1: time_off=1800; // 30 minutes
timer1=0; timer2=1; timer3=1; timer4=1; break; 
case 2: time_off=3600; // 1 hour
timer1=1; timer2=0; timer3=1; timer4=1; break;
case 3: time_off=7200; // 2 hours
timer1=1; timer2=1; timer3=0; timer4=1; break;
case 4: time_off=14400; // 4 hours
timer1=1; timer2=1; timer3=1; timer4=0; break;
}

while(!timer) {;}
anti_vib=0;
while(anti_vib<20 p="">
{;}
save_rev=0xff;
EX0=1;

//************************************************** **




//******************** NATURE ************************
if!nature) || (save_rev==nature_IR)) // nature wind function
{
chip();
wind++;
if(wind>1)
{
wind=0;
goto dungimi; // return speed after turn-off nature wind function
}
while(!nature) {;}
anti_vib=0;
while(anti_vib<20 p="">
{;}
save_rev=0xff;
EX0=1;

}
//**************************************************




//**************************************************
if(wind) // if nature wind function is turned-on
{
switch(tocdo)
{
case 1: if(wind_time>5)
{speed1 =~ speed1; wind_time=0;} 
break; 
case 2: if(wind_time>10)
{ speed2 =1; 
anti_vib=0;
while(anti_vib<5 p="">
{;}
speed1=0;
wind_time=0;} 
if(wind_time>7)
{ anti_vib=0;
while(anti_vib<5 p="">
{;}
speed2=0;} 
if(wind_time>3)
{ anti_vib=0;
while(anti_vib<5 p="">
{;}
speed1=1;} 
break;

case 3: if( wind_time>10)
{ speed3 =1; 
speed1 =1;
anti_vib=0;
while(anti_vib<5 p="">
{;}
speed2 =0; //chuyen sang so 2
wind_time=0;

if(wind_time>7)
{ speed3 =1;
speed2 =1;
anti_vib=0;
while(anti_vib<5 p="">
{;}
speed1=0; //chuyen sang so 1
goto exit;
if(wind_time>3)
{ speed1 =1;
speed2 =1;
anti_vib=0;
while(anti_vib<5 p="">
{;}
speed3 =0; //chuyen sang so 3
exit: break;

}
//**************************************************


}//**

//**************************************************
//**************************************************


off: 
alarm=0;

}//* end while()

}//------------------end

DOWNLOAD FULL MÃ NGUỒN:
Khi nhấn nút "Tải Về Máy", bạn sẽ vào trang quảng cáo, vui lòng chờ 5 giây. Nút  hiện ra ở góc phải phía trên, nhấn vào để đến trang download

Nguồn bmtbd.uct.edu.vn
http://dientuchiase.blogspot.com/

Mạch điều khiển quạt từ xa - Hẹn giờ, tai lieu chia se

Nhãn:

Đăng nhận xét

Author Name

{picture https://blogger.googleusercontent.com/img/b/R29vZ2xl/AVvXsEjN0PUWA2genMqX3Sm26mBTX_30OJgDenoIi4K6BR-E1vl3nI7LALp0X759QZgzqrMcGBB7jEbdZnubJbp4n2ZZ22KT196CWCg9DLs3MfEivocdmkjZEPEn-A42hyphenhyphen9dmsca0VIDQr_LjqM/s512-Ic42/pham-van-ngoc-anh.jpg}

Tôi là Ngọc Anh. Tôi đến từ Nghệ An. Tôi tốt nghiệp một trường đại học tại Sài Gòn. Hiện tôi đang phát triển công ty riêng. Liên lạc với tôi qua:

{facebook https://www.facebook.com/phamvanngocanh}
{twitter https://twitter.com/nghiphong1993}
{google https://plus.google.com/+dientuchiase/posts}
{youtube https://www.youtube.com/channel/UCeJKhA_goBNFmDw6RKNtmYQ}

Biểu mẫu liên hệ

Tên

Email *

Thông báo *

Được tạo bởi Blogger.