Игра на миллион
Ничего не буду от себя добавлять, читаем, смотрим, вносим посильный вклад.
А вдруг новые панфиловцы получатся. Или русский Wargaming :)

Оторвитесь ненадолго от беспощадного ЛУТа!
Две недели решат судьбу проекта.
PS:
Таки добавлю дескрипшн.
А то, похоже, многие осуждают, не читая.
А вдруг новые панфиловцы получатся. Или русский Wargaming :)

Оторвитесь ненадолго от беспощадного ЛУТа!
Две недели решат судьбу проекта.
PS:
Таки добавлю дескрипшн.
А то, похоже, многие осуждают, не читая.
Каждый из нас задумывался, как сложилась бы судьба нашей страны, если бы Александр Невский не победил на Чудском озере, или если бы большевики не пришли к власти. Как бы мы жили, если бы Горбачев не развалил СССР, или если майдан в Киеве был бы предотвращен. Теперь у вас есть реальный шанс узнать это! В нашей новой игре каждый от мала до велика сможет примерить на себя роль Верховного Правителя, лично управлять Россией, и повлиять на её историю и исход всех значительных исторических событий на протяжении столетий. Я предлагаю вам вместе сделать эту хорошую и полезную игру.
Наша игра построена на принятии решений. В самом начале игроку нужно выбрать кампанию: период в истории России и соответствующего ему правителя. Вместе с властью на игрока сваливаются и проблемы – будь то война или революция, тяжелое внешнеполитическое положение или внутренние проблемы в стране. Для решения проблем у игрока в распоряжении будут иметься различные ресурсы – военный, экономический, социальный и так далее. Помогать в решении сложных вопросов игроку будут советники – генералы, министры и прочие значимые исторические фигуры.
В ходе игры, будут происходить исторические события, на которые игрок должен отреагировать — принять то или иное решение. В зависимости от наличия ресурсов, лояльности советников и многих других факторов (в том числе и от предыдущих решений!) у игрока будет набор вариантов того, что он может сделать.
Простых решений в «Империи» не будет
W5100 Вопрос
Здравствуйте, почти уже сделал проект при помощи wiznet w5100, но тут мне понадобилось разрешить доступ к сайту с определённого IP. И вот тут возник вопрос где его взять ?? При использовании UDP протокола там в заголовке передаётся информация IP, порт и ещё чего-то. А в TCP сразу считывается HTTP заголовок в котором только ip хоста указанно.
В скором времени планируется переход на w5500 может там чего есть?
В скором времени планируется переход на w5500 может там чего есть?
STM32F407, Timer+USART
Добрый вечер. Пишу программу которая каждую секунду будет отсылать по USART переменную увеличивающуюся на единицу. Не отправляет. Не пойму в чем проблема. Помогите разобраться!
#include "stm32f4xx.h"
#include "stm32f4xx_rcc.h"
#include "stm32f4xx_gpio.h"
#include "stm32f4xx_tim.h"
#include "stm32f4xx_exti.h"
#include "stm32f4xx_syscfg.h"
#include "stm32f4xx_usart.h"
#include "misc.h"
#include <stdlib.h>
void usart_init(void)
{
GPIO_InitTypeDef GPIO_InitStructure;
USART_InitTypeDef USART_InitStructure;
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOC, ENABLE);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE);
GPIO_PinAFConfig(GPIOC, GPIO_PinSource10, GPIO_AF_USART3);
GPIO_PinAFConfig(GPIOC, GPIO_PinSource11, GPIO_AF_USART3);
GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOC, &GPIO_InitStructure);
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;
GPIO_Init(GPIOC, &GPIO_InitStructure);
USART_InitStructure.USART_BaudRate = 19200;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_Parity = USART_Parity_No;
USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
USART_Init(USART3, &USART_InitStructure);
USART_ITConfig(USART3,USART_IT_RXNE,ENABLE);
USART_Cmd(USART3, ENABLE);
}
void usart_send(char byte)
{
USART_SendData(USART3,byte);
while (USART_GetFlagStatus(USART3, USART_FLAG_TC) == RESET){}
}
void usart_send_text(char *buffer)
{
while (*buffer)
{
usart_send(*buffer);
buffer++;
}
}
void init_timer(){
TIM_TimeBaseInitTypeDef base_timer;
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM6, ENABLE);
TIM_TimeBaseStructInit(&base_timer);
base_timer.TIM_Prescaler = 24000000 - 1;
base_timer.TIM_Period = 1000;
TIM_TimeBaseInit(TIM6, &base_timer);
TIM_ITConfig(TIM6, TIM_IT_Update, ENABLE);
TIM_Cmd(TIM6, ENABLE);
NVIC_EnableIRQ(TIM6_DAC_IRQn);
}
u16 i = 0;
char p[100];
void TIM6_DAC_IRQHandler()
{
if (TIM_GetITStatus(TIM6, TIM_IT_Update) != RESET)
{
TIM_ClearITPendingBit(TIM6, TIM_IT_Update);
i++;
sprintf (p,"%d",i);
usart_send_text(p);
}
}
int main(){
init_timer();
usart_init();
do {
} while(1);
}
STM32F407VG, ADC+DMA+USART
Написал программу ADC+DMA+USART.Микроконтроллер STM32F407VG. Почему-то не работает. Не могу понять почему… Суть программы: При подаче напряжения на выход АЦП, DMA2 передает данные в память после чего DMA1 передает данные в USART3 который шлет все в PC
/*******************************************************************/
#include "stm32f4xx.h"
#include "stm32f4xx_rcc.h"
#include "stm32f4xx_gpio.h"
#include "stm32f4xx_adc.h"
#include "stm32f4xx_exti.h"
#include "stm32f4xx_syscfg.h"
#include "stm32f4xx_usart.h"
#include "stm32f4xx_dma.h"
#include "misc.h"
/*******************************************************************/
uint16_t adc_buffer[64];
void ADC_INIT(void)
{
//ADC Initialization
ADC_InitTypeDef ADC_InitStructure;
ADC_InitStructure.ADC_ScanConvMode = DISABLE;
ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;
ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_Ext_IT11;
ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
ADC_InitStructure.ADC_NbrOfConversion = 1;
ADC_Init(ADC1, &ADC_InitStructure);
ADC_RegularChannelConfig(ADC1, ADC_Channel_6, 1, ADC_SampleTime_3Cycles);
ADC_DMARequestAfterLastTransferCmd(ADC1, ENABLE);
//ADC On to work with DMA
ADC_DMACmd(ADC1, ENABLE);
ADC_Cmd(ADC1, ENABLE);
}
void USART_INIT(void)
{
GPIO_InitTypeDef GPIO_InitStruct;
USART_InitTypeDef USART_InitStructure;
// USART TX
GPIO_PinAFConfig(GPIOB, GPIO_PinSource10, GPIO_AF_USART3);
GPIO_InitStruct.GPIO_Pin = GPIO_Pin_10;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN;
GPIO_InitStruct.GPIO_OType = GPIO_OType_PP;
GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOB, &GPIO_InitStruct);
//USART Initialization
USART_InitStructure.USART_BaudRate = 115200;
USART_InitStructure.USART_WordLength = USART_WordLength_8b;
USART_InitStructure.USART_StopBits = USART_StopBits_1;
USART_InitStructure.USART_Parity = USART_Parity_No ;
USART_InitStructure.USART_HardwareFlowControl =USART_HardwareFlowControl_None;
USART_InitStructure.USART_Mode = USART_Mode_Tx;
USART_Init(USART3, &USART_InitStructure);
USART_Cmd(USART3, ENABLE);
USART_DMACmd(USART3, USART_DMAReq_Tx, ENABLE);
}
void DMA1_USART(void)
{
DMA_InitTypeDef DMA_InitStructure;
DMA_InitStructure.DMA_Channel = DMA_Channel_4;
DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t)&(USART3->DR);
DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)&adc_buffer[0];
DMA_InitStructure.DMA_DIR = DMA_DIR_MemoryToPeripheral;
DMA_InitStructure.DMA_BufferSize = 64;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_Byte;
DMA_InitStructure.DMA_MemoryDataSize = DMA_PeripheralDataSize_Byte;
DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;
DMA_InitStructure.DMA_Priority = DMA_Priority_Low;
DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;
DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_HalfFull;
DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;
DMA_Init(DMA1_Stream1, &DMA_InitStructure);
DMA_Cmd(DMA1_Stream1, ENABLE);
}
void DMA2_INIT(void)
{
DMA_InitTypeDef DMA_InitStructure;
DMA_InitStructure.DMA_Channel = DMA_Channel_0;
DMA_InitStructure.DMA_PeripheralBaseAddr = (uint32_t) &ADC1->DR;
DMA_InitStructure.DMA_Memory0BaseAddr = (uint32_t)&adc_buffer[0];
DMA_InitStructure.DMA_DIR = DMA_DIR_PeripheralToMemory;
DMA_InitStructure.DMA_BufferSize = 64;
DMA_InitStructure.DMA_PeripheralInc = DMA_PeripheralInc_Disable;
DMA_InitStructure.DMA_MemoryInc = DMA_MemoryInc_Enable;
DMA_InitStructure.DMA_PeripheralDataSize = DMA_PeripheralDataSize_HalfWord;
DMA_InitStructure.DMA_MemoryDataSize = DMA_MemoryDataSize_HalfWord;
DMA_InitStructure.DMA_Mode = DMA_Mode_Circular;
DMA_InitStructure.DMA_Priority = DMA_Priority_High;
DMA_InitStructure.DMA_FIFOMode = DMA_FIFOMode_Disable;
DMA_InitStructure.DMA_FIFOThreshold = DMA_FIFOThreshold_HalfFull;
DMA_InitStructure.DMA_MemoryBurst = DMA_MemoryBurst_Single;
DMA_InitStructure.DMA_PeripheralBurst = DMA_PeripheralBurst_Single;
DMA_Init(DMA2_Stream0, &DMA_InitStructure);
DMA_Cmd(DMA2_Stream0, ENABLE);
DMA_ITConfig(DMA2_Stream0, DMA_IT_TC, ENABLE);
}
void DMA2_Stream0_IRQHandler(void)
{
DMA_ClearITPendingBit(DMA2_Stream0, DMA_IT_TCIF0);
}
int main()
{
NVIC_InitTypeDef NVIC_InitStructure;
GPIO_InitTypeDef GPIO_InitStruct;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_DMA2, ENABLE);
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOE, ENABLE);
RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOB, ENABLE);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3,ENABLE);
//GPIO Initialization For ADC1
GPIO_InitStruct.GPIO_Pin = GPIO_Pin_11;
GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN;
GPIO_InitStruct.GPIO_PuPd = GPIO_PuPd_NOPULL;
GPIO_Init(GPIOE, &GPIO_InitStruct);
//Interrapt from DMA
NVIC_InitStructure.NVIC_IRQChannel = DMA2_Stream0_IRQn;
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
NVIC_Init(&NVIC_InitStructure);
while(1)
{
__NOP();
}
}
AVR готовые решения ,заготовки для проектов
Универсальный измерительный прибор (база: atmega8\atmega8l )
У меня был на панельке микроконтроллер.
www.ebay.com/sch/i.html?_from=R40&_sacat=0&_nkw=TRANSISTOR+TESTER+NPN+PNP+MOSFET&LH_BIN=1
Вариант с ESR (ATmega168)
www.ebay.com/sch/i.html?_from=R40&_sacat=0&_nkw=TESTER+CAPACITOR+ESR&LH_BIN=1
Автоперевод со странички автора:
translate.google.com/translate?hl=en&sl=de&tl=ru&u=http%3A%2F%2Fwww.mikrocontroller.net%2Farticles%2FAVR-Transistortester&sandbox=1
Особенности
Автоматическое обнаружение NPN и PNP транзисторы, N-и P-канальных МОП-транзисторов, диодов (в том числе двойные диоды), тиристоры, симисторы и резисторов и конденсаторов.
Автоматический расчет и отображение контактов компонента для тестирования
Обнаружение и отображение защитные диоды для транзисторов и МОП-транзисторов
Определении прибыли и база-эмиттер прямого напряжения на транзисторах
Измерение порогового напряжения затвора и емкость затвора МОП-транзистора
Отображения значений на текстовом ЖК-дисплей (2 * 16 символов)
Продолжительность тестирования компонентов: менее 2 секунд (за исключением больших конденсаторов)
Управление одной кнопкой, автоматическое отключение
Потребляемая мощность в выключенном состоянии: <20 нА
Есть прошивки с измерением ESR конденсаторов. (требуется atmega168)
translate.google.com/translate?hl=en&sl=de&tl=ru&u=http%3A%2F%2Fwww.mikrocontroller.net%2Farticles%2FAVR_Transistortester&sandbox=1
Введение
Оригинальный дизайн: www.mikrocontroller.net/articles/AVR-Transistortester
Дальнейшее развитие в работах Карла-Хайнца Kübbeler
Я продолжил проект транзистора тестером Маркус Frejek и специально разработанное программное обеспечение. Благодаря улучшенным свойствам имя уже было предложено компонентов тестера. Но я сам все еще видеть отличительной чертой в автоматическом определении типа транзистора и имущества, а разработанная Маркусом Frejek.
Здесь я хочу перечислить наиболее важные свойства
Работает с ATmega8, ATmega168 и ATmega328 процессоров.
Отображение результатов измерений на ЖК-2x16 характер.
Управление одной кнопкой с автоматическим отключением.
Устройство имеет три универсальных Meßports (тест PIN).
Автоматическое обнаружение NPN, PNP, N-и P-канальный МОП-транзистор, JFET, Импульсные диоды малой мощности и тиристорные и тиристорные.
Автоматическое распознавание выводов компонентов, компоненты могут быть подключены в любом случае.
Измерение коэффициента усиления по току и напряжение база-эмиттер для биполярных транзисторов, включая Дарлингтон.
Автоматическое обнаружение защитный диод для биполярных транзисторов и МОП-транзисторы.
До двух резисторов измеряется в измерения с разрешением до 0,1 Ом, диапазон простирается на более чем 50 МОм. Значения сопротивления менее 10 Ом отображаются для ATmega168/328 С помощью ЭПР-метода измерения с разрешением 0,01 Ом.
Подключенным конденсатором может быть измерено в диапазоне 35pF к 100mF с разрешением до 1 пФ.
Резисторов и конденсаторов показаны с их символами окружении соответствующие им номера контактов разъема.
Резистор и конденсатор значения могут отображаться до четырех знаков после запятой в правильном измерении.
До двух диодов также показаны flußrichtungsrichtig с его символическое представление, окруженный номера разъема и дополнительную информацию прямого напряжения.
Кроме того, отдельные значения емкости диода и версия 1.08k тока в обратном направлении измеряется.
ATmega168/328 для калибровки нулевой емкости, нулевого сопротивления и других параметров в самотестирования филиал возможно.
Для ATmega168/328 также индуктивности о 0.01mH могут быть обнаружены и измерены до 20H.
Для ATmega168/328 измерения ESR (эквивалентное последовательное сопротивление) интегрирован более 0:18 мкФ с разрешением 0,01 Ом.
ATmega168/328 VLOSS для потери напряжения рассматривается коллегией из зарядного импульса около 5 конденсаторов нФ. Таким образом, качество конденсаторов может быть оценена.
Более подробную информацию с примерами измерений можно прочитать в PDF документацией на немецком и английском языках.
Отступление…
Тут есть некоторое количество тупиц и оленей, поэтому сразу скажу:
1) Статья-заметка информативная, если надо и хотите узнать больше, кликайте по ссылкам, там есть все ответы.Моя задача — первичная информация.
2) Приведены описания взятые из автопереводчика гугла, да есть такая штука.
3) Если что-то не ясно читайте пункт 1)
У меня был на панельке микроконтроллер.
www.ebay.com/sch/i.html?_from=R40&_sacat=0&_nkw=TRANSISTOR+TESTER+NPN+PNP+MOSFET&LH_BIN=1
Вариант с ESR (ATmega168)
www.ebay.com/sch/i.html?_from=R40&_sacat=0&_nkw=TESTER+CAPACITOR+ESR&LH_BIN=1
Автоперевод со странички автора:
translate.google.com/translate?hl=en&sl=de&tl=ru&u=http%3A%2F%2Fwww.mikrocontroller.net%2Farticles%2FAVR-Transistortester&sandbox=1
Особенности
Автоматическое обнаружение NPN и PNP транзисторы, N-и P-канальных МОП-транзисторов, диодов (в том числе двойные диоды), тиристоры, симисторы и резисторов и конденсаторов.
Автоматический расчет и отображение контактов компонента для тестирования
Обнаружение и отображение защитные диоды для транзисторов и МОП-транзисторов
Определении прибыли и база-эмиттер прямого напряжения на транзисторах
Измерение порогового напряжения затвора и емкость затвора МОП-транзистора
Отображения значений на текстовом ЖК-дисплей (2 * 16 символов)
Продолжительность тестирования компонентов: менее 2 секунд (за исключением больших конденсаторов)
Управление одной кнопкой, автоматическое отключение
Потребляемая мощность в выключенном состоянии: <20 нА
Есть прошивки с измерением ESR конденсаторов. (требуется atmega168)
translate.google.com/translate?hl=en&sl=de&tl=ru&u=http%3A%2F%2Fwww.mikrocontroller.net%2Farticles%2FAVR_Transistortester&sandbox=1
Введение
Оригинальный дизайн: www.mikrocontroller.net/articles/AVR-Transistortester
Дальнейшее развитие в работах Карла-Хайнца Kübbeler
Я продолжил проект транзистора тестером Маркус Frejek и специально разработанное программное обеспечение. Благодаря улучшенным свойствам имя уже было предложено компонентов тестера. Но я сам все еще видеть отличительной чертой в автоматическом определении типа транзистора и имущества, а разработанная Маркусом Frejek.
Здесь я хочу перечислить наиболее важные свойства
Работает с ATmega8, ATmega168 и ATmega328 процессоров.
Отображение результатов измерений на ЖК-2x16 характер.
Управление одной кнопкой с автоматическим отключением.
Устройство имеет три универсальных Meßports (тест PIN).
Автоматическое обнаружение NPN, PNP, N-и P-канальный МОП-транзистор, JFET, Импульсные диоды малой мощности и тиристорные и тиристорные.
Автоматическое распознавание выводов компонентов, компоненты могут быть подключены в любом случае.
Измерение коэффициента усиления по току и напряжение база-эмиттер для биполярных транзисторов, включая Дарлингтон.
Автоматическое обнаружение защитный диод для биполярных транзисторов и МОП-транзисторы.
До двух резисторов измеряется в измерения с разрешением до 0,1 Ом, диапазон простирается на более чем 50 МОм. Значения сопротивления менее 10 Ом отображаются для ATmega168/328 С помощью ЭПР-метода измерения с разрешением 0,01 Ом.
Подключенным конденсатором может быть измерено в диапазоне 35pF к 100mF с разрешением до 1 пФ.
Резисторов и конденсаторов показаны с их символами окружении соответствующие им номера контактов разъема.
Резистор и конденсатор значения могут отображаться до четырех знаков после запятой в правильном измерении.
До двух диодов также показаны flußrichtungsrichtig с его символическое представление, окруженный номера разъема и дополнительную информацию прямого напряжения.
Кроме того, отдельные значения емкости диода и версия 1.08k тока в обратном направлении измеряется.
ATmega168/328 для калибровки нулевой емкости, нулевого сопротивления и других параметров в самотестирования филиал возможно.
Для ATmega168/328 также индуктивности о 0.01mH могут быть обнаружены и измерены до 20H.
Для ATmega168/328 измерения ESR (эквивалентное последовательное сопротивление) интегрирован более 0:18 мкФ с разрешением 0,01 Ом.
ATmega168/328 VLOSS для потери напряжения рассматривается коллегией из зарядного импульса около 5 конденсаторов нФ. Таким образом, качество конденсаторов может быть оценена.
Более подробную информацию с примерами измерений можно прочитать в PDF документацией на немецком и английском языках.
Отступление…
Тут есть некоторое количество тупиц и оленей, поэтому сразу скажу:
1) Статья-заметка информативная, если надо и хотите узнать больше, кликайте по ссылкам, там есть все ответы.Моя задача — первичная информация.
2) Приведены описания взятые из автопереводчика гугла, да есть такая штука.
3) Если что-то не ясно читайте пункт 1)
XControl. Управление через компьютер, телефон, планшет
Думаю, тем, кто интересуется бюджетным вариантом умного дома или просто автоматизацией, это будет интересно))))))
PS: Не сочтите за спам)))
XControl представляет из себя программно-аппаратный комплекс, с помощью которого можно управлять электроцепями, а так же, контролировать разнообразные датчики через компьютер, телефон или планшет. Система состоит из основного аппаратного блока и трех программ – XControl, которая предоставляет возможность просматривать одновременно за несколькими аппаратными блоками, программы XControl-Configer, с помощью которой устанавливаются основные настройки блока, а так же, программы XControl для платформы Android.

Читать дальше
PS: Не сочтите за спам)))
XControl представляет из себя программно-аппаратный комплекс, с помощью которого можно управлять электроцепями, а так же, контролировать разнообразные датчики через компьютер, телефон или планшет. Система состоит из основного аппаратного блока и трех программ – XControl, которая предоставляет возможность просматривать одновременно за несколькими аппаратными блоками, программы XControl-Configer, с помощью которой устанавливаются основные настройки блока, а так же, программы XControl для платформы Android.

Читать дальше
Мощный фонарик за 15 минут
Недавно получил светодиоды с dealextreme на 90lm, 180lm.
Как раз некстати сдох старый фонарик, пришлось слепить на скорую руку.
Все что нужно — отсек на 4 АА батарейки, кнопка, кусок текстолита, SMD резисторы на 1..10 ОМ, паяльник, и термоклей.
Читать дальше
Как раз некстати сдох старый фонарик, пришлось слепить на скорую руку.
Все что нужно — отсек на 4 АА батарейки, кнопка, кусок текстолита, SMD резисторы на 1..10 ОМ, паяльник, и термоклей.
Читать дальше