Sunday, 28 July 2013

Blit(Display) Performance improvement in changing Screen Orientation (Portrait Mode)

I have encounter this issue during my development on mobile device app. We were trying to get the same refresh rate on both landscape and portrait screen orientation. I was getting 20 ms refresh rate for 800x480 resolution screen using memory DC blitting, but in portrait the performance deemed to 50 ms. My implementation was to achieve the similar look and feel for Display. So we were trying something given in figure, to render on screen in both orientation.


Now the graphics card always pulls pixels out of the frame buffer in the same
order, usually in landscape mode (Image1). So during refresh, the pixels are read in that order, starting with A.  Memory is organized so that the pixels in a single scanline are collected together
in a single "page" of memory, and memory accesses are faster when you stay
in the same page. 
But When you rotate the screen the refresh order does not change.  So, even
though you now see the screen like this: Image.2 the refresh still starts with pixel E , then J, then O and goes similar order through Z.
The desktop rotates because it is being DRAWN in the new order

And when we do a graphics operations, like filling the screen, you will start
with pixel A, then B, then C and same(Image2). Which leads you to the Performance Issue reason is Although they are adjacent on the screen, they are relatively far apart in the graphics memory, and that means it takes longer to switch from pixel to pixel.  Each access is a new page...

So if you want to achieve the similar performance like in landscape you should try implementing you code in such way so thatit should follow the redarw instruction in similar fashion as it was there in Landscape mode.  That is From E to J to O to T....D to I to N... till Z.

Thanks,

Sunday, 21 July 2013

Converting 32bit color to 16bit color code on Windows.

Usually on windows programming the color codes we use that belongs to 32bit color palate. It seems all fine when running the application on one platform devices as they have common specification. The problem arises when you switch your code from 32bit devices to 16bit where color code looks similar but it display differently. For example the color if RGB(145,23,59) would not look same when you simply covert this to 16bit values.

Here is the byte conversion from 32 bit color code to 16 bit code:-


DWORD dwColor32;
//converting to WORD;

WORD r  = (WORD) ( (dwColor32 & 0x00F80000) >> 19 );
WORD g = (WORD) ( (dwColor32 & 0x0000FC00) >> 5  );
WORD b = (WORD) ( (dwColor32 & 0x000000F8) << 8  ); 

WORD wColor16 = r | g | b;  // converted color in 16bit having same color palate

Hope above code should resolve your issues.