+// $Id$
using System;
using System.IO;
using System.Collections;
using Gtk;
using Gdk;
-using Gnome;
using Glade;
public class Application {
[Glade.Widget]
private Gtk.Window MainWindow;
[Glade.Widget]
+ private Gtk.CheckMenuItem useNewSyntax;
+ [Glade.Widget]
private Gtk.DrawingArea DrawingArea;
[Glade.Widget]
+ //Flags CheckButtons
private Gtk.CheckButton SolidCheckButton;
[Glade.Widget]
private Gtk.CheckButton UniSolidCheckButton;
[Glade.Widget]
private Gtk.CheckButton WaterCheckButton;
[Glade.Widget]
+ private Gtk.CheckButton HurtsCheckButton;
+ [Glade.Widget]
+ private Gtk.CheckButton FireCheckButton;
+ [Glade.Widget]
+ private Gtk.CheckButton BrickCheckButton;
+ [Glade.Widget]
+ private Gtk.CheckButton CoinCheckButton;
+ [Glade.Widget]
+ private Gtk.CheckButton FullBoxCheckButton;
+ [Glade.Widget]
private Gtk.CheckButton SlopeCheckButton;
[Glade.Widget]
+ private Gtk.CheckButton GoalCheckButton;
+ [Glade.Widget]
private Gtk.CheckButton DontUseCheckButton;
[Glade.Widget]
private Gtk.CheckButton HiddenCheckButton;
[Glade.Widget]
+
private Gtk.Entry DataEntry;
[Glade.Widget]
private Gtk.Entry AnimFpsEntry;
[Glade.Widget]
private Gtk.Entry IDEntry;
[Glade.Widget]
- private Gnome.AppBar AppBar;
- [Glade.Widget]
- private Gtk.VBox MainLayout;
- [Glade.Widget]
private Gtk.TreeView TileList;
[Glade.Widget]
private Gtk.Combo TileGroupComboBox;
[Glade.Widget]
private Gtk.MenuItem AddTileGroupMenu;
+ [Glade.Widget]
+ private Gtk.Dialog RemapDialog;
+ [Glade.Widget]
+ private Gtk.SpinButton RD_spinButton;
+
private string tilesetdir;
private string tilesetfile;
private TileSet tileset;
private Gdk.Pixbuf pixbuf;
public static int Main(string[] args) {
- Program kit = new Program("tiler", "0.0.1", Modules.UI, args);
+ Gtk.Application.Init();
Application app = new Application();
if(args.Length == 1)
app.LoadTileSet(args[0]);
- kit.Run();
+ Gtk.Application.Run();
return 0;
}
Glade.XML gxml = new Glade.XML(null, "tiler.glade", null, null);
gxml.Autoconnect(this);
- if(MainWindow == null || DrawingArea == null || AppBar == null)
+ if(MainWindow == null || DrawingArea == null || RemapDialog == null)
throw new Exception("some widgets not found");
DrawingArea.AddEvents((int) Gdk.EventMask.ButtonPressMask);
DrawingArea.AddEvents((int) Gdk.EventMask.ButtonReleaseMask);
DrawingArea.AddEvents((int) Gdk.EventMask.ButtonMotionMask);
- // libglade missed interactivity property :-/
- MainLayout.Remove(AppBar);
- AppBar = new AppBar(true, true, PreferencesType.Always);
- AppBar.UserResponse += new EventHandler(OnAppBarUserResponse);
- MainLayout.PackStart(AppBar, false, false, 0);
- AppBar.Show();
-
MainWindow.Show();
}
fileChooser.AddButton(Gtk.Stock.Cancel, Gtk.ResponseType.Cancel);
fileChooser.AddButton(Gtk.Stock.Ok, Gtk.ResponseType.Ok);
fileChooser.DefaultResponse = Gtk.ResponseType.Ok;
- Gtk.FileFilter filter = new Gtk.FileFilter();
+ Gtk.FileFilter filter;
+ filter = new Gtk.FileFilter();
filter.Name = "Supertux tilesets";
filter.AddPattern("*.strf");
+ filter.AddPattern("*.stgt");
+ fileChooser.AddFilter( filter );
+ filter = new Gtk.FileFilter();
+ filter.Name = "Supertux 0.1.x tilesets";
+ filter.AddPattern("*.stgt");
+ fileChooser.AddFilter( filter );
+ filter = new Gtk.FileFilter();
+ filter.Name = "Supertux 0.3.x tilesets";
+ filter.AddPattern("*.strf");
fileChooser.AddFilter( filter );
Gtk.FileFilter all = new Gtk.FileFilter();
all.Name = "All Files";
SelectionChanged();
FillTileGroupComboBox();
FillTileList();
+
+ useNewSyntax.Active = tileset.IsNew;
+ if (tileset.IsNew)
+ Console.WriteLine("Warning: new syntax of 0.3.x files \"More tiles in one image\" isn't currently supported for WRITING");
+
}
protected void OnImportImage(object o, EventArgs e) {
tile.ID = startid + i;
ImageRegion region = new ImageRegion();
region.ImageFile = currentimage;
- region.Region = new System.Drawing.Rectangle(x*32, y*32, 32, 32);
+ region.Region = new System.Drawing.Rectangle(x*TileSet.TILE_WIDTH, y*TileSet.TILE_HEIGHT, TileSet.TILE_WIDTH, TileSet.TILE_HEIGHT);
tile.Images.Add(region);
if(Tiles[i] != null) {
Console.WriteLine(
}
try {
pixbuf = new Pixbuf(tilesetdir + "/" + file);
- if(pixbuf.Width % 32 != 0 || pixbuf.Height % 32 != 0)
+ if(pixbuf.Width % TileSet.TILE_WIDTH != 0 || pixbuf.Height % TileSet.TILE_HEIGHT != 0)
Console.WriteLine("Warning: Image Width or Height is not a multiple of 32");
} catch(Exception e) {
ShowException(e);
return;
}
currentimage = new FileInfo(file).Name;
- TilesX = pixbuf.Width / 32;
- TilesY = pixbuf.Height / 32;
+ TilesX = pixbuf.Width / TileSet.TILE_WIDTH;
+ TilesY = pixbuf.Height / TileSet.TILE_HEIGHT;
SelectionArray = new bool[TilesX * TilesY];
Tiles = new Tile[TilesX * TilesY];
continue;
ImageRegion region = (ImageRegion) tile.Images[0];
if(region.ImageFile == currentimage) {
- int px = region.Region.X / 32;
- int py = region.Region.Y / 32;
+ int px = region.Region.X / TileSet.TILE_WIDTH;
+ int py = region.Region.Y / TileSet.TILE_HEIGHT;
int i = py*TilesX+px;
if(i < 0 || i >= Tiles.Length) {
Console.WriteLine("Invalid Imageregion at tile " +
}
if(Tiles[i] != null) {
Console.WriteLine("Multiple tiles for region " +
- px*32 + " , " + py*32);
+ px*TileSet.TILE_WIDTH + " , " + py*TileSet.TILE_HEIGHT);
continue;
}
Tiles[i] = tile;
}
protected void OnSave(object o, EventArgs e) {
- if (tileset.TooNew)
- Console.WriteLine(
- "Sorry, the file you are editing is too new, there will be huge data loss if you save this.");
- else
+ if (tileset.IsNew && useNewSyntax.Active) {
+ MessageDialog dialog = new MessageDialog(MainWindow, DialogFlags.Modal | DialogFlags.DestroyWithParent, MessageType.Error, ButtonsType.Ok,
+ "Sorry, the file you are editing is too new and 0.3.x syntax is not supported yet.");
+ dialog.Run();
+ dialog.Destroy();
+ } else {
tileset.Write(tilesetfile);
+ }
}
protected void OnQuit(object o, EventArgs e) {
}
protected void OnAbout(object o, EventArgs e) {
- Console.WriteLine(
- "There is no about dialog yet...");
+// string[] authors = new string[]{
+// "<autors?>",
+// };
+
+ Gtk.AboutDialog dialog = new Gtk.AboutDialog();
+// dialog.Icon = <icon>;
+ dialog.ProgramName = "SuperTux Tiler";
+ dialog.Version = "0.0.3";
+ dialog.Comments = "A tileset editor for SuperTux 0.1.x";
+// dialog.Authors = authors;
+ dialog.Copyright = "Copyright (c) 2006 SuperTux Devel Team";
+ dialog.License =
+ "This program is free software; you can redistribute it and/or modify" + Environment.NewLine +
+ "it under the terms of the GNU General Public License as published by" + Environment.NewLine +
+ "the Free Software Foundation; either version 2 of the License, or" + Environment.NewLine +
+ "(at your option) any later version." + Environment.NewLine +
+ Environment.NewLine +
+ "This program is distributed in the hope that it will be useful," + Environment.NewLine +
+ "but WITHOUT ANY WARRANTY; without even the implied warranty of" + Environment.NewLine +
+ "MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the" + Environment.NewLine +
+ "GNU General Public License for more details." + Environment.NewLine +
+ Environment.NewLine +
+ "You should have received a copy of the GNU General Public License" + Environment.NewLine +
+ "along with this program; if not, write to the Free Software Foundation, Inc.," + Environment.NewLine +
+ "59 Temple Place, Suite 330, Boston, MA 02111-1307 USA" + Environment.NewLine;
+ dialog.Website = "http://supertux.lethargik.org/";
+ dialog.WebsiteLabel = "SuperTux on the Web";
+ dialog.Run();
+ dialog.Destroy();
}
protected void OnRemapTiles(object o, EventArgs e) {
- AppBar.SetPrompt("Start-ID:", true);
+ if(Tiles == null)
+ return;
+ RemapDialog.Show();
}
- protected void OnCreateTileGroup(object o, EventArgs e) {
+ protected void OnRemapDialogCancel(object o, EventArgs e) {
+ RemapDialog.Hide();
}
- protected void OnRenameTileGroup(object o, EventArgs e) {
- }
-
- protected void OnAppBarUserResponse(object o, EventArgs e) {
+ protected void OnRemapDialogApply(object o, EventArgs e) {
+ RemapDialog.Hide();
try {
- if(AppBar.Response == null || AppBar.Response == ""
- || Tiles == null)
- return;
// remap tiles
int id;
try {
- id = Int32.Parse(AppBar.Response);
+ id = RD_spinButton.ValueAsInt;
} catch(Exception exception) {
ShowException(exception);
return;
}
RemapTiles(id);
} finally {
- AppBar.ClearPrompt();
+ RD_spinButton.Value = 1;
}
}
+ protected void OnCreateTileGroup(object o, EventArgs e) {
+ }
+
+ protected void OnRenameTileGroup(object o, EventArgs e) {
+ }
+
protected void RemapTiles(int startID) {
if(Tiles == null)
return;
}
private void select(int x, int y) {
- int tile = y/32 * TilesX + x/32;
+ int tile = y/TileSet.TILE_HEIGHT * TilesX + x/TileSet.TILE_WIDTH;
if(tile < 0 || tile >= SelectionArray.Length)
return;
return;
foreach(Tile tile in Selection) {
if(sender == SolidCheckButton)
- tile.Solid = SolidCheckButton.Active;
+ tile.SetAttribute(Attribute.SOLID, SolidCheckButton.Active);
if(sender == UniSolidCheckButton)
- tile.UniSolid = UniSolidCheckButton.Active;
+ tile.SetAttribute(Attribute.UNISOLID, UniSolidCheckButton.Active);
if(sender == IceCheckButton)
- tile.Ice = IceCheckButton.Active;
+ tile.SetAttribute(Attribute.ICE, IceCheckButton.Active);
if(sender == WaterCheckButton)
- tile.Water = WaterCheckButton.Active;
+ tile.SetAttribute(Attribute.WATER, WaterCheckButton.Active);
+ if(sender == HurtsCheckButton)
+ tile.SetAttribute(Attribute.HURTS, HurtsCheckButton.Active);
+ if(sender == FireCheckButton)
+ tile.SetAttribute(Attribute.FIRE, FireCheckButton.Active);
+ if(sender == BrickCheckButton)
+ tile.SetAttribute(Attribute.BRICK, BrickCheckButton.Active);
+ if(sender == CoinCheckButton)
+ tile.SetAttribute(Attribute.COIN, CoinCheckButton.Active);
+ if(sender == FullBoxCheckButton)
+ tile.SetAttribute(Attribute.FULLBOX, FullBoxCheckButton.Active);
if(sender == SlopeCheckButton)
- tile.Slope = SlopeCheckButton.Active;
+ tile.SetAttribute(Attribute.SLOPE, SlopeCheckButton.Active);
+ if(sender == GoalCheckButton)
+ tile.SetAttribute(Attribute.GOAL, GoalCheckButton.Active);
if(sender == HiddenCheckButton)
tile.Hidden = HiddenCheckButton.Active;
if(sender == DontUseCheckButton)
string nextimage = "";
foreach(Tile tile in Selection) {
if(first) {
- SolidCheckButton.Active = tile.Solid;
- UniSolidCheckButton.Active = tile.UniSolid;
- IceCheckButton.Active = tile.Ice;
- WaterCheckButton.Active = tile.Water;
- SlopeCheckButton.Active = tile.Slope;
+ SolidCheckButton.Active = tile.HasAttribute(Attribute.SOLID);
+ UniSolidCheckButton.Active = tile.HasAttribute(Attribute.UNISOLID);
+ IceCheckButton.Active = tile.HasAttribute(Attribute.ICE);
+ WaterCheckButton.Active = tile.HasAttribute(Attribute.WATER);
+ HurtsCheckButton.Active = tile.HasAttribute(Attribute.HURTS);
+ FireCheckButton.Active = tile.HasAttribute(Attribute.FIRE);
+ BrickCheckButton.Active = tile.HasAttribute(Attribute.BRICK);
+ CoinCheckButton.Active = tile.HasAttribute(Attribute.COIN);
+ FullBoxCheckButton.Active = tile.HasAttribute(Attribute.FULLBOX);
+ SlopeCheckButton.Active = tile.HasAttribute(Attribute.SLOPE);
+ GoalCheckButton.Active = tile.HasAttribute(Attribute.GOAL);
HiddenCheckButton.Active = tile.Hidden;
DontUseCheckButton.Active = tile.ID == -1;
DataEntry.Text = tile.Data.ToString();