Nokia 7210 4096 renkli GLCD

Başlatan serdararikan, 19 Mayıs 2010, 21:09:55

papylon

Kesinlikle haklısın.

Zaten benimde yukarıda kastettiğim (LCD'nin kendisi gibi ufak ve sevimli projelerde kullanılabilir.) küçük projelerde 7210, biraz daha Jan Jan'lı projelerde ILI9325 veya benzeri anlamındaydı.

Monocrom LCD'ye Hayır!   Yaşasın RGB...  ;D

muhittin_kaplan

hepinize katılıyorum ama ilk mesajdaki linkte problem mi var.
4shared e yüklerseniz daha güzel olur

serdararikan

Alıntı yapılan: muhittin_kaplan - 03 Haziran 2010, 22:38:25
hepinize katılıyorum ama ilk mesajdaki linkte problem mi var.
4shared e yüklerseniz daha güzel olur

http://www.upload.gen.tr/d.php/s12/7ea479gq/nokia_7210.rar.html

yukarıdaki linkte son yazdığım hali var.içi dolu dikdörtgenleri daha hızlı çizebilmek için SPI kullandım biraz daha hızlandı ayrıca 5x7 boyutlarında yazı yazmak için bir kütüphane daha ekledim.

"Bilgi paylaşıldıkça artar......"

kolay gelsin

muhittin_kaplan

c değilde swordfish yada protonda yazacağım.
bir nevi çevirme işlemi yapacağım..

papylon

@serdararikan

Bu aralar boştayken LCD ile epeyce oynama şansım oldu. LCD'ye resim bile bastırdım.  ;D

Datasheet'ini anlayabildiğim kadarı ile kurcaladım fakat anlayamadığım ve sormak istediğim bir şey var.

X-Y başlangıcı olarak Ekranın 4 köşesinden herhangi bir yerini donanımsal olarak ayarlama imkanı var mı?

X ve Y mirror seçeneği var ve ekranın altını üstüne getiriyor ama sağ ve sol için de bu şekilde X-Y sıfır noktası belirlenebiliyor mu?

erhanmete

Alıntı yapılan: serdararikan - 02 Haziran 2010, 00:40:04
Alıntı yapılan: papylon - 02 Haziran 2010, 00:32:09
7210 LCD'yi alırken @Ahmet2004'ün kullandığı ILI9325 yongalı GLCD'yi ben de aldım ama deneme fırsatım olmadı.
Kütüphaneyle biraz oynayıp, LCD'nin kendisi gibi ufak ve sevimli projelerde kullanılabilir.

132-2 X 132-2 piksel bile olsa  :D

mesajım yanlış anlaşılmasın.ben bu lcd yi kullanmak isterken ilk amacım gidip 15-20tl verip 128x64 LCD ler almayı mantıklı bulmadığım için yola koyuldum.ve halen aynı fikirdeyim.bu tip bi lcd 5tl ye alınırken monokrom bir ekrana 20tl vermek anlamsız.


sizinle aynı fikirdeyim
adetli olarak temin edebileceğim bir adres verebilirmisiniz.
teşekkür ederim.

serdararikan

Alıntı yapılan: papylon - 07 Haziran 2010, 00:33:27
@serdararikan

Bu aralar boştayken LCD ile epeyce oynama şansım oldu. LCD'ye resim bile bastırdım.  ;D

Datasheet'ini anlayabildiğim kadarı ile kurcaladım fakat anlayamadığım ve sormak istediğim bir şey var.

X-Y başlangıcı olarak Ekranın 4 köşesinden herhangi bir yerini donanımsal olarak ayarlama imkanı var mı?

X ve Y mirror seçeneği var ve ekranın altını üstüne getiriyor ama sağ ve sol için de bu şekilde X-Y sıfır noktası belirlenebiliyor mu?

o kadar detaylı incelemedim ama sanırım bi swap olayı var.hangi işlemciyi kullanıyorsun resim falan bastığına göre hafızası yüksek bi işlemci olması lazım??

papylon

Bugün işi çözdüm. Gece yatıp sabah kalkınca kafa biraz dinlendi sanırım.  :)

MEMORY DATA ACCESS CONTROL registerin'da ki MX-MY ve V bitlerinden kontrol ediliyor. Tabi birazda software.


Alıntı Yap
hangi işlemciyi kullanıyorsun resim falan bastığına göre hafızası yüksek bi işlemci olması lazım??
Yok yok, öyle uçuk kaçık bir işlemci falan değil, hepimizin yakinen tanıdığı şu bildiğimiz 16F877'lerden olur kendisi. ;D

Bastığım resimde kocaman falan değil. 25 x 25 piksel 8-bit RGB modunda  ufacık bir Windows7 amblemi. Deneme amaçlıydı yani. Gayet de güzel görünüyor 8-bit RGB için.
Kütüphaneyi tam olarak bitireyim, o zaman paylaşırım sizlerle.

papylon

8-bit RGB için kütüphane dosyasını tamamladım. Aşağıdaki linkten indirebilirsiniz.

Kütüphane fonksiyonuna açıklamalar yazamadım onun için kusura bakmayın, fakat neyin ne olduğunun anlaşılabilmesi için ufak bir de program yazdım, onda açıklamalar var.

İndireceğiniz NOKIA 7210.rar dosyasının içinde deneme için iki küçük resim, bmp ve jpeg Hex Converter, Hex ve COF dosyaları, ve kütüphane fonksiyonu var.

Ekranın herhangi dört köşesinden birini 0 koordinat noktası olarak belirleyebilirsiniz. Bunu da 7210_driver.c kütüphanesinde ki  "#define   DISPOS" tanımlamasından yapabilirsiniz.


NOKIA 7210.rar


serdararikan

@ papylon

eline sağlık güzel kütüphane olmuş.

papylon

İşe yaradıysa ne mutlu...
;D Güle  ;D güle kullanın...

matador

Ustalar bu ekranı nereden ve ne kadara aldınız?

ugurtelefon

Alıntı yapılan: matador - 25 Ocak 2011, 23:42:17
Ustalar bu ekranı nereden ve ne kadara aldınız?

ceptelefonu malzemesi satan işyerlerinde bulabilirsin. 5-7tl arası bir fiyattadır.
Gerçi ben bu projeyi yapmadım ama gsm sektöründe olduğum için dikkatimi çekti.Çok hoş bir proje.Birçok endüstiriyel uygulamada scala olarak yada girilen komutları,cihazın o anki durumunu göstermek için kullanılabilir.

matador

Alıntı yapılan: serdararikan - 19 Mayıs 2010, 21:09:55
ilgilenen arkadaşlar için Nokia 7210 ekran için yazdığım kodları ve basit bir uygulama adına scope çalışmamın videosunu ekliyorum.


c dosyası
#include"7210_driver.h"
#define _XTAL_FREQ 20000000L

void ShiftBits(unsigned char dt)
{
	unsigned char i,mask=0b10000000;
	for (i=0;i<8;i++)
	{
		if (dt & mask) DATA=1; else DATA=0;
		clk_plus
		mask>>=1;
	}
}

unsigned char data;
void shift()
{
		#asm
		BSF	7,3
		BCF	7,3
		BCF	7,5
		btfsc (_data),7
		bsf	7,5
		BSF	7,3
		BCF	7,3
		BCF	7,5
		btfsc (_data),6
		bsf	7,5
		BSF	7,3
		BCF	7,3
		BCF	7,5
		btfsc (_data),5
		bsf	7,5
		BSF	7,3
		BCF	7,3
		BCF	7,5
		btfsc (_data),4
		bsf	7,5
		BSF	7,3
		BCF	7,3
		BCF	7,5
		btfsc (_data),3
		bsf	7,5
		BSF	7,3
		BCF	7,3
		BCF	7,5
		btfsc (_data),2
		bsf	7,5
		BSF	7,3
		BCF	7,3
		BCF	7,5
		btfsc (_data),1
		bsf	7,5
		BSF	7,3
		BCF	7,3
		BCF	7,5
		btfsc (_data),0
		bsf	7,5
		BSF	7,3
		BCF	7,3	
	#endasm	
}

void SendData(unsigned char dt)
{	
	CS=0;
	DATA=1;
	clk_plus
	ShiftBits(dt);
}

void SendCommand(unsigned char dt)
{	
	CS=0;
	DATA=0;
	clk_plus
	ShiftBits(dt);
}

void SetContrast(unsigned char value)
{
	SendCommand(SETCON);
	SendData(value);
	CS=1;
}

void LCD_Initialize(unsigned char value)
{
	CS=1;
	RST=0;
	__delay_ms(30);
	RST=1;
	SendCommand(SLEEPOUT);
	__delay_ms(2);	
	SendCommand(MADCTL);
	SendData(0x20);
	SendCommand(SETCON);
	SendData(0x30);
	CS=1;
	__delay_ms(4);	
	SendCommand(DISPON);
	SendCommand(COLMOD);
	if (value==Mod_RGB8) SendData(2); else SendData(3);
}

void DoluDikdortgen(int X1,int Y1,int X2,int Y2,unsigned char renk)
{	int PixelCount,i;
	SendCommand(PASET);
	SendData(X1);
	SendData(X2);
	SendCommand(CASET);
	SendData(Y1);
	SendData(Y2);
	SendCommand(RAMWR);
	PixelCount = (X2 - X1 + 1) * (Y2 - Y1 + 1);
	for (i = 0; i < PixelCount; i++) SendData(renk);
	SendCommand(NOP);
	CS=1;
}

void Pixel(int X,int Y,unsigned char renk)
{	
	SendCommand(PASET);
	SendData(X);
	SendCommand(CASET);
	SendData(Y);
	SendCommand(RAMWR);
	SendData(renk);
	CS=1;
}

void CizgiCiz(int X1,int Y1,int X2,int Y2,unsigned char renk)
{	
	int dy;
   int dx;
   int StepX, StepY;
   int Fraction;

   dy = Y2 - Y1;
   dx = X2 - X1;

   if (dy < 0)
   {   
		dy = -dy;
      StepY = -1;
   }
   else StepY = 1;

   if (dx < 0)
   {   
		dx = -dx;
      StepX = -1;
   }
   else StepX = 1;

   dy <<= 1;                            // dy is now 2*dy
   dx <<= 1;                            // dx is now 2*dx
   Pixel(X1,Y1,renk);

   if (dx > dy)
   {   Fraction = dy - (dx >> 1);             // same as 2*dy - dx
      while (X1 != X2)
      {   if (Fraction >= 0)
         {   Y1 += StepY;
            Fraction -= dx;             // same as fraction -= 2*dx
         }

         X1 += StepX;
         Fraction += dy;                // same as fraction -= 2*dy
         Pixel(X1, Y1, renk);
      }
   }

   else
   {   Fraction = dx - (dy >> 1);
      while (Y1 != Y2)
      {   if (Fraction >= 0)
         {   X1 += StepX;
            Fraction -= dy;
         }

         Y1 += StepY;
         Fraction += dx;
         Pixel(X1, Y1,renk);
      }
   }
}

void DaireCiz(int X,int Y,int Radius,unsigned char renk)
{
	int f;
   int ddF_x;
   int ddF_y;
   int x;
   int y;

   f = 1 - Radius;
   ddF_x = 0;
   ddF_y = -2 * Radius;
   x = 0;
   y = Radius;

   Pixel(X, Y + Radius, renk);
   Pixel(X, Y - Radius, renk);
   Pixel(X + Radius, Y, renk);
   Pixel(X - Radius, Y, renk);

   while (x < y)
   {   if (f >= 0)
      {   y--;
         ddF_y += 2;
         f += ddF_y;
      }

      x++;
      ddF_x += 2;
      f += ddF_x + 1;

      Pixel(X + x, Y + y, renk);
      Pixel(X - x, Y + y, renk);
      Pixel(X + x, Y - y, renk);
      Pixel(X - x, Y - y, renk);
      Pixel(X + y, Y + x, renk);
      Pixel(X - y, Y + x, renk);
      Pixel(X + y, Y - x, renk);
      Pixel(X - y, Y - x, renk);
   }
}

void DoluDaireCiz(int X,int Y,int Radius,unsigned char renk)
{
	int f;
   int ddF_x;
   int ddF_y;
   int x;
   int y;

   f = 1 - Radius;
   ddF_x = 0;
   ddF_y = -2 * Radius;
   x = 0;
   y = Radius;

	CizgiCiz(X - Radius,Y,X + Radius,Y,renk);
	Pixel(X, Y + Radius, renk);
   Pixel(X, Y - Radius, renk);
   
   while (x < y)
   {   if (f >= 0)
      {   y--;
         ddF_y += 2;
         f += ddF_y;
      }

      x++;
      ddF_x += 2;
      f += ddF_x + 1;

		CizgiCiz(X + x,Y + y,X - x,Y + y,renk);
		CizgiCiz(X + x,Y - y,X - x,Y - y,renk);
		CizgiCiz(Y + y,X - x,Y - y,X - x,renk);
		CizgiCiz(Y + y,X + x,Y - y,X + x,renk);
   }
}

void Dikdortgen12(unsigned char X1,unsigned char Y1,unsigned char X2,unsigned char Y2,unsigned int renk)
{
	CizgiCiz12(X1,Y1,X2,Y1,renk);
	CizgiCiz12(X1,Y2,X2,Y2,renk);
	CizgiCiz12(X1,Y1,X1,Y2,renk);
	CizgiCiz12(X2,Y1,X2,Y2,renk);
}

void DoluDikdortgen12(int X1,int Y1,int X2,int Y2,unsigned int renk)
{
	int i;
   int PixelCount;
   unsigned char Byte1, Byte2, Byte3;
   int LoopCount;

	SendCommand(PASET);
	SendData(X1);
	SendData(X2);
	SendCommand(CASET);
	SendData(Y1);
	SendData(Y2);
	SendCommand(RAMWR);
	
   if ((X1 > X2) || (Y1 > Y2)) return;
  
   Byte1 = (renk >> 4) & 0xff;
   Byte2 = (((renk & 0x0f) << 4) | ((renk >> 8) & 0x0f));
   Byte3 = (renk & 0xff);

   PixelCount =  (X2 - X1 + 1) * (Y2 - Y1 + 1);
   LoopCount = (PixelCount / 2) + 1;
	CS=0;
   for (i = 0; i < LoopCount; i++)
   {   
		DATA=1;
		data=Byte1;
		shift();
		DATA=1;
		data=Byte2;
		shift();
		DATA=1;
		data=Byte3;		
		shift();
	}
   SendCommand(NOP);
   CS=1;
}

void Pixel12(int X,int Y,int renk)
{	
	unsigned char Byte1, Byte2;
	SendCommand(PASET);
	SendData(X);
	SendCommand(CASET);
	SendData(Y);
	SendCommand(RAMWR);
  
   Byte1 = (renk >> 4) & 0xff;
   Byte2 = ((renk & 0x0f) << 4) ;

	SendData(Byte1);
	SendData(Byte2);

   SendCommand(NOP);
   CS=1;
}

void DaireCiz12(int X,int Y,int Radius,int renk)
{
	int f;
   int ddF_x;
   int ddF_y;
   int x;
   int y;

   f = 1 - Radius;
   ddF_x = 0;
   ddF_y = -2 * Radius;
   x = 0;
   y = Radius;

   Pixel12(X, Y + Radius, renk);
   Pixel12(X, Y - Radius, renk);
   Pixel12(X + Radius, Y, renk);
   Pixel12(X - Radius, Y, renk);

   while (x < y)
   {   if (f >= 0)
      {   y--;
         ddF_y += 2;
         f += ddF_y;
      }

      x++;
      ddF_x += 2;
      f += ddF_x + 1;

      Pixel12(X + x, Y + y, renk);
      Pixel12(X - x, Y + y, renk);
      Pixel12(X + x, Y - y, renk);
      Pixel12(X - x, Y - y, renk);
      Pixel12(X + y, Y + x, renk);
      Pixel12(X - y, Y + x, renk);
      Pixel12(X + y, Y - x, renk);
      Pixel12(X - y, Y - x, renk);
   }
}

void CizgiCiz12(int X1,int Y1,int X2,int Y2,int renk)
{	
	int dy;
   int dx;
   int StepX, StepY;
   int Fraction;

   dy = Y2 - Y1;
   dx = X2 - X1;

   if (dy < 0)
   {   
		dy = -dy;
      StepY = -1;
   }
   else StepY = 1;

   if (dx < 0)
   {   
		dx = -dx;
      StepX = -1;
   }
   else StepX = 1;

   dy <<= 1;                            // dy is now 2*dy
   dx <<= 1;                            // dx is now 2*dx
   Pixel12(X1,Y1,renk);

   if (dx > dy)
   {   Fraction = dy - (dx >> 1);             // same as 2*dy - dx
      while (X1 != X2)
      {   if (Fraction >= 0)
         {   Y1 += StepY;
            Fraction -= dx;             // same as fraction -= 2*dx
         }

         X1 += StepX;
         Fraction += dy;                // same as fraction -= 2*dy
         Pixel12(X1, Y1, renk);
      }
   }

   else
   {   Fraction = dx - (dy >> 1);
      while (Y1 != Y2)
      {   if (Fraction >= 0)
         {   X1 += StepX;
            Fraction -= dy;
         }

         Y1 += StepY;
         Fraction += dx;
         Pixel12(X1, Y1, renk);
      }
   }
}

void DoluDaireCiz12(int X,int Y,int Radius,int renk)
{
	int a, b, P;
   a = 0;
   b = Radius;
   P = 1 - Radius;

   do
   {
      CizgiCiz12(X-a, Y+b, X+a, Y+b, renk);
      CizgiCiz12(X-a, Y-b, X+a, Y-b, renk);
      CizgiCiz12(X-b, Y+a, X+b, Y+a, renk);
      CizgiCiz12(X-b, Y-a, X+b, Y-a, renk);
      if(P < 0)
         P+= 3 + 2*a++;
      else
         P+= 5 + 2*(a++ - b--);
    } while(a <= b);
}

void Buton12(unsigned char X,unsigned char Y,unsigned char width,unsigned char height,int renk)
{
	DoluDikdortgen12(X,Y,X+width,Y+height,white);
	DoluDikdortgen12(X+3,Y+3,X+width-3,Y+height-3,renk);
	CizgiCiz12(X+width,Y,X+width,Y+height,black);
	CizgiCiz12(X+width-1,Y+1,X+width-1,Y+height-1,black);
	CizgiCiz12(X+width-2,Y+2,X+width-2,Y+height-2,black);
	CizgiCiz12(X,Y+height,X+width,Y+height,black);
	CizgiCiz12(X+1,Y+height-1,X+width-1,Y+height-1,black);
	CizgiCiz12(X+2,Y+height-2,X+width-2,Y+height-2,black);
	CizgiCiz12(X,Y,X+3,Y+3,renk);
}


header dosyası
#include<pic.h>

#define		RST	RC0
#define		CS		RC1
#define		LED	RB0
#define		CLK	RC3
#define		DATA	RC5

#define SDO		RC5
#define SCK		RC3

#define NOP    		0x00       // nop
#define SWRESET 		0x01       // software reset
#define BSTROFF 		0x02       // booster voltage OFF
#define BSTRON    	0x03       // booster voltage ON
#define RDDIDIF 		0x04       // read display identification
#define RDDST    		0x09       // read display status
#define SLEEPIN 		0x10       // sleep in
#define SLEEPOUT 		0x11       // sleep out
#define PTLON    		0x12       // partial display mode
#define NORON    		0x13       // display normal mode
#define INVOFF    	0x20       // inversion OFF
#define INVON    		0x21       // inversion ON
#define DALO    		0x22       // all pixel OFF
#define DAL    		0x23       // all pixel ON
#define SETCON    	0x25       // write contrast
#define DISPOFF 		0x28       // display OFF
#define DISPON    	0x29       // display ON
#define CASET    		0x2A       // column address set
#define PASET    		0x2B       // page address set
#define RAMWR    		0x2C       // memory write
#define RGBSET    	0x2D       // colour set
#define PTLAR    		0x30       // partial area
#define VSCRDEF 		0x33       // vertical scrolling definition
#define TEOFF    		0x34       // test mode
#define TEON    		0x35      // test mode
#define MADCTL    	0x36       // memory access control
#define SEP    		0x37       // vertical scrolling start address
#define IDMOFF    	0x38       // idle mode OFF
#define IDMON    		0x39       // idle mode ON
#define COLMOD    	0x3A       // interface pixel format
#define SETVOP    	0xB0       // set Vop
#define BRS    		0xB4       // bottom row swap
#define TRS    		0xB6       // top row swap
#define DISCTR    	0xB9       // display control
#define DOR    		0xBA       // data order
#define TCDFE    		0xBD       // enable/disable DF temperature compensation
#define TCVOPE    	0xBF       // enable/disable Vop temp comp
#define EC       		0xC0       // internal or external oscillator
#define SETMUL    	0xC2       // set multiplication factor
#define TCVOPAB 		0xC3       // set TCVOP slopes A and B
#define TCVOPCD 		0xC4       // set TCVOP slopes c and d
#define TCDF    		0xC5       // set divider frequency
#define DF8COLOR 		0xC6       // set divider frequency 8-color mode
#define SETBS    		0xC7       // set bias system
#define RDTEMP    	0xC8       // temperature read back
#define NLI    		0xC9       // n-line inversion
#define RDID1    		0xDA       // read ID1
#define RDID2    		0xDB       // read ID2
#define RDID3    		0xDC       // read ID3

#define Mod_RGB8		2
#define Mod_RGB12		3

#define red				0xf00
#define green			0x0f0
#define blue			0x00f
#define black			0x000
#define white			0xfff
#define cyan			0x0FF
#define magenta 		0xF0F
#define yellow			0xFF0
#define brown			0xB22
#define orange			0xFA0
#define pink			0xF6A


#define clk_plus	CLK=1;CLK=0;

extern void ShiftBits(unsigned char dt);
extern void SendData(unsigned char dt);
extern void SendCommand(unsigned char dt);

extern void LCD_Initialize(unsigned char value);
extern void SetContrast(unsigned char value);

extern void DoluDikdortgen(int X1,int Y1,int X2,int Y2,unsigned char renk);
extern void Pixel(int X,int Y,unsigned char renk);
extern void CizgiCiz(int X1,int Y1,int X2,int Y2,unsigned char renk);
extern void DaireCiz(int X,int Y,int Radius,unsigned char renk);
extern void DoluDaireCiz(int X,int Y,int Radius,unsigned char renk);

extern void Dikdortgen12(unsigned char X1,unsigned char Y1,unsigned char X2,unsigned char Y2,unsigned int renk);
extern void DoluDikdortgen12(int X1,int Y1,int X2,int Y2,unsigned int renk);
extern void Pixel12(int X,int Y,int renk);
extern void CizgiCiz12(int X1,int Y1,int X2,int Y2,int renk);
extern void DaireCiz12(int X,int Y,int Radius,int renk);
extern void DoluDaireCiz12(int X,int Y,int Radius,int renk);

extern void Buton12(unsigned char X,unsigned char Y,unsigned char width,unsigned char height,int renk);




http://rapidshare.com/files/389245531/nokia_7210.rar.html

Hocam lcd'yi sürmek için yardımcı bir devreye ihtiyaç var mı? Lcd'yi bağladığınız devre ne için? Verdiğiniz http://electronique.marcel.free.fr/LCD%20Nokia%20couleurs.html şu linkte de benzer bir devre var smdlerle yapılmış.  Direk pic'in çıkışlarını bağlarsam sorun olur mu?   Lcd'de kullanılan sürücüyü anlamak için nereye bakacağız.

serdararikan

gönderdiğiniz linkteki devreyide yapabilirsiniz.PIC 5V ile çalıştığı için gerilim bölücüler ile picin 5V unu 3.3V a düşürüyoruz.devre onun için.birde ekranın soketi çok ince pinlere sahip.lehimleme kolaylığı olsun diye öyle bir pcb hazırladık.sürücü dediğimiz şey ekranı açmak ve ekrana pixel bilgisi göndermek için hazırladığımız kodlar.Tahtakalede bu ekran çok ucuz 5tl civarında gidip oradan ekranı temin edebilirsin.forumda benim ve diğer arkadaların hazırladığı kodları kullanarak zaman kazanabilirsin.gerisi hayal gücüne kalmış