mirror of https://github.com/stella-emu/stella.git
More GUI infrastructure changes. I'm hoping to have the CheatWidget
complete by tomorrow evening. git-svn-id: svn://svn.code.sf.net/p/stella/code/trunk@493 8b62c5a3-ac7e-4cc8-8f21-d9a121418aba
This commit is contained in:
parent
15ae1043e9
commit
780422bd42
|
@ -13,7 +13,7 @@
|
||||||
## See the file "license" for information on usage and redistribution of
|
## See the file "license" for information on usage and redistribution of
|
||||||
## this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
## this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
##
|
##
|
||||||
## $Id: makefile,v 1.93 2005-06-12 20:12:10 stephena Exp $
|
## $Id: makefile,v 1.94 2005-06-14 01:11:47 stephena Exp $
|
||||||
##============================================================================
|
##============================================================================
|
||||||
|
|
||||||
##============================================================================
|
##============================================================================
|
||||||
|
@ -157,6 +157,7 @@ M6502_OBJS = D6502.o Device.o M6502.o M6502Low.o M6502Hi.o NullDev.o System.o
|
||||||
|
|
||||||
GUI_OBJS = Font.o Menu.o Launcher.o \
|
GUI_OBJS = Font.o Menu.o Launcher.o \
|
||||||
Widget.o PopUpWidget.o ScrollBarWidget.o ListWidget.o TabWidget.o \
|
Widget.o PopUpWidget.o ScrollBarWidget.o ListWidget.o TabWidget.o \
|
||||||
|
EditableWidget.o EditTextWidget.o \
|
||||||
Dialog.o DialogContainer.o OptionsDialog.o VideoDialog.o AudioDialog.o \
|
Dialog.o DialogContainer.o OptionsDialog.o VideoDialog.o AudioDialog.o \
|
||||||
EventMappingDialog.o GameInfoDialog.o HelpDialog.o AboutDialog.o \
|
EventMappingDialog.o GameInfoDialog.o HelpDialog.o AboutDialog.o \
|
||||||
LauncherDialog.o LauncherOptionsDialog.o BrowserDialog.o GameList.o \
|
LauncherDialog.o LauncherOptionsDialog.o BrowserDialog.o GameList.o \
|
||||||
|
@ -407,6 +408,12 @@ ListWidget.o: $(GUI)/ListWidget.cxx $(GUI)/ListWidget.hxx
|
||||||
TabWidget.o: $(GUI)/TabWidget.cxx $(GUI)/TabWidget.hxx
|
TabWidget.o: $(GUI)/TabWidget.cxx $(GUI)/TabWidget.hxx
|
||||||
$(CXX) -c $(FLAGS) $(OPTIONS) $(LDFLAGS) $(GUI)/TabWidget.cxx
|
$(CXX) -c $(FLAGS) $(OPTIONS) $(LDFLAGS) $(GUI)/TabWidget.cxx
|
||||||
|
|
||||||
|
EditableWidget.o: $(GUI)/EditableWidget.cxx $(GUI)/EditableWidget.hxx
|
||||||
|
$(CXX) -c $(FLAGS) $(OPTIONS) $(LDFLAGS) $(GUI)/EditableWidget.cxx
|
||||||
|
|
||||||
|
EditTextWidget.o: $(GUI)/EditTextWidget.cxx $(GUI)/EditTextWidget.hxx
|
||||||
|
$(CXX) -c $(FLAGS) $(OPTIONS) $(LDFLAGS) $(GUI)/EditTextWidget.cxx
|
||||||
|
|
||||||
Dialog.o: $(GUI)/Dialog.cxx $(GUI)/Dialog.hxx
|
Dialog.o: $(GUI)/Dialog.cxx $(GUI)/Dialog.hxx
|
||||||
$(CXX) -c $(FLAGS) $(OPTIONS) $(LDFLAGS) $(GUI)/Dialog.cxx
|
$(CXX) -c $(FLAGS) $(OPTIONS) $(LDFLAGS) $(GUI)/Dialog.cxx
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferGL.cxx,v 1.28 2005-06-08 18:45:07 stephena Exp $
|
// $Id: FrameBufferGL.cxx,v 1.29 2005-06-14 01:11:47 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <SDL.h>
|
#include <SDL.h>
|
||||||
|
@ -352,26 +352,25 @@ void FrameBufferGL::fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferGL::drawChar(const GUI::Font& FONT, uInt8 chr,
|
void FrameBufferGL::drawChar(const GUI::Font* FONT, uInt8 chr,
|
||||||
uInt32 xorig, uInt32 yorig, OverlayColor color)
|
uInt32 xorig, uInt32 yorig, OverlayColor color)
|
||||||
{
|
{
|
||||||
// FIXME - I do this to prevent 'const' warnings; it should be done better
|
GUI::Font* font = (GUI::Font*) FONT;
|
||||||
GUI::Font& font = (GUI::Font&)FONT;
|
|
||||||
|
|
||||||
// If this character is not included in the font, use the default char.
|
// If this character is not included in the font, use the default char.
|
||||||
if(chr < font.desc().firstchar ||
|
if(chr < font->desc().firstchar ||
|
||||||
chr >= font.desc().firstchar + font.desc().size)
|
chr >= font->desc().firstchar + font->desc().size)
|
||||||
{
|
{
|
||||||
if (chr == ' ')
|
if (chr == ' ')
|
||||||
return;
|
return;
|
||||||
chr = font.desc().defaultchar;
|
chr = font->desc().defaultchar;
|
||||||
}
|
}
|
||||||
|
|
||||||
const Int32 w = font.getCharWidth(chr);
|
const Int32 w = font->getCharWidth(chr);
|
||||||
const Int32 h = font.getFontHeight();
|
const Int32 h = font->getFontHeight();
|
||||||
chr -= font.desc().firstchar;
|
chr -= font->desc().firstchar;
|
||||||
const uInt16* tmp = font.desc().bits + (font.desc().offset ?
|
const uInt16* tmp = font->desc().bits + (font->desc().offset ?
|
||||||
font.desc().offset[chr] : (chr * h));
|
font->desc().offset[chr] : (chr * h));
|
||||||
|
|
||||||
SDL_Rect rect;
|
SDL_Rect rect;
|
||||||
for(int y = 0; y < h; y++)
|
for(int y = 0; y < h; y++)
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferGL.hxx,v 1.15 2005-06-08 18:45:08 stephena Exp $
|
// $Id: FrameBufferGL.hxx,v 1.16 2005-06-14 01:11:48 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef FRAMEBUFFER_GL_HXX
|
#ifndef FRAMEBUFFER_GL_HXX
|
||||||
|
@ -35,7 +35,7 @@ class GUI::Font;
|
||||||
This class implements an SDL OpenGL framebuffer.
|
This class implements an SDL OpenGL framebuffer.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: FrameBufferGL.hxx,v 1.15 2005-06-08 18:45:08 stephena Exp $
|
@version $Id: FrameBufferGL.hxx,v 1.16 2005-06-14 01:11:48 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class FrameBufferGL : public FrameBuffer
|
class FrameBufferGL : public FrameBuffer
|
||||||
{
|
{
|
||||||
|
@ -164,7 +164,7 @@ class FrameBufferGL : public FrameBuffer
|
||||||
@param y The y coordinate
|
@param y The y coordinate
|
||||||
@param color The color of the character
|
@param color The color of the character
|
||||||
*/
|
*/
|
||||||
virtual void drawChar(const GUI::Font& font, uInt8 c, uInt32 x, uInt32 y,
|
virtual void drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32 y,
|
||||||
OverlayColor color);
|
OverlayColor color);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferSoft.cxx,v 1.24 2005-06-08 18:45:08 stephena Exp $
|
// $Id: FrameBufferSoft.cxx,v 1.25 2005-06-14 01:11:48 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <SDL.h>
|
#include <SDL.h>
|
||||||
|
@ -375,26 +375,25 @@ void FrameBufferSoft::fillRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBufferSoft::drawChar(const GUI::Font& FONT, uInt8 chr,
|
void FrameBufferSoft::drawChar(const GUI::Font* FONT, uInt8 chr,
|
||||||
uInt32 xorig, uInt32 yorig, OverlayColor color)
|
uInt32 xorig, uInt32 yorig, OverlayColor color)
|
||||||
{
|
{
|
||||||
// FIXME - I do this to prevent 'const' warnings; it should be done better
|
GUI::Font* font = (GUI::Font*)FONT;
|
||||||
GUI::Font& font = (GUI::Font&)FONT;
|
|
||||||
|
|
||||||
// If this character is not included in the font, use the default char.
|
// If this character is not included in the font, use the default char.
|
||||||
if(chr < font.desc().firstchar ||
|
if(chr < font->desc().firstchar ||
|
||||||
chr >= font.desc().firstchar + font.desc().size)
|
chr >= font->desc().firstchar + font->desc().size)
|
||||||
{
|
{
|
||||||
if (chr == ' ')
|
if (chr == ' ')
|
||||||
return;
|
return;
|
||||||
chr = font.desc().defaultchar;
|
chr = font->desc().defaultchar;
|
||||||
}
|
}
|
||||||
|
|
||||||
const Int32 w = font.getCharWidth(chr);
|
const Int32 w = font->getCharWidth(chr);
|
||||||
const Int32 h = font.getFontHeight();
|
const Int32 h = font->getFontHeight();
|
||||||
chr -= font.desc().firstchar;
|
chr -= font->desc().firstchar;
|
||||||
const uInt16* tmp = font.desc().bits + (font.desc().offset ?
|
const uInt16* tmp = font->desc().bits + (font->desc().offset ?
|
||||||
font.desc().offset[chr] : (chr * h));
|
font->desc().offset[chr] : (chr * h));
|
||||||
|
|
||||||
SDL_Rect rect;
|
SDL_Rect rect;
|
||||||
for(int y = 0; y < h; y++)
|
for(int y = 0; y < h; y++)
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBufferSoft.hxx,v 1.15 2005-06-08 18:45:08 stephena Exp $
|
// $Id: FrameBufferSoft.hxx,v 1.16 2005-06-14 01:11:48 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef FRAMEBUFFER_SOFT_HXX
|
#ifndef FRAMEBUFFER_SOFT_HXX
|
||||||
|
@ -35,7 +35,7 @@ class RectList;
|
||||||
This class implements an SDL software framebuffer.
|
This class implements an SDL software framebuffer.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: FrameBufferSoft.hxx,v 1.15 2005-06-08 18:45:08 stephena Exp $
|
@version $Id: FrameBufferSoft.hxx,v 1.16 2005-06-14 01:11:48 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class FrameBufferSoft : public FrameBuffer
|
class FrameBufferSoft : public FrameBuffer
|
||||||
{
|
{
|
||||||
|
@ -164,7 +164,7 @@ class FrameBufferSoft : public FrameBuffer
|
||||||
@param y The y coordinate
|
@param y The y coordinate
|
||||||
@param color The color of the character
|
@param color The color of the character
|
||||||
*/
|
*/
|
||||||
virtual void drawChar(const GUI::Font& font, uInt8 c, uInt32 x, uInt32 y,
|
virtual void drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32 y,
|
||||||
OverlayColor color);
|
OverlayColor color);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBuffer.cxx,v 1.43 2005-06-08 18:45:08 stephena Exp $
|
// $Id: FrameBuffer.cxx,v 1.44 2005-06-14 01:11:48 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
|
@ -185,7 +185,7 @@ void FrameBuffer::update()
|
||||||
// Draw the bounded box and text
|
// Draw the bounded box and text
|
||||||
blendRect(x+1, y+2, w-2, h-4, kBGColor);
|
blendRect(x+1, y+2, w-2, h-4, kBGColor);
|
||||||
box(x, y+1, w, h-2, kColor, kColor);
|
box(x, y+1, w, h-2, kColor, kColor);
|
||||||
drawString(myOSystem->font(), myMessageText, x+1, y+4, w, kTextColor, kTextAlignCenter);
|
drawString(&myOSystem->font(), myMessageText, x+1, y+4, w, kTextColor, kTextAlignCenter);
|
||||||
myMessageTime--;
|
myMessageTime--;
|
||||||
|
|
||||||
// Erase this message on next update
|
// Erase this message on next update
|
||||||
|
@ -536,14 +536,14 @@ void FrameBuffer::frameRect(uInt32 x, uInt32 y, uInt32 w, uInt32 h,
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
void FrameBuffer::drawString(const GUI::Font& font, const string& s,
|
void FrameBuffer::drawString(const GUI::Font* font, const string& s,
|
||||||
int x, int y, int w,
|
int x, int y, int w,
|
||||||
OverlayColor color, TextAlignment align,
|
OverlayColor color, TextAlignment align,
|
||||||
int deltax, bool useEllipsis)
|
int deltax, bool useEllipsis)
|
||||||
{
|
{
|
||||||
const int leftX = x, rightX = x + w;
|
const int leftX = x, rightX = x + w;
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
int width = font.getStringWidth(s);
|
int width = font->getStringWidth(s);
|
||||||
string str;
|
string str;
|
||||||
|
|
||||||
if(useEllipsis && width > w)
|
if(useEllipsis && width > w)
|
||||||
|
@ -554,7 +554,7 @@ void FrameBuffer::drawString(const GUI::Font& font, const string& s,
|
||||||
// What is best really depends on the context; but unless we want to
|
// What is best really depends on the context; but unless we want to
|
||||||
// make this configurable, replacing the middle probably is a good
|
// make this configurable, replacing the middle probably is a good
|
||||||
// compromise.
|
// compromise.
|
||||||
const int ellipsisWidth = font.getStringWidth("...");
|
const int ellipsisWidth = font->getStringWidth("...");
|
||||||
|
|
||||||
// SLOW algorithm to remove enough of the middle. But it is good enough for now.
|
// SLOW algorithm to remove enough of the middle. But it is good enough for now.
|
||||||
const int halfWidth = (w - ellipsisWidth) / 2;
|
const int halfWidth = (w - ellipsisWidth) / 2;
|
||||||
|
@ -562,7 +562,7 @@ void FrameBuffer::drawString(const GUI::Font& font, const string& s,
|
||||||
|
|
||||||
for(i = 0; i < s.size(); ++i)
|
for(i = 0; i < s.size(); ++i)
|
||||||
{
|
{
|
||||||
int charWidth = font.getCharWidth(s[i]);
|
int charWidth = font->getCharWidth(s[i]);
|
||||||
if(w2 + charWidth > halfWidth)
|
if(w2 + charWidth > halfWidth)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -582,13 +582,13 @@ void FrameBuffer::drawString(const GUI::Font& font, const string& s,
|
||||||
// (width + ellipsisWidth - w)
|
// (width + ellipsisWidth - w)
|
||||||
int skip = width + ellipsisWidth - w;
|
int skip = width + ellipsisWidth - w;
|
||||||
for(; i < s.size() && skip > 0; ++i)
|
for(; i < s.size() && skip > 0; ++i)
|
||||||
skip -= font.getCharWidth(s[i]);
|
skip -= font->getCharWidth(s[i]);
|
||||||
|
|
||||||
// Append the remaining chars, if any
|
// Append the remaining chars, if any
|
||||||
for(; i < s.size(); ++i)
|
for(; i < s.size(); ++i)
|
||||||
str += s[i];
|
str += s[i];
|
||||||
|
|
||||||
width = font.getStringWidth(str);
|
width = font->getStringWidth(str);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
str = s;
|
str = s;
|
||||||
|
@ -601,7 +601,7 @@ void FrameBuffer::drawString(const GUI::Font& font, const string& s,
|
||||||
x += deltax;
|
x += deltax;
|
||||||
for(i = 0; i < str.size(); ++i)
|
for(i = 0; i < str.size(); ++i)
|
||||||
{
|
{
|
||||||
w = font.getCharWidth(str[i]);
|
w = font->getCharWidth(str[i]);
|
||||||
if(x+w > rightX)
|
if(x+w > rightX)
|
||||||
break;
|
break;
|
||||||
if(x >= leftX)
|
if(x >= leftX)
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: FrameBuffer.hxx,v 1.38 2005-06-08 18:45:08 stephena Exp $
|
// $Id: FrameBuffer.hxx,v 1.39 2005-06-14 01:11:48 stephena Exp $
|
||||||
//============================================================================
|
//============================================================================
|
||||||
|
|
||||||
#ifndef FRAMEBUFFER_HXX
|
#ifndef FRAMEBUFFER_HXX
|
||||||
|
@ -46,7 +46,7 @@ enum TextAlignment {
|
||||||
All GUI elements (ala ScummVM) are drawn here as well.
|
All GUI elements (ala ScummVM) are drawn here as well.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: FrameBuffer.hxx,v 1.38 2005-06-08 18:45:08 stephena Exp $
|
@version $Id: FrameBuffer.hxx,v 1.39 2005-06-14 01:11:48 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class FrameBuffer
|
class FrameBuffer
|
||||||
{
|
{
|
||||||
|
@ -245,7 +245,7 @@ class FrameBuffer
|
||||||
@param deltax
|
@param deltax
|
||||||
@param useEllipsis Whether to use '...' when the string is too long
|
@param useEllipsis Whether to use '...' when the string is too long
|
||||||
*/
|
*/
|
||||||
void drawString(const GUI::Font& font, const string& str, int x, int y, int w,
|
void drawString(const GUI::Font* font, const string& str, int x, int y, int w,
|
||||||
OverlayColor color, TextAlignment align = kTextAlignLeft,
|
OverlayColor color, TextAlignment align = kTextAlignLeft,
|
||||||
int deltax = 0, bool useEllipsis = true);
|
int deltax = 0, bool useEllipsis = true);
|
||||||
|
|
||||||
|
@ -363,7 +363,7 @@ class FrameBuffer
|
||||||
@param y The y coordinate
|
@param y The y coordinate
|
||||||
@param color The color of the character
|
@param color The color of the character
|
||||||
*/
|
*/
|
||||||
virtual void drawChar(const GUI::Font& font, uInt8 c, uInt32 x, uInt32 y,
|
virtual void drawChar(const GUI::Font* font, uInt8 c, uInt32 x, uInt32 y,
|
||||||
OverlayColor color) = 0;
|
OverlayColor color) = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CheatWidget.cxx,v 1.1 2005-06-12 20:12:10 stephena Exp $
|
// $Id: CheatWidget.cxx,v 1.2 2005-06-14 01:11:48 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -26,14 +26,48 @@
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
|
|
||||||
#include "ListWidget.hxx"
|
#include "ListWidget.hxx"
|
||||||
|
#include "EditTextWidget.hxx"
|
||||||
|
|
||||||
#include "CheatWidget.hxx"
|
#include "CheatWidget.hxx"
|
||||||
|
|
||||||
|
enum {
|
||||||
|
kSearchCmd,
|
||||||
|
kCmpCmd,
|
||||||
|
kRestartCmd
|
||||||
|
};
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
CheatWidget::CheatWidget(GuiObject* boss, int x, int y, int w, int h)
|
CheatWidget::CheatWidget(GuiObject* boss, int x, int y, int w, int h)
|
||||||
: Widget(boss, x, y, w, h),
|
: Widget(boss, x, y, w, h),
|
||||||
CommandSender(boss)
|
CommandSender(boss)
|
||||||
{
|
{
|
||||||
|
int xpos = 10;
|
||||||
|
const int bwidth = 50, space = 20;
|
||||||
|
|
||||||
|
// Add the edit textbox, set to accept decimal values
|
||||||
|
myEditBox = new EditTextWidget(boss, 10, 10, 80, 16, "");
|
||||||
|
myEditBox->setFont(_boss->instance()->consoleFont());
|
||||||
|
myEditBox->setEditString("HELLO!");
|
||||||
|
// myEditBox->setTarget(this);
|
||||||
|
|
||||||
|
// myResult = new StaticTextWidget();
|
||||||
|
|
||||||
|
// Add the three search-related buttons
|
||||||
|
mySearchButton = new ButtonWidget(boss, xpos, _h - space, bwidth, 16,
|
||||||
|
"Search", kSearchCmd, 0);
|
||||||
|
mySearchButton->setTarget(this);
|
||||||
|
xpos += 8 + bwidth;
|
||||||
|
|
||||||
|
myCompareButton = new ButtonWidget(boss, xpos, _h - space, bwidth, 16,
|
||||||
|
"Compare", kCmpCmd, 0);
|
||||||
|
myCompareButton->setTarget(this);
|
||||||
|
xpos += 8 + bwidth;
|
||||||
|
|
||||||
|
myRestartButton = new ButtonWidget(boss, xpos, _h - space, bwidth, 16,
|
||||||
|
"Restart", kRestartCmd, 0);
|
||||||
|
myRestartButton->setTarget(this);
|
||||||
|
xpos += 8 + bwidth;
|
||||||
|
|
||||||
ListWidget* myList = new ListWidget(boss, 10, 24, 100, h - 50);
|
ListWidget* myList = new ListWidget(boss, 10, 24, 100, h - 50);
|
||||||
myList->setTarget(this);
|
myList->setTarget(this);
|
||||||
myList->setEditable(false);
|
myList->setEditable(false);
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: CheatWidget.hxx,v 1.1 2005-06-12 20:12:10 stephena Exp $
|
// $Id: CheatWidget.hxx,v 1.2 2005-06-14 01:11:48 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -23,6 +23,9 @@
|
||||||
#define CHEAT_WIDGET_HXX
|
#define CHEAT_WIDGET_HXX
|
||||||
|
|
||||||
class GuiObject;
|
class GuiObject;
|
||||||
|
class ButtonWidget;
|
||||||
|
class StaticTextWidget;
|
||||||
|
class EditTextWidget;
|
||||||
|
|
||||||
#include "Widget.hxx"
|
#include "Widget.hxx"
|
||||||
#include "Command.hxx"
|
#include "Command.hxx"
|
||||||
|
@ -38,7 +41,14 @@ class CheatWidget : public Widget, public CommandSender
|
||||||
void handleCommand(CommandSender* sender, int cmd, int data);
|
void handleCommand(CommandSender* sender, int cmd, int data);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Widget* myActiveWidget;
|
Widget* myActiveWidget;
|
||||||
|
|
||||||
|
EditTextWidget* myEditBox;
|
||||||
|
StaticTextWidget* myResult;
|
||||||
|
|
||||||
|
ButtonWidget* mySearchButton;
|
||||||
|
ButtonWidget* myCompareButton;
|
||||||
|
ButtonWidget* myRestartButton;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -0,0 +1,121 @@
|
||||||
|
//============================================================================
|
||||||
|
//
|
||||||
|
// SSSS tt lll lll
|
||||||
|
// SS SS tt ll ll
|
||||||
|
// SS tttttt eeee ll ll aaaa
|
||||||
|
// SSSS tt ee ee ll ll aa
|
||||||
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
||||||
|
// SS SS tt ee ll ll aa aa
|
||||||
|
// SSSS ttt eeeee llll llll aaaaa
|
||||||
|
//
|
||||||
|
// Copyright (c) 1995-2005 by Bradford W. Mott
|
||||||
|
//
|
||||||
|
// See the file "license" for information on usage and redistribution of
|
||||||
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
//
|
||||||
|
// $Id: EditTextWidget.cxx,v 1.1 2005-06-14 01:11:48 stephena Exp $
|
||||||
|
//
|
||||||
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
//============================================================================
|
||||||
|
|
||||||
|
#include "OSystem.hxx"
|
||||||
|
#include "FrameBuffer.hxx"
|
||||||
|
#include "Dialog.hxx"
|
||||||
|
#include "EditTextWidget.hxx"
|
||||||
|
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
EditTextWidget::EditTextWidget(GuiObject* boss, int x, int y, int w, int h,
|
||||||
|
const string& text)
|
||||||
|
: EditableWidget(boss, x, y - 1, w, h + 2)
|
||||||
|
{
|
||||||
|
_flags = WIDGET_ENABLED | WIDGET_CLEARBG | WIDGET_RETAIN_FOCUS |
|
||||||
|
WIDGET_TAB_NAVIGATE;
|
||||||
|
_type = kEditTextWidget;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditTextWidget::setEditString(const string& str)
|
||||||
|
{
|
||||||
|
EditableWidget::setEditString(str);
|
||||||
|
_backupString = str;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditTextWidget::handleMouseDown(int x, int y, int button, int clickCount)
|
||||||
|
{
|
||||||
|
// First remove caret
|
||||||
|
if (_caretVisible)
|
||||||
|
drawCaret(true);
|
||||||
|
|
||||||
|
x += _editScrollOffset;
|
||||||
|
|
||||||
|
int width = 0;
|
||||||
|
unsigned int i;
|
||||||
|
|
||||||
|
for (i = 0; i < _editString.size(); ++i)
|
||||||
|
{
|
||||||
|
width += _font->getCharWidth(_editString[i]);
|
||||||
|
if (width >= x)
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (setCaretPos(i))
|
||||||
|
draw();
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditTextWidget::drawWidget(bool hilite)
|
||||||
|
{
|
||||||
|
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
||||||
|
|
||||||
|
// Draw a thin frame around us.
|
||||||
|
fb.hLine(_x, _y, _x + _w - 1, kColor);
|
||||||
|
fb.hLine(_x, _y + _h - 1, _x +_w - 1, kShadowColor);
|
||||||
|
fb.vLine(_x, _y, _y + _h - 1, kColor);
|
||||||
|
fb.vLine(_x + _w - 1, _y, _y + _h - 1, kShadowColor);
|
||||||
|
|
||||||
|
// Draw the text
|
||||||
|
adjustOffset();
|
||||||
|
fb.drawString(_font, _editString, _x + 2, _y + 2, getEditRect().width(),
|
||||||
|
kTextColor, kTextAlignLeft, -_editScrollOffset, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
GUI::Rect EditTextWidget::getEditRect() const
|
||||||
|
{
|
||||||
|
GUI::Rect r(2, 1, _w - 2, _h);
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditTextWidget::receivedFocusWidget()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditTextWidget::lostFocusWidget()
|
||||||
|
{
|
||||||
|
// If we loose focus, 'commit' the user changes
|
||||||
|
_backupString = _editString;
|
||||||
|
drawCaret(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditTextWidget::startEditMode()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditTextWidget::endEditMode()
|
||||||
|
{
|
||||||
|
releaseFocus();
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditTextWidget::abortEditMode()
|
||||||
|
{
|
||||||
|
setEditString(_backupString);
|
||||||
|
releaseFocus();
|
||||||
|
}
|
|
@ -0,0 +1,56 @@
|
||||||
|
//============================================================================
|
||||||
|
//
|
||||||
|
// SSSS tt lll lll
|
||||||
|
// SS SS tt ll ll
|
||||||
|
// SS tttttt eeee ll ll aaaa
|
||||||
|
// SSSS tt ee ee ll ll aa
|
||||||
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
||||||
|
// SS SS tt ee ll ll aa aa
|
||||||
|
// SSSS ttt eeeee llll llll aaaaa
|
||||||
|
//
|
||||||
|
// Copyright (c) 1995-2005 by Bradford W. Mott
|
||||||
|
//
|
||||||
|
// See the file "license" for information on usage and redistribution of
|
||||||
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
//
|
||||||
|
// $Id: EditTextWidget.hxx,v 1.1 2005-06-14 01:11:48 stephena Exp $
|
||||||
|
//
|
||||||
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
//============================================================================
|
||||||
|
|
||||||
|
#ifndef EDIT_TEXT_WIDGET_HXX
|
||||||
|
#define EDIT_TEXT_WIDGET_HXX
|
||||||
|
|
||||||
|
#include "Rect.hxx"
|
||||||
|
#include "EditableWidget.hxx"
|
||||||
|
|
||||||
|
|
||||||
|
/* EditTextWidget */
|
||||||
|
class EditTextWidget : public EditableWidget
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
EditTextWidget(GuiObject* boss, int x, int y, int w, int h, const string& text);
|
||||||
|
|
||||||
|
void setEditString(const string& str);
|
||||||
|
|
||||||
|
virtual void handleMouseDown(int x, int y, int button, int clickCount);
|
||||||
|
|
||||||
|
virtual bool wantsFocus() { return true; }
|
||||||
|
|
||||||
|
protected:
|
||||||
|
void drawWidget(bool hilite);
|
||||||
|
void receivedFocusWidget();
|
||||||
|
void lostFocusWidget();
|
||||||
|
|
||||||
|
void startEditMode();
|
||||||
|
void endEditMode();
|
||||||
|
void abortEditMode();
|
||||||
|
|
||||||
|
GUI::Rect getEditRect() const;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
string _backupString;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
|
@ -0,0 +1,232 @@
|
||||||
|
//============================================================================
|
||||||
|
//
|
||||||
|
// SSSS tt lll lll
|
||||||
|
// SS SS tt ll ll
|
||||||
|
// SS tttttt eeee ll ll aaaa
|
||||||
|
// SSSS tt ee ee ll ll aa
|
||||||
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
||||||
|
// SS SS tt ee ll ll aa aa
|
||||||
|
// SSSS ttt eeeee llll llll aaaaa
|
||||||
|
//
|
||||||
|
// Copyright (c) 1995-2005 by Bradford W. Mott
|
||||||
|
//
|
||||||
|
// See the file "license" for information on usage and redistribution of
|
||||||
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
//
|
||||||
|
// $Id: EditableWidget.cxx,v 1.1 2005-06-14 01:11:48 stephena Exp $
|
||||||
|
//
|
||||||
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
//============================================================================
|
||||||
|
|
||||||
|
#include "EditableWidget.hxx"
|
||||||
|
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
EditableWidget::EditableWidget(GuiObject* boss, int x, int y, int w, int h)
|
||||||
|
: Widget(boss, x, y, w, h)
|
||||||
|
{
|
||||||
|
_caretVisible = false;
|
||||||
|
_caretTime = 0;
|
||||||
|
_caretPos = 0; // FIXME
|
||||||
|
|
||||||
|
_caretInverse = false;
|
||||||
|
|
||||||
|
_editScrollOffset = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
EditableWidget::~EditableWidget()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditableWidget::setEditString(const string& str)
|
||||||
|
{
|
||||||
|
// TODO: We probably should filter the input string here,
|
||||||
|
// e.g. using tryInsertChar.
|
||||||
|
_editString = str;
|
||||||
|
_caretPos = _editString.size();
|
||||||
|
|
||||||
|
_editScrollOffset = (_font->getStringWidth(_editString) - (getEditRect().width()));
|
||||||
|
if (_editScrollOffset < 0)
|
||||||
|
_editScrollOffset = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
bool EditableWidget::tryInsertChar(char c, int pos)
|
||||||
|
{
|
||||||
|
if (isprint(c))
|
||||||
|
{
|
||||||
|
_editString.insert(pos, c, 1);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
void EditableWidget::handleTickle() {
|
||||||
|
uint32 time = getMillis();
|
||||||
|
if (_caretTime < time) {
|
||||||
|
_caretTime = time + kCaretBlinkTime;
|
||||||
|
drawCaret(_caretVisible);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
bool EditableWidget::handleKeyDown(int ascii, int keycode, int modifiers)
|
||||||
|
{
|
||||||
|
bool handled = true;
|
||||||
|
bool dirty = false;
|
||||||
|
|
||||||
|
// First remove caret
|
||||||
|
if (_caretVisible)
|
||||||
|
drawCaret(true);
|
||||||
|
|
||||||
|
switch (keycode)
|
||||||
|
{
|
||||||
|
case '\n': // enter/return
|
||||||
|
case '\r':
|
||||||
|
// confirm edit and exit editmode
|
||||||
|
endEditMode();
|
||||||
|
dirty = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 27: // escape
|
||||||
|
abortEditMode();
|
||||||
|
dirty = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 8: // backspace
|
||||||
|
if (_caretPos > 0)
|
||||||
|
{
|
||||||
|
_caretPos--;
|
||||||
|
_editString.erase(_caretPos);
|
||||||
|
dirty = true;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 127: // delete
|
||||||
|
_editString.erase(_caretPos);
|
||||||
|
dirty = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 256 + 20: // left arrow
|
||||||
|
if (_caretPos > 0)
|
||||||
|
dirty = setCaretPos(_caretPos - 1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 256 + 19: // right arrow
|
||||||
|
if (_caretPos < (int)_editString.size())
|
||||||
|
dirty = setCaretPos(_caretPos + 1);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 256 + 22: // home
|
||||||
|
dirty = setCaretPos(0);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 256 + 23: // end
|
||||||
|
dirty = setCaretPos(_editString.size());
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if (tryInsertChar((char)ascii, _caretPos))
|
||||||
|
{
|
||||||
|
_caretPos++;
|
||||||
|
dirty = true;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
handled = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (dirty)
|
||||||
|
draw();
|
||||||
|
|
||||||
|
return handled;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
int EditableWidget::getCaretOffset() const
|
||||||
|
{
|
||||||
|
int caretpos = 0;
|
||||||
|
for (int i = 0; i < _caretPos; i++)
|
||||||
|
caretpos += _font->getCharWidth(_editString[i]);
|
||||||
|
|
||||||
|
caretpos -= _editScrollOffset;
|
||||||
|
|
||||||
|
return caretpos;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
void EditableWidget::drawCaret(bool erase)
|
||||||
|
{
|
||||||
|
// Only draw if item is visible
|
||||||
|
if (!isVisible() || !_boss->isVisible())
|
||||||
|
return;
|
||||||
|
|
||||||
|
GUI::Rect editRect = getEditRect();
|
||||||
|
|
||||||
|
OverlayColor color = (erase ^ _caretInverse) ? kBGColor : kTextColorHi;
|
||||||
|
int x = editRect.left;
|
||||||
|
int y = editRect.top + 1;
|
||||||
|
|
||||||
|
x += getCaretOffset();
|
||||||
|
|
||||||
|
if (y < 0 || y + editRect.height() - 2 >= _h)
|
||||||
|
return;
|
||||||
|
|
||||||
|
x += getAbsX();
|
||||||
|
y += getAbsY();
|
||||||
|
|
||||||
|
FrameBuffer& fb = _boss->instance()->frameBuffer();
|
||||||
|
fb.vLine(x, y, y + editRect.height() - 2, color);
|
||||||
|
fb.refresh();//FIXMEfb.addDirtyRect(x, y, 2, editRect.height() - 2);
|
||||||
|
|
||||||
|
_caretVisible = !erase;
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
bool EditableWidget::setCaretPos(int newPos)
|
||||||
|
{
|
||||||
|
assert(newPos >= 0 && newPos <= (int)_editString.size());
|
||||||
|
_caretPos = newPos;
|
||||||
|
|
||||||
|
return adjustOffset();
|
||||||
|
}
|
||||||
|
|
||||||
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
bool EditableWidget::adjustOffset()
|
||||||
|
{
|
||||||
|
// check if the caret is still within the textbox; if it isn't,
|
||||||
|
// adjust _editScrollOffset
|
||||||
|
|
||||||
|
int caretpos = getCaretOffset();
|
||||||
|
const int editWidth = getEditRect().width();
|
||||||
|
|
||||||
|
if (caretpos < 0)
|
||||||
|
{
|
||||||
|
// scroll left
|
||||||
|
_editScrollOffset += caretpos;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else if (caretpos >= editWidth)
|
||||||
|
{
|
||||||
|
// scroll right
|
||||||
|
_editScrollOffset -= (editWidth - caretpos);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else if (_editScrollOffset > 0)
|
||||||
|
{
|
||||||
|
const int strWidth = _font->getStringWidth(_editString);
|
||||||
|
if (strWidth - _editScrollOffset < editWidth)
|
||||||
|
{
|
||||||
|
// scroll right
|
||||||
|
_editScrollOffset = (strWidth - editWidth);
|
||||||
|
if (_editScrollOffset < 0)
|
||||||
|
_editScrollOffset = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
|
@ -0,0 +1,68 @@
|
||||||
|
//============================================================================
|
||||||
|
//
|
||||||
|
// SSSS tt lll lll
|
||||||
|
// SS SS tt ll ll
|
||||||
|
// SS tttttt eeee ll ll aaaa
|
||||||
|
// SSSS tt ee ee ll ll aa
|
||||||
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
||||||
|
// SS SS tt ee ll ll aa aa
|
||||||
|
// SSSS ttt eeeee llll llll aaaaa
|
||||||
|
//
|
||||||
|
// Copyright (c) 1995-2005 by Bradford W. Mott
|
||||||
|
//
|
||||||
|
// See the file "license" for information on usage and redistribution of
|
||||||
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
//
|
||||||
|
// $Id: EditableWidget.hxx,v 1.1 2005-06-14 01:11:48 stephena Exp $
|
||||||
|
//
|
||||||
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
//============================================================================
|
||||||
|
|
||||||
|
#ifndef EDITABLE_WIDGET_HXX
|
||||||
|
#define EDITABLE_WIDGET_HXX
|
||||||
|
|
||||||
|
#include "Widget.hxx"
|
||||||
|
#include "Rect.hxx"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base class for widgets which need to edit text, like ListWidget and
|
||||||
|
* EditTextWidget.
|
||||||
|
*/
|
||||||
|
class EditableWidget : public Widget
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
EditableWidget(GuiObject *boss, int x, int y, int w, int h);
|
||||||
|
virtual ~EditableWidget();
|
||||||
|
|
||||||
|
virtual void setEditString(const string& str);
|
||||||
|
virtual const string& getEditString() const { return _editString; }
|
||||||
|
|
||||||
|
virtual bool handleKeyDown(int ascii, int keycode, int modifiers);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual void startEditMode() = 0;
|
||||||
|
virtual void endEditMode() = 0;
|
||||||
|
virtual void abortEditMode() = 0;
|
||||||
|
|
||||||
|
virtual GUI::Rect getEditRect() const = 0;
|
||||||
|
virtual int getCaretOffset() const;
|
||||||
|
void drawCaret(bool erase);
|
||||||
|
bool setCaretPos(int newPos);
|
||||||
|
bool adjustOffset();
|
||||||
|
|
||||||
|
virtual bool tryInsertChar(char c, int pos);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
string _editString;
|
||||||
|
|
||||||
|
bool _caretVisible;
|
||||||
|
int _caretTime;
|
||||||
|
int _caretPos;
|
||||||
|
|
||||||
|
bool _caretInverse;
|
||||||
|
|
||||||
|
int _editScrollOffset;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: ListWidget.cxx,v 1.14 2005-06-10 17:46:06 stephena Exp $
|
// $Id: ListWidget.cxx,v 1.15 2005-06-14 01:11:48 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -417,10 +417,10 @@ int ListWidget::getCaretPos() const
|
||||||
{
|
{
|
||||||
char temp[10];
|
char temp[10];
|
||||||
sprintf(temp, "%2d. ", (_selectedItem + _numberingMode));
|
sprintf(temp, "%2d. ", (_selectedItem + _numberingMode));
|
||||||
caretpos += _font.getStringWidth(temp);
|
caretpos += _font->getStringWidth(temp);
|
||||||
}
|
}
|
||||||
|
|
||||||
caretpos += _font.getStringWidth(_list[_selectedItem]);
|
caretpos += _font->getStringWidth(_list[_selectedItem]);
|
||||||
|
|
||||||
return caretpos;
|
return caretpos;
|
||||||
}
|
}
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: PopUpWidget.cxx,v 1.10 2005-06-08 18:45:09 stephena Exp $
|
// $Id: PopUpWidget.cxx,v 1.11 2005-06-14 01:11:48 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -280,7 +280,7 @@ PopUpWidget::PopUpWidget(GuiObject* boss, int x, int y, int w, int h,
|
||||||
_selectedItem = -1;
|
_selectedItem = -1;
|
||||||
|
|
||||||
if(!_label.empty() && _labelWidth == 0)
|
if(!_label.empty() && _labelWidth == 0)
|
||||||
_labelWidth = _font.getStringWidth(_label);
|
_labelWidth = _font->getStringWidth(_label);
|
||||||
|
|
||||||
myPopUpDialog = new PopUpDialog(this, x + getAbsX(), y + getAbsY());
|
myPopUpDialog = new PopUpDialog(this, x + getAbsX(), y + getAbsY());
|
||||||
}
|
}
|
||||||
|
@ -372,7 +372,7 @@ void PopUpWidget::drawWidget(bool hilite)
|
||||||
// Draw the selected entry, if any
|
// Draw the selected entry, if any
|
||||||
if(_selectedItem >= 0)
|
if(_selectedItem >= 0)
|
||||||
{
|
{
|
||||||
TextAlignment align = (_font.getStringWidth(_entries[_selectedItem].name) > w-6) ?
|
TextAlignment align = (_font->getStringWidth(_entries[_selectedItem].name) > w-6) ?
|
||||||
kTextAlignRight : kTextAlignLeft;
|
kTextAlignRight : kTextAlignLeft;
|
||||||
fb.drawString(_font, _entries[_selectedItem].name, x+2, _y+3, w-6,
|
fb.drawString(_font, _entries[_selectedItem].name, x+2, _y+3, w-6,
|
||||||
!isEnabled() ? kColor : kTextColor, align);
|
!isEnabled() ? kColor : kTextColor, align);
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: PromptWidget.cxx,v 1.2 2005-06-13 02:47:44 urchlay Exp $
|
// $Id: PromptWidget.cxx,v 1.3 2005-06-14 01:11:48 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -111,7 +111,7 @@ void PromptWidget::drawWidget(bool hilite)
|
||||||
#else
|
#else
|
||||||
char c = buffer((start + line) * _lineWidth + column);
|
char c = buffer((start + line) * _lineWidth + column);
|
||||||
#endif
|
#endif
|
||||||
fb.drawChar(instance()->consoleFont(), c, x, y, kTextColor);
|
fb.drawChar(&instance()->consoleFont(), c, x, y, kTextColor);
|
||||||
x += _kConsoleCharWidth;
|
x += _kConsoleCharWidth;
|
||||||
}
|
}
|
||||||
y += _kConsoleLineHeight;
|
y += _kConsoleLineHeight;
|
||||||
|
@ -637,7 +637,7 @@ void PromptWidget::drawCaret()
|
||||||
|
|
||||||
char c = buffer(_currentPos);
|
char c = buffer(_currentPos);
|
||||||
fb.fillRect(x, y, _kConsoleCharWidth, _kConsoleLineHeight, kTextColor);
|
fb.fillRect(x, y, _kConsoleCharWidth, _kConsoleLineHeight, kTextColor);
|
||||||
fb.drawChar(_boss->instance()->consoleFont(), c, x, y + 2, kBGColor);
|
fb.drawChar(&_boss->instance()->consoleFont(), c, x, y + 2, kBGColor);
|
||||||
}
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
|
@ -0,0 +1,178 @@
|
||||||
|
//============================================================================
|
||||||
|
//
|
||||||
|
// SSSS tt lll lll
|
||||||
|
// SS SS tt ll ll
|
||||||
|
// SS tttttt eeee ll ll aaaa
|
||||||
|
// SSSS tt ee ee ll ll aa
|
||||||
|
// SS tt eeeeee ll ll aaaaa -- "An Atari 2600 VCS Emulator"
|
||||||
|
// SS SS tt ee ll ll aa aa
|
||||||
|
// SSSS ttt eeeee llll llll aaaaa
|
||||||
|
//
|
||||||
|
// Copyright (c) 1995-2005 by Bradford W. Mott
|
||||||
|
//
|
||||||
|
// See the file "license" for information on usage and redistribution of
|
||||||
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
|
//
|
||||||
|
// $Id: Rect.hxx,v 1.1 2005-06-14 01:11:48 stephena Exp $
|
||||||
|
//
|
||||||
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
//============================================================================
|
||||||
|
|
||||||
|
#ifndef RECT_HXX
|
||||||
|
#define RECT_HXX
|
||||||
|
|
||||||
|
#include "GuiUtils.hxx"
|
||||||
|
|
||||||
|
namespace GUI {
|
||||||
|
|
||||||
|
/*! @brief simple class for handling both 2D position and size
|
||||||
|
|
||||||
|
This small class is an helper for position and size values.
|
||||||
|
*/
|
||||||
|
struct Point
|
||||||
|
{
|
||||||
|
int x; //!< The horizontal part of the point
|
||||||
|
int y; //!< The vertical part of the point
|
||||||
|
|
||||||
|
Point() : x(0), y(0) {};
|
||||||
|
Point(const Point & p) : x(p.x), y(p.y) {};
|
||||||
|
explicit Point(int x1, int y1) : x(x1), y(y1) {};
|
||||||
|
Point & operator=(const Point & p) { x = p.x; y = p.y; return *this; };
|
||||||
|
bool operator==(const Point & p) const { return x == p.x && y == p.y; };
|
||||||
|
bool operator!=(const Point & p) const { return x != p.x || y != p.y; };
|
||||||
|
};
|
||||||
|
|
||||||
|
/*! @brief simple class for handling a rectangular zone.
|
||||||
|
|
||||||
|
This small class is an helper for rectangles.
|
||||||
|
Note: This implementation is built around the assumption that (top,left) is
|
||||||
|
part of the rectangle, but (bottom,right) is not! This is reflected in
|
||||||
|
various methods, including contains(), intersects() and others.
|
||||||
|
|
||||||
|
Another very wide spread approach to rectangle classes treats (bottom,right)
|
||||||
|
also as a part of the rectangle.
|
||||||
|
|
||||||
|
Coneptually, both are sound, but the approach we use saves many intermediate
|
||||||
|
computations (like computing the height in our case is done by doing this:
|
||||||
|
height = bottom - top;
|
||||||
|
while in the alternate system, it would be
|
||||||
|
height = bottom - top + 1;
|
||||||
|
|
||||||
|
When writing code using our Rect class, always keep this principle in mind!
|
||||||
|
*/
|
||||||
|
struct Rect
|
||||||
|
{
|
||||||
|
int top, left; //!< The point at the top left of the rectangle (part of the rect).
|
||||||
|
int bottom, right; //!< The point at the bottom right of the rectangle (not part of the rect).
|
||||||
|
|
||||||
|
Rect() : top(0), left(0), bottom(0), right(0) {}
|
||||||
|
Rect(int w, int h) : top(0), left(0), bottom(h), right(w) {}
|
||||||
|
Rect(int x1, int y1, int x2, int y2) : top(y1), left(x1), bottom(y2), right(x2)
|
||||||
|
{
|
||||||
|
assert(isValidRect());
|
||||||
|
}
|
||||||
|
int width() const { return right - left; }
|
||||||
|
int height() const { return bottom - top; }
|
||||||
|
|
||||||
|
void setWidth(int aWidth) {
|
||||||
|
right = left + aWidth;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setHeight(int aHeight) {
|
||||||
|
bottom = top + aHeight;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! @brief check if given position is inside this rectangle
|
||||||
|
|
||||||
|
@param x the horizontal position to check
|
||||||
|
@param y the vertical position to check
|
||||||
|
|
||||||
|
@return true if the given position is inside this rectangle, false otherwise
|
||||||
|
*/
|
||||||
|
bool contains(int x, int y) const {
|
||||||
|
return (left <= x) && (x < right) && (top <= y) && (y < bottom);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! @brief check if given point is inside this rectangle
|
||||||
|
|
||||||
|
@param p the point to check
|
||||||
|
|
||||||
|
@return true if the given point is inside this rectangle, false otherwise
|
||||||
|
*/
|
||||||
|
bool contains(const Point & p) const {
|
||||||
|
return contains(p.x, p.y);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! @brief check if given rectangle intersects with this rectangle
|
||||||
|
|
||||||
|
@param r the rectangle to check
|
||||||
|
|
||||||
|
@return true if the given rectangle is inside the rectangle, false otherwise
|
||||||
|
*/
|
||||||
|
bool intersects(const Rect & r) const {
|
||||||
|
return (left < r.right) && (r.left < right) && (top < r.bottom) && (r.top < bottom);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! @brief extend this rectangle so that it contains r
|
||||||
|
|
||||||
|
@param r the rectangle to extend by
|
||||||
|
*/
|
||||||
|
void extend(const Rect & r) {
|
||||||
|
left = MIN(left, r.left);
|
||||||
|
right = MAX(right, r.right);
|
||||||
|
top = MIN(top, r.top);
|
||||||
|
bottom = MAX(bottom, r.bottom);
|
||||||
|
}
|
||||||
|
|
||||||
|
/*! @brief extend this rectangle in all four directions by the given number of pixels
|
||||||
|
|
||||||
|
@param offset the size to grow by
|
||||||
|
*/
|
||||||
|
void grow(int offset) {
|
||||||
|
top -= offset;
|
||||||
|
left -= offset;
|
||||||
|
bottom += offset;
|
||||||
|
right += offset;
|
||||||
|
}
|
||||||
|
|
||||||
|
void clip(const Rect & r) {
|
||||||
|
assert(isValidRect());
|
||||||
|
assert(r.isValidRect());
|
||||||
|
|
||||||
|
if (top < r.top) top = r.top;
|
||||||
|
else if (top > r.bottom) top = r.bottom;
|
||||||
|
|
||||||
|
if (left < r.left) left = r.left;
|
||||||
|
else if (left > r.right) left = r.right;
|
||||||
|
|
||||||
|
if (bottom > r.bottom) bottom = r.bottom;
|
||||||
|
else if (bottom < r.top) bottom = r.top;
|
||||||
|
|
||||||
|
if (right > r.right) right = r.right;
|
||||||
|
else if (right < r.left) right = r.left;
|
||||||
|
}
|
||||||
|
|
||||||
|
void clip(int maxw, int maxh) {
|
||||||
|
clip(Rect(0, 0, maxw, maxh));
|
||||||
|
}
|
||||||
|
|
||||||
|
bool isValidRect() const {
|
||||||
|
return (left <= right && top <= bottom);
|
||||||
|
}
|
||||||
|
|
||||||
|
void moveTo(int x, int y) {
|
||||||
|
bottom += y - top;
|
||||||
|
right += x - left;
|
||||||
|
top = y;
|
||||||
|
left = x;
|
||||||
|
}
|
||||||
|
|
||||||
|
void moveTo(const Point & p) {
|
||||||
|
moveTo(p.x, p.y);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
} // End of namespace Common
|
||||||
|
|
||||||
|
#endif
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: TabWidget.cxx,v 1.5 2005-06-12 20:12:10 stephena Exp $
|
// $Id: TabWidget.cxx,v 1.6 2005-06-14 01:11:48 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -81,7 +81,7 @@ int TabWidget::addTab(const string& title)
|
||||||
int numTabs = _tabs.size();
|
int numTabs = _tabs.size();
|
||||||
|
|
||||||
// Determine the new tab width
|
// Determine the new tab width
|
||||||
int newWidth = _font.getStringWidth(title) + 2 * kTabPadding;
|
int newWidth = _font->getStringWidth(title) + 2 * kTabPadding;
|
||||||
if (_tabWidth < newWidth)
|
if (_tabWidth < newWidth)
|
||||||
_tabWidth = newWidth;
|
_tabWidth = newWidth;
|
||||||
|
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: Widget.cxx,v 1.13 2005-06-10 17:46:07 stephena Exp $
|
// $Id: Widget.cxx,v 1.14 2005-06-14 01:11:48 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -40,7 +40,7 @@ Widget::Widget(GuiObject* boss, int x, int y, int w, int h)
|
||||||
_flags(0),
|
_flags(0),
|
||||||
_hasFocus(false),
|
_hasFocus(false),
|
||||||
_color(kTextColor),
|
_color(kTextColor),
|
||||||
_font((GUI::Font&)boss->instance()->font())
|
_font((GUI::Font*)&(boss->instance()->font()))
|
||||||
{
|
{
|
||||||
// Insert into the widget list of the boss
|
// Insert into the widget list of the boss
|
||||||
_next = _boss->_firstWidget;
|
_next = _boss->_firstWidget;
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
// See the file "license" for information on usage and redistribution of
|
// See the file "license" for information on usage and redistribution of
|
||||||
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
// this file, and for a DISCLAIMER OF ALL WARRANTIES.
|
||||||
//
|
//
|
||||||
// $Id: Widget.hxx,v 1.15 2005-06-10 17:46:07 stephena Exp $
|
// $Id: Widget.hxx,v 1.16 2005-06-14 01:11:48 stephena Exp $
|
||||||
//
|
//
|
||||||
// Based on code from ScummVM - Scumm Interpreter
|
// Based on code from ScummVM - Scumm Interpreter
|
||||||
// Copyright (C) 2002-2004 The ScummVM project
|
// Copyright (C) 2002-2004 The ScummVM project
|
||||||
|
@ -66,7 +66,7 @@ enum {
|
||||||
This is the base class for all widgets.
|
This is the base class for all widgets.
|
||||||
|
|
||||||
@author Stephen Anthony
|
@author Stephen Anthony
|
||||||
@version $Id: Widget.hxx,v 1.15 2005-06-10 17:46:07 stephena Exp $
|
@version $Id: Widget.hxx,v 1.16 2005-06-14 01:11:48 stephena Exp $
|
||||||
*/
|
*/
|
||||||
class Widget : public GuiObject
|
class Widget : public GuiObject
|
||||||
{
|
{
|
||||||
|
@ -109,8 +109,8 @@ class Widget : public GuiObject
|
||||||
bool isVisible() const { return !(_flags & WIDGET_INVISIBLE); }
|
bool isVisible() const { return !(_flags & WIDGET_INVISIBLE); }
|
||||||
|
|
||||||
void setColor(OverlayColor color) { _color = color; }
|
void setColor(OverlayColor color) { _color = color; }
|
||||||
void setFont(const GUI::Font& font) { _font = font; }
|
void setFont(const GUI::Font& font) { _font = (GUI::Font*) &font; }
|
||||||
const GUI::Font& font() { return _font; }
|
const GUI::Font* font() { return _font; }
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void drawWidget(bool hilite) {}
|
virtual void drawWidget(bool hilite) {}
|
||||||
|
@ -134,7 +134,7 @@ class Widget : public GuiObject
|
||||||
int _flags;
|
int _flags;
|
||||||
bool _hasFocus;
|
bool _hasFocus;
|
||||||
OverlayColor _color;
|
OverlayColor _color;
|
||||||
GUI::Font& _font;
|
GUI::Font* _font;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
static Widget* findWidgetInChain(Widget* start, int x, int y);
|
static Widget* findWidgetInChain(Widget* start, int x, int y);
|
||||||
|
|
Loading…
Reference in New Issue