QB64.org Forum
		Active Forums => Programs => Topic started by: 191Brian on February 19, 2021, 04:17:44 pm
		
			
			- 
				Hi All 
 
 I guess this has already been done before but as its on my to do list and I want my next game to be tile based (struggling for a theme) I decided to have a go.
 
 This version only works with tiles as individual png files the zip includes a set I made in MS Paint if you want to add tiles they need to have "tile" in the file name and be saved into the images folder.
 
 It can save and load maps using the buttons across the top of the screen.
 
 
 
 
 The next version will include the option to use tile sheets.
 
 Looking for feedback and suggested improvements or features to add.
 
 Usage
 Set map & tile size with buttons, use mouse to select a tile from the columns on the right then mouse click on the map to place the tile.
 
 Brian ...
- 
				Where's Steve? I see his farm... but where's Steve-O?
 
 Nobody cares if it's been done before, we only care that it's done better than before! Actually, we don't really care about that, either. Whatever trips your trigger, and you are willing to share, is a win around here. From the screen shot, it looks like you have a first rate project coming along. Now back to the other important stuff, where's Steve?
 
 Pete
- 
				I luv this, simplicity and specially the size that is less than Pete's string math by couple of 100 lines!
 
 @191Brian  You might separate tiles a tiny bit so you can see the edges. Man I admire the dedication, time and energy all you guys take to get all these tiles going in a game.
 
 @johnno56 should check this out!
- 
				Tile map Editor... Cool.
 
 Took it for a spin. No errors. But no tiles either... I'm going to guess the 'Shell' function could be my problem as it does note produce a list of tiles... I think this might be another Windows / Linux thing... Time for research...
- 
				Hi Johno
 
 Yes I should have mentioned it uses a shell cmd to get a list of tile file names.
 
 Lines 388 & 395 would need to be changed to the Linux command line syntax and maybe change \ to / .I sold my only Linux PC last month and haven't got around to setting up a spare laptop with some flavour of Linux yet which distro do you use?.
 
 Brian ...
- 
				Hi All
 
 See attached an updated version.  [ This attachment cannot be displayed inline in 'Print Page' view ]
 Added the ability to load tile/sprite sheets, assumes the file is in the images folder and that the individual tiles are the current tile size without any padding. I have included a sheet for a house called housered128x128.png. If you save a map which uses a tile sheet you need to load the sheet before you load the map currently.
 Added outline around the tiles.
 Added _KEYCLEAR to the user input routine to fix a bug were it jumped past the input statement.
 Added a couple more tile images.
 [ This attachment cannot be displayed inline in 'Print Page' view ]
 
 Brian ...
- 
				The reason I drag @johnno56 in, is that we worked (or he started I took over) on what he calls Sprite Editor but I would call Tile Editor, piece of cake to adapt to 32 x 32, just 2x's the demo screen shot sizes we were doing. Towards end I had it setup for N x N tiles (I think, its been awhile).  We got it working in Linux then Johnno abandoned?
 
 Anyway if you are interested, the resizable version are here if I recall:
 https://www.qb64.org/forum/index.php?topic=313.msg122756#msg122756
 
 I think his flavor is Mint chocolate chip, wait... is that my mother's favorite ice cream?
- 
				Oh. Very funny.... Chocolate is NO laughing mater... lol
 
 Very nice program....
 
 I had already cobbled together some changes so I could load the tiles... Not 100% but close enough to create and save a 'map'... This is way faster than creating a single sprite at a time with our editor,,,
 
 Just downloaded v 0.3 and will try it out after posting....
 
 J
- 
				Very true chocolate is a serious subject. 
 
 Great idea I hadn't thought of using it as a pixel editor but as it has the scale option it would work fine and you could easily generate a sheet of coloured pixels as your pallet.
 
 Have some more updates planned now i have heard about filedrop plus giving you the option to choose the folder it looks for images a couple more tweaks and refactoring some code.
 Brian...
 
 
 Oh. Very funny.... Chocolate is NO laughing mater... lol
 
 Very nice program....
 
 I had already cobbled together some changes so I could load the tiles... Not 100% but close enough to create and save a 'map'... This is way faster than creating a single sprite at a time with our editor,,,
 
 Just downloaded v 0.3 and will try it out after posting....
 
 J
 
 
- 
				Ok. Installed and edited the new version. I already had a tile sheet to test. It's an 8x8 sheet of 32x32 pixel tiles.
 
 I found 8x8 was too many. See attached. I think the problem is: When the program starts, it automatically loads the tiles in the list first in the background, then when 'load sheet' is selected it then 'adds' the sheet tiles to the already displayed list tiles. Program caters for 4 columns of 20 tiles (80). 8x8 sheet of 64 plus the already loaded 20.... (see attached)
 [ This attachment cannot be displayed inline in 'Print Page' view ]
 
 Perhaps,  the option of selecting a list of tiles OR a sheet of tiles when load is selected? Or maybe I could have used a smaller sheet... lol
 
 Changed the sheet to 7x7 tiles and that worked fine. (see attached)
 [ This attachment cannot be displayed inline in 'Print Page' view ]
 
 J
- 
				No. No. Don't use it as a pixel editor... Far too many headaches. Tile map editor is cool...
			
- 
				Its great to see it being used!
 
 The next update should address some of those issues and retain the ability mix individual tiles and sheets.
 
 Brian ...
- 
				Hi All
 
 As I have no experience of creating tile based games I would like to know what is reasonable of size map the editor should cater for?
 
 Also is it fair to assume any potential user would have a screen at least 1366x768 ?
 
 Brian ...
- 
				Interesting question. Not easily answered. Ok. My opinion.... Standard screen size for a tile-based game.... Because everyone has the potential of having different screen dimensions, going with what "fits all", is the place to start. Tile size has a say in it as well. If you are using 8x8 or 16x16 or 32x32 etc, make sure that your map can fit evenly for the screen you chose. eg: 640x480 @ 32x32 will give you 20x15 tiles. 1024x768 @ 32x32 will give you 32x24 etc.. Starting with either of these sizes would be fine.
 
 Old classic tile-based games were "fixed screen". ie: Get across the screen to exit; new screen is drawn; player back to left of screen. Then along comes screen scrolling. Suddenly the "camera" can now "follow" the player across, what seems to be, an "endless loop" of scenery. ie: Mario Brothers. My suggestion. Start with a "fixed" screen. "Scrolling" will give you a "nicer feel" to the game but as I have almost no experience with scrolling, fixed is all I can suggest.....
 
 I not sure if all this helps. If not, I 'am' sure, that the other guys would have better suggestions... lol
 
 J
- 
				My suggestion is to draw whatever size map you need, up to 65,535x65,536 pixels in size.  With a 64x64 sprite, you can have 1024x1024 squares on your grid...
 
 Then simply _PUTIMAGE the segment you want onto the display screen.
- 
				My suggestion is to draw whatever size map you need, up to 65,535x65,536 pixels in size.  With a 64x64 sprite, you can have 1024x1024 squares on your grid...
 
 Then simply _PUTIMAGE the segment you want onto the display screen.
 
 
 :) maybe later
 
 My screen is theoretically something around 768 pixel height but title bar takes 20 or so 740 is tight but doable, 700 much more comfortable.
 
 Fellippe and Terry report 1024 max width is faster and I think so too but not definitively tested, go by the word of these people who should know.
 
 This is what I am using in SB1 for a nice even max of 42 lines, giving 40 lines for printing and 41, 42 can scroll all they want.
 - CONST-  Xmax  = 1024,-  Ymax  = 672 '16*42 lines
 
- ' more declares 
- _DELAY .25 '                     have to waits a bit for screen to load 
-   
 
- 
				Hi All
 
 Latest version   [ This attachment cannot be displayed inline in 'Print Page' view ]
 
 Added some error checking when loading maps
 Nicer graphical user input and error messages
 Added prompt for images folder to load tiles/sheets from
 Increased the number tiles in the selection part to 100 tiles (5 columns of 20)
 Changed screen size to 1366x768
 Changed program name to "Tile map editor"
 Added mode button for next feature which will allow you to assign codes to tile positions for indicating solid objects etc
 
 Brian ...
 [ This attachment cannot be displayed inline in 'Print Page' view ]
- 
				Hi All
 
 [ This attachment cannot be displayed inline in 'Print Page' view ]
 Now has the map codes feature added initially only 1 hard coded code "w", to put the map code on the map click the mode button to change to mode 1 then click the w button then click on the map, to clear a code click the X button then click on the map click the mode button again to switch back to tile mode.
 When you save a map it creates an additional file containing the map codes prefixed with "MapCodes-". Load will look for a map codes file and load it automatically.
 Will probably be the last update for a few days as I will be switching to creating a game (Using the tile map editor).
 
 [ This attachment cannot be displayed inline in 'Print Page' view ]
 
 
- 
				That map looks awesome.
			
- 
				Version 0.5 required a bit of tweaking.... When I look at the sample images posted on QB64, I noticed that on my machine, only half of the tiles are displayed. Linux is a bit fiddly when it comes to filename. Some of the tile filenames include "tile" and others include "Tile". Once all the filenames included "tile" then all the 32x32 tiles were displayed.
 
 I have also tested the editor using  "Wine" and it runs perfectly as is and unedited.
 
 I have a tile-based platformer that I cobbled together, using another Basic that will not be named, which could benefit from this program. My program reads a text-based map file and converts it to tiles. It looks like the saved tile map is also text-based, but instead of converting a singe character, the tile path is saved. Interesting. This method has the advantage of eliminating squillions (number of tiles) of 'if...then's within the program but increases the size of the map file. Swings and roundabouts*
 
 Bit of a challenge but sounds like fun!
 
 As usual, very nicely done... I look forward to seeing your game... No pressure, right? lol
 
 J
 
 *British, informal. —used to say that two choices or situations are basically the same because they have an equal number of advantages and disadvantages It is a case of swings and roundabouts.
- 
				I've also got a tile map editor here (https://www.qb64.org/forum/index.php?topic=490.msg3745#msg3745 (https://www.qb64.org/forum/index.php?topic=490.msg3745#msg3745)), in case you'd like to play around and take a look at it sometime.  It allows for up to 3 different layers (which my game uses basically for walking, swimming, or flying states) of movement, and allows usage of multiple tile sets with each map.  Even if it's not exactly what you're looking for, it might be something you'd be interested in taking a look at and playing around with for a bit.  :)
			
- 
				Thank you SMcNeill will take a look.
 
 I've also got a tile map editor here (https://www.qb64.org/forum/index.php?topic=490.msg3745#msg3745 (https://www.qb64.org/forum/index.php?topic=490.msg3745#msg3745)), in case you'd like to play around and take a look at it sometime.  It allows for up to 3 different layers (which my game uses basically for walking, swimming, or flying states) of movement, and allows usage of multiple tile sets with each map.  Even if it's not exactly what you're looking for, it might be something you'd be interested in taking a look at and playing around with for a bit.  :)
 
 
- 
				Hi All
 
 Well having starting to use the map editor I realised I need more map codes so made a quick update to display 6 map code buttons, you can change the codes in the data statement in line 650 leaving the X at the end of the data statement as that is the button used to clear map codes.
 
 Brian ...
 
 [ This attachment cannot be displayed inline in 'Print Page' view ]
 [ This attachment cannot be displayed inline in 'Print Page' view ]
- 
				Hi Johno 
 
 I did briefly think about  tile cross ref to a character code but thought we already have a unique code in the file name. This way will make the code neater and save having to transfer the cross ref data. I didn't think the file size would be an issue but will see what they are like.
 Could you share the mods need to make it work in Linux.
 
 Brian...
 
 
 Version 0.5 required a bit of tweaking.... When I look at the sample images posted on QB64, I noticed that on my machine, only half of the tiles are displayed. Linux is a bit fiddly when it comes to filename. Some of the tile filenames include "tile" and others include "Tile". Once all the filenames included "tile" then all the 32x32 tiles were displayed.
 
 I have also tested the editor using  "Wine" and it runs perfectly as is and unedited.
 
 I have a tile-based platformer that I cobbled together, using another Basic that will not be named, which could benefit from this program. My program reads a text-based map file and converts it to tiles. It looks like the saved tile map is also text-based, but instead of converting a singe character, the tile path is saved. Interesting. This method has the advantage of eliminating squillions (number of tiles) of 'if...then's within the program but increases the size of the map file. Swings and roundabouts*
 
 Bit of a challenge but sounds like fun!
 
 As usual, very nicely done... I look forward to seeing your game... No pressure, right? lol
 
 J
 
 *British, informal. —used to say that two choices or situations are basically the same because they have an equal number of advantages and disadvantages It is a case of swings and roundabouts.
 
 
- 
				This is the modified 'loadtiles' that I use. As stated earlier, after changing the tile filename case, the tiles loaded ok.
 
 For some reason 'fPath' did not work. So I left is set to 'images' (just pressed Enter at program start)
 
 But here is the strange part.... When loading a sample sheet via 'loadSheet' the sheetImage = ImageLoad(".\" + imageFolder + "\" + fileName) worked just fine.
 
 SUB LoadTiles
 DIM fH AS LONG
 DIM fileName AS STRING
 DIM fPath AS STRING
 DIM tileImage AS LONG
 
 ZeroImagesArray
 fH = FREEFILE
 
 'SHELL _HIDE "cmd /c dir .\" + imageFolder + "\*tile*.png  /B > tiles.txt"
 SHELL _HIDE "ls images/*tile*.png > tiles.txt"
 
 IF _FILEEXISTS("tiles.txt") THEN
 OPEN "tiles.txt" FOR INPUT AS fH
 DO UNTIL EOF(fH)
 LINE INPUT #fH, fileName
 PRINT fileName
 'fPath = ".\" + imageFolder + "\" + fileName
 fPath = fileName
 tileImage = ImageLoad(fPath)
 AddTileImage tileImage, fileName
 LOOP
 END IF
 CLOSE #fH
 END SUB
 
 
 I think with future versions, I will run the editor using "Wine", that way I don't have to make any changes... Too much thinking involved... Stop laughing bplus...
- 
				Too much thinking involved... Stop laughing bplus... 
 The need for caffeine is disguised as the need to think ;-))
- 
				Another one of your amazing talents... Mind reading.... Cool...
			
- 
				During game dev (which is taking a lot longer than I thought it would) I had to fix a few things in the Tile Map Editor so here is an updated version with the following changes.
 [ This attachment cannot be displayed inline in 'Print Page' view ]
 Fixed Load Sheet coordinate error
 Added image files used list output - for transfer to game program - saving a map creates 3 files now map, map codes & file list
 Fixed clear map codes function not working
 Added change image folder button
 Show current map & image folder in title bar
 Debugged text input box function.
 [ This attachment cannot be displayed inline in 'Print Page' view ]
 
 Screen shot of game created using map files from the editor.
 [ This attachment cannot be displayed inline in 'Print Page' view ]
 
 
- 
				Latest version v0.8
 Usable version published on itch.io https://191brian.itch.io/qb64-tile-map-editor (https://191brian.itch.io/qb64-tile-map-editor)
 
 
 Usage
 Put your tile & tile/sprite sheet images in a folder off the main program folder or use the supplied tiles run "tile map editor.exe" choose an image folder and auto load the tiles (for auto load tiles to work the tile images must have "tile" somewhere in their name).  Use the buttons across the top of the screen to set your map and tile size load any sheets. Use your mouse to select a tile from the list on the righthand side then click on the map to paint with that tile. To set map codes for walls and exit points click the mode button to put it in to mode 1 then pick a map code and click on the map to paint the code, to clear a code click the X then click on the map. To save your map click the save button and enter a map name.
 Saving produces 3 comma delimited text files:
 1. File with line 1 holding  the map width, height and tile size followed by table of tile image file names.
 2. File with a table of map codes
 3. File which lists all the tile image files used on the map
 
 When loading an existing map ensure the correct folder for its images is selected and any sheets are load first, the program will list any missing files.