unsigned char *dst = buf + dsty * 800*4 + (x + xpos + slot->bitmap_left)*4;
unsigned char *src = bm->buffer + y * bm->width;
- for (xx = 0; xx < bm->width; xx++) {
- *dst = (*dst * (256-*src) + r * *src) >> 8;
+
+ int width = (x + xpos + slot->bitmap_left + bm->width >= 800) ? (799 - x - xpos - slot->bitmap_left) : bm->width;
+ for (xx = 0; xx < width; xx++) {
+ *dst = (*dst * (256-*src) + b * *src) >> 8;
*dst++;
*dst = (*dst * (256-*src) + g * *src) >> 8;
*dst++;
- *dst = (*dst * (256-*src) + b * *src) >> 8;
+ *dst = (*dst * (256-*src) + r * *src) >> 8;
*dst++;
*dst++ = 0;
src++;
return x;
}
+
+void my_draw_text_deferred(std::vector<TextDefer> &td, const widestring &str, double size, int xpos, int ypos)
+{
+ TextDefer newtd;
+ newtd.str = str;
+ newtd.size = size;
+ newtd.xpos = xpos;
+ newtd.ypos = ypos;
+ td.push_back(newtd);
+}
+
+void draw_all_deferred_text(unsigned char *buf, std::vector<TextDefer> ¤t, std::vector<TextDefer> &old)
+{
+ for (unsigned i = 0; i < current.size(); ++i) {
+ int r, g, b;
+ if (i < old.size() && current[i].str != old[i].str) {
+ // changed text
+ r = 255;
+ g = 0;
+ b = 0;
+ } else {
+ r = g = b = 255;
+ }
+
+ my_draw_text(current[i].str, buf, current[i].size, current[i].xpos, current[i].ypos, r, g, b);
+ }
+}
+