view mde/gui/widget/TextWidget.d @ 99:5de5810e3516

Implemented an editable TextContent widget; it's now possible to edit text options using the GUI. The widget supports moving the text entry-point using arrows and home/end, but there's no visual indicator or edit-point setting using the mouse.
author Diggory Hardy <diggory.hardy@gmail.com>
date Fri, 14 Nov 2008 12:44:32 +0000
parents dbf332403c6e
children 42e241e7be3e
line wrap: on
line source

/* LICENSE BLOCK
Part of mde: a Modular D game-oriented Engine
Copyright © 2007-2008 Diggory Hardy

This program is free software: you can redistribute it and/or modify it under the terms
of the GNU General Public License as published by the Free Software Foundation, either
version 2 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with this program.  If not, see <http://www.gnu.org/licenses/>. */

/** Basic text widget and supporting code for widgets containing text.
 *
 * All content widgets have one (at least for basic content widgets) Content, from
 * mde.gui.content.Items . */
module mde.gui.widget.TextWidget;

import mde.gui.widget.Widget;
import mde.gui.exception;
import mde.gui.renderer.IRenderer;
import mde.gui.content.Content;

debug {
    import tango.util.log.Log : Log, Logger;
    private Logger logger;
    static this () {
        logger = Log.getLogger ("mde.gui.widget.TextWidget");
    }
}

/** Base text widget.
 *
 * Little use currently except to ease future additions. */
class ATextWidget : AWidget
{
    /** Set the adapter first:
     * adapter = mgr.renderer.getAdapter ("string", 0xRRGGBB); */
    this (IWidgetManager mgr, widgetID id, WidgetData data) {
        adapter.getDimensions (mw, mh);
        w = mw;
        h = mh;
        super (mgr, id, data);
    }
    
    void draw () {
        super.draw();
        adapter.draw (x,y);
    }
    
protected:
    IRenderer.TextAdapter adapter;
}


/// Basic text widget
class TextLabelWidget : ATextWidget
{
    /** Constructor for a widget containing [fixed] content.
     *
     * Widget uses the initialisation data:
     * [widgetID, contentID, colour]
     * where contentID is an ID for the string ID of the contained content
     * and colour is an 8-bit-per-channel RGB colour of the form 0xRRGGBB. */
    this (IWidgetManager mgr, widgetID id, WidgetData data) {
        WDCheck (data, 2, 1);
        adapter = mgr.renderer.getAdapter (data.strings[0], data.ints[1]);
        super (mgr, id, data);
    }
}

/// Basic widget displaying a label from a content.
class ContentLabelWidget : ATextWidget
{
    this (IWidgetManager mgr, widgetID id, WidgetData data, IContent c) {
        WDCheck (data, 3, 0);
        content = c;
        if (!content) throw new ContentException ();
        index = data.ints[1];
        adapter = mgr.renderer.getAdapter (content.toString(index), data.ints[2]);
        super (mgr, id,data);
    }
    
protected:
    IContent content;
    int index;
}