Перейти к содержанию

Вывод Показаний На Lcd От Nokia 1100


Рекомендуемые сообщения

Здравствуйте, Всем. Подскажите, как вывести показания с переменной Temp на Lcd от Nokia 1100.

Текст с использованием функции nlcd_PrintF(PSTR(" ")) отображает.

Ссылку на описание функций реализованных в библиотеке к Lcd прилагаю...http://digitalchip.r...ia-1100-chast-2

И сам код....

#define F_CPU 8000000UL
#include <avr/io.h>
#include <iom8.h>
#include <util/delay.h>
#include "lcd_lib.h"
#include "nokia1100_lcd_lib.h"

//определяем порт и бит к которому подключено устройство 1-wire
#define W1_PORT PORTB
#define W1_DDR DDRB
#define W1_PIN PINB
#define W1_BIT 0
//функция определяет есть ли устройство на шине
unsigned char w1_find()
{
unsigned char device;
W1_DDR |= 1<<W1_BIT;
_delay_us(485);
W1_DDR &= ~(1<<W1_BIT);
_delay_us(65);

if((W1_PIN & (1<<W1_BIT)) ==0x00)
device = 1;
else
device = 0;
_delay_us(420);
return device;
}
//функция посылает команду на устройство 1-wire
void w1_sendcmd(unsigned char cmd)
{
for(unsigned char i = 0; i < 8; i++)
{
if((cmd & (1<<i)) == 1<<i)
{
W1_DDR |= 1<<W1_BIT;
_delay_us(2);
W1_DDR &= ~(1<<W1_BIT);
_delay_us(65);
}
else
{

W1_DDR |= 1<<W1_BIT;
_delay_us(65);
W1_DDR &= ~(1<<W1_BIT);
_delay_us(5);
}
}
}
//функция читает один байт с устройства 1-wire
unsigned char w1_receive_byte()
{
unsigned char data;
for(unsigned char i = 0; i < 8; i++)
{
W1_DDR |= 1<<W1_BIT;
_delay_us(2);
W1_DDR &= ~(1<<W1_BIT) ;
_delay_us(7);
if((W1_PIN & (1<<W1_BIT)) == 0x00)
data &= ~(1<<i);
else
data |= 1<<i;
_delay_us(50);
}
return data;
}
//функция преобразует полученные с датчика 18b20 данные в температуру
int temp_18b20()
{
unsigned char data[2];
int temp = 0;
if(w1_find()==1)//если есть устройство на шине
{
w1_sendcmd(0xcc);//пропустить ROM код, мы знаем, что у нас одно устройство или передаем всем
w1_sendcmd(0x44);//преобразовать температуру
_delay_ms(750);//преобразование в 12 битном режиме занимает 750ms
w1_find();//снова посылаем Presence и Reset
w1_sendcmd(0xcc);
w1_sendcmd(0xbe);//передать байты ведущему(у 18b20 в первых двух содержится температура)
data[0] = w1_receive_byte();//читаем два байта с температурой
data[1] = w1_receive_byte();
//загоняем в двух байтную переменную
temp = data[1];
temp = temp<<8;
temp |= data[0];
//переводим в градусы
temp *= 0.0625;//0.0625 градуса на единицу данных
}
//возвращаем температуру
return temp;
}
int main()
{

int temp;
nlcd_Init();
_delay_ms(100);
nlcd_GotoXY(0,0);
	 nlcd_PrintF(temp);

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

Преобразовать число в строку. Либо sprintf (медленный и тяжелый), либо itoa, либо самописные. На счет самописных можете заглянуть в соседнюю тему (там, для другого дисплея, но именно перевод числа в строку от этого не зависит). Еще на изиэлектронике было целое исследование по различным способам, но ссылку сейчас не найду.

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

С преобразованием числа в строку разобрался, всё работает ОГРОМНОЕ СПАСИБО. Но теперь появилась другая проблема, при подключении заголовочного файла OneWire.h не хватает памяти Data 1129 bytes (110.3% Full) Как быть?

Прилагаю весь проект...

thermometr.rar

Ссылка на комментарий
Поделиться на другие сайты

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

тупой вариант - взять контроллер побольше

нормальный вариант - заняться оптимизацией. Например, вырезать из библиотеки неиспользуемые символы, убрать вывод символов одинарной или двойной ширины, если используется только один тип. Вариантов много.

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

Сделал вот-так, теперь выводит t=0.0 и ничего не изменяется

...

#define F_CPU 8000000UL
#include <avr/io.h>
#include <iom8.h>
#include <util/delay.h>
#include "nokia1100_lcd_lib.h"

//определяем порт и бит к которому подключено устройство 1-wire
#define W1_PORT PORTB
#define W1_DDR DDRB
#define W1_PIN PINB
#define W1_BIT 0
//функция определяет есть ли устройство на шине
unsigned char w1_find()
{
unsigned char device;
W1_DDR |= 1<<W1_BIT;
_delay_us(485);
W1_DDR &= ~(1<<W1_BIT);
_delay_us(65);

if((W1_PIN & (1<<W1_BIT)) ==0x00)
 device = 1;
else
 device = 0;
_delay_us(420);
return device;
}
//функция посылает команду на устройство 1-wire
void w1_sendcmd(unsigned char cmd)
{
for(unsigned char i = 0; i < 8; i++)
{
 if((cmd & (1<<i)) == 1<<i)
 {
  W1_DDR |= 1<<W1_BIT;
  _delay_us(2);
  W1_DDR &= ~(1<<W1_BIT);  
  _delay_us(65);
 }
 else
 {

  W1_DDR |= 1<<W1_BIT;
  _delay_us(65);
  W1_DDR &= ~(1<<W1_BIT);
  _delay_us(5);  
 }
}
}
//функция читает один байт с устройства 1-wire
unsigned char w1_receive_byte()
{
unsigned char data;
for(unsigned char i = 0; i < 8; i++)
{
 W1_DDR |= 1<<W1_BIT;
 _delay_us(2);
 W1_DDR &= ~(1<<W1_BIT) ;
 _delay_us(7);
 if((W1_PIN & (1<<W1_BIT)) == 0x00)
  data &= ~(1<<i);
 else
  data |= 1<<i;
 _delay_us(50);
}
return data;
}
//функция преобразует полученные с датчика 18b20 данные в температуру
int temp_18b20()
{
unsigned char data[2];
int temp = 0;
if(w1_find()==1)//если есть устройство на шине
{
 w1_sendcmd(0xcc);//пропустить ROM код, мы знаем, что у нас одно устройство или передаем всем
 w1_sendcmd(0x44);//преобразовать температуру
 _delay_ms(750);//преобразование в 12 битном режиме занимает 750ms
 w1_find();//снова посылаем Presence и Reset
 w1_sendcmd(0xcc);
 w1_sendcmd(0xbe);//передать байты ведущему(у 18b20 в первых двух содержится температура)
 data[0] = w1_receive_byte();//читаем два байта с температурой
 data[1] = w1_receive_byte();
  //загоняем в двух байтную переменную
 temp = data[1];
 temp = temp<<8;
 temp |= data[0];
 //переводим в градусы
 temp *= 0.0625;//0.0625 градуса на единицу данных
}
//возвращаем температуру
return temp;
}
int main()
{
char buffer[16] = "";
int temp;
nlcd_Init();
while(1)
{

  temp = temp_18b20();  
  if(temp > 1000)//если температура <0
  {
   temp = 4096 - temp;
   temp = -temp;
  }
  sprintf(buffer, "t=%i.%i",temp, temp%1);
  nlcd_Clear();
  nlcd_GotoXY(4,7);
  nlcd_Print(buffer);
  _delay_ms(30);
}
}

Ссылка на комментарий
Поделиться на другие сайты

int temp = 0;
...
temp *= 0.0625;//0.0625 градуса на единицу данных

Ну-ну.
sprintf(buffer, "t=%i.%i",temp, temp%1);
Что автор пытался сказать тут мне совсем непонятно. Остаток от деления на 1, простите?!

Исходные данные с датчика принимаются правильно? То есть в чем проблема, кроме вывода: в работе с датчиком или в последующей программной обработке?

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

Спасибо Огромное, с этим разобрался....

Ещё один вопросик.... Есть такой код вольтметра на базе Atmega8 и lcd 3110, вольты отображаются правильно, но проблема в том, что показания постоянно мерцают. Как быть?

#include <mega8.h>
#include <delay.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <n3310lcd.c>
//наши переменные
unsigned char volt;

//Функция инициализации
void ADC_init()
{
	 ADMUX = 0xf0; //если более понятно пишем 0b11110000
	 ADCSRA = 0x8d; //0b10001101
}
//Функция измерения
unsigned char ADC_result(unsigned char adc_input)
{
	 ADMUX=adc_input | (ADMUX & 0xF0); //выставляем канал
	 delay_us(30); //задержка для стабилизации
	 ADCSRA |= 0x40;
	 while((ADCSRA & 0x10)==0); //Ждём флаг окончания измерения
	 ADCSRA|=0x10;
	 return ADCH;//Возвращаем старший байт
}
//Наша главная функция
void main(void)
{
		    LcdInit();
 ADC_init();


   while (1)
   {

   volt=ADC_result(0)*0.01*4.73*10; //умножение на 10 для точности до десятых
   LcdClear();
   LcdString(1,1);
   sprintf(lcd_buf, "U=%i.%uВольт", volt/10,volt%10);
   LcdString(1,2);
   sprintf(lcd_buf, "Напряжение");
   LcdUpdate();

  };
}

Ссылка на комментарий
Поделиться на другие сайты

А на код то посмотреть внимательнее ?

Очистка экрана, вывод, очистка, вывод, .... Что, кроме мерцания, ещё может быть на экране ?

Мало того, это всё делается с бешеной скоростью. А для чего так часто мерить и выводить ?

Ссылка на комментарий
Поделиться на другие сайты

А на код то посмотреть внимательнее ?

Очистка экрана, вывод, очистка, вывод, .... Что, кроме мерцания, ещё может быть на экране ?

Мало того, это всё делается с бешеной скоростью. А для чего так часто мерить и выводить ?

Спасибо за помощь!!! Убрал LcdClear(); Теперь всё работает нормально.....

Ссылка на комментарий
Поделиться на другие сайты

Ребята, столкнулся ещё с такой проблемкой: Делаю вольтметр и термометр на Atmega8 и Lcd nokia 3310, мне нужно, что-бы при напряжении больше 15 вольт выводилось сообщение "Перезаряд". Попробовал реализовать это с помощью оператора if. Опробовал в Proteus , и получается, что при достижении 15 Вольт сообщение выводится , но потом когда понижаешь напряжение, сообщение так и остается. Не пойму как так, хотя условие оператора if не выполняется сообщение всё равно выводится.

void main(void)

{
unsigned char devices,;
int i;
 LcdInit();
 LcdImage(fon);
 LcdUpdate();
 delay_ms(600);
 LcdClear();

 LcdInit();		  
 ADC_init();
 devices=w1_search(0xf0,rom_codes);			 
   while (1)
    {

    temp[0]=ds18b20_temperature(&rom_codes[0][0]);

    if (temp>1000){			  
	    temp[0]=4096-temp[0];		   
		 temp[0]=-temp[0];  }





   for (i = 231; i<239; i++) LcdCache[i] = tem2[i-231]; 
   for (i = 147; i<155; i++) LcdCache[i] = tem1[i-147];	
   for (i = 63; i<79; i++) LcdCache[i] = Radar[i-63];

   volt=ADC_result(0)*0.01*12.5*10; //умножение на 10 для точности до десятых
   sprintf(lcd_buf, "U=%i.%uV", volt/10,volt%10);
 LcdString(1,1);
 if (volt/10>15) { sprintf(lcd_buf, "Перезаряд");
 LcdString(1,4);
 }
   sprintf(lcd_buf,"t=%i.",temp[0],temp[0]%1);
 LcdString(1,3);
 if (temp[0]<0) {for (i = 315; i<323; i++) LcdCache[i] = snow[i-315];
}
	  else { for (i = 315; i<323; i++) LcdCache[i] = sun[i-315];
	   }

  LcdUpdate();

  };
}

Ссылка на комментарий
Поделиться на другие сайты

Строку из 9-10 пробелов, например.

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

добрый вечер.

попался тут под руку телефон 3310, состояние неизвестно,не проверял.

проверить решил сам дисплей.подключил дисплей от него к меге8,но что то пол экрана не работает и со строчками какой то косяк, хотя в протеусе все норм.

на скринах видно,что должно быть(сначала пишет привет,хеллоу, а через пару секуннд показывает шар), а на фотках - что получилось.пример кода брал из статьи на этом сайте. проект студии и протеуса прилагаю.

в программе особо не разбирался, ибо в примере на сайте работает и в протеусе тоже.пока хочу понять, жив вообще дисплей или нет

подскажите, в чем может быть проблема?может это какая то типичная ошибка?например в подключении

post-180923-0-18274500-1454705011_thumb.jpg

post-180923-0-81970000-1454705012_thumb.jpg

post-180923-0-52513400-1454705013_thumb.png

3310.rar

Ссылка на комментарий
Поделиться на другие сайты

Попробуйте увеличить ширину дисплея на 2 символа. В 5110.c в функции LcdGotoXY() исправить формулу на LcdCacheIdx = x * 6 + y * 96; Но лучше подобрать это чиселко экспериментально. С нижней полоской возможно тоже самое, если дисплей и в самом деле обладает большим разрешением, чем думает программа.

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

если дисплей и в самом деле обладает большим разрешением, чем думает программа.

спасибо,вы правы.

я немного вас дезинформировал, телефон у меня 3410, а не 3310.

нагуглил,что у него разрешение выше, 96на65.буду переписывать либу

только вот не пойму,рабочая область этого экрана, только та часть,что заметно контрастнее или вся поверхность экрана?

post-180923-0-08467100-1454753681_thumb.jpg

Изменено пользователем AlexAlex9417
Ссылка на комментарий
Поделиться на другие сайты

Очевидно, вся, на которую можно хоть что-то вывести.

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы публикуете как гость. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.
Примечание: Ваш пост будет проверен модератором, прежде чем станет видимым.

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
×
×
  • Создать...