Closed GoogleCodeExporter closed 8 years ago
reinit is done with this command within Arduino env (not tested):
u8g_InitLL(u8g.getU8g(), u8g.getU8g()->dev);
This should send the init sequence again.
Can you confirm, that everything is ok without the additional circuit?
What about adding some larger caps between ground and power supply?
Original comment by olikr...@gmail.com
on 13 Sep 2012 at 3:52
Original comment by olikr...@gmail.com
on 13 Sep 2012 at 3:52
wow, the reinitialize code works perfectly, and I did try things out with
larger caps, but if i really try to ignite having the screen mess up by
connecting my ground planes on my breadboards, then eventually after enough
tries, i can still manage to mess up the screen. I just recently ordered
some supercaps figuring that it was most likely dips on my 12 volts needed
for the screen so i'll have to get back to you on whether it fixed the
whole situation.
and great job on this library by the way. ever since i've been playing
with arduinos, i've been fascinated by driving lcd screens and I definitely
like this library the most by far.
Original comment by electric...@gmail.com
on 13 Sep 2012 at 5:26
glad, that you like this lib :-)
i will close this issue, feel free to add a new one (or contact me directly)
Oliver
Original comment by olikr...@gmail.com
on 13 Sep 2012 at 5:38
Original comment by olikr...@gmail.com
on 13 Sep 2012 at 5:38
Oliver,
I'm hitting some issues with the speed of running the u8g library and
arduino. Let's say i'm trying to display a lot of text on a screen while
having the arduino processing inputs and outputs simultaneously.
Is there any way I can optimize my code so that the frame rate speeds up or
only changes when needed? For example, my main loop is always drawing to
the screen, and I also need it to run the operation code as fast as
possible. I was considering having the font library be pulled into RAM
instead of PROGMEM because I believe there could be some delay with looking
up characters from the font library in PROGMEM, and I've also tried
considering a "run once" code where the screen updates to the latest text,
and then doesn't continue writing to the screen until something needs to
change, but that doesn't seem to work.
The whole reason behind this is that I'm trying to make a simple menu
structure, however if it's taking 20ms to write to the screen each time,
then that's 20ms of processing time in my loop that I lose, so I can't do
button press updates very quickly and therefore have a laggy or skipped
button response.
Is there anything you could suggest I do to speed up this process whether
it be use software interrupts for buttons or anything like that?
Original comment by electric...@gmail.com
on 18 Sep 2012 at 9:48
Hi
I would suggest to contact me directly @gmail.com (see e-mail in the source
code of u8glib). With e-mails it is easier to share and discuss code.
Here are some ideas:
General speed up:
- use 2x version of the display device
- use hardware SPI variants
Processing:
- Interleave your processing code with the picture loop
- E.g. use button checks within the picture loop
Let me give an example with m2tklib (which is my menu lib):
// Arduino loop procedure
void loop() {
m2.checkKey();
if ( m2.handleKey() ) {
u8g.firstPage();
do {
m2.checkKey();
draw();
} while( u8g.nextPage() );
}
}
"m2.checkKey()" is the m2tklib procedure to check for a menu
button (also does debounce and queueing). It can be called inside
and outside of the picture loop.
Oliver
Original comment by olikr...@gmail.com
on 19 Sep 2012 at 4:34
Original issue reported on code.google.com by
electric...@gmail.com
on 13 Sep 2012 at 2:29