cutting irregular pieces from image for puzzle game

Creating Games? Developing something for fun?

Moderators: FourthWorld, heatherlaine, Klaus, kevinmiller, robinmiller

bn
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 4184
Joined: Sun Jan 07, 2007 9:12 pm

Re: cutting irregular pieces from image for puzzle game

Post by bn » Fri Jul 11, 2025 9:49 am

I think it is due to the fact that the folder does not exist. It is not automatically created.

Here is what worked for me on a Mac.

Code: Select all

on mouseUp
   put the number of images of this card into nImages
   put specialFolderPath("documents") & "/app data/testing/tempImages" into tTempPath
   
   
   set the itemDelimiter to slash
   put itemOffset("Documents",tTempPath) into tOffset
   
   put item 1 to tOffset of tTempPath into tRootPath
   
   repeat with i = tOffset +1 to the number of items of tTempPath
      if there is not a folder (item 1 to i of tTempPath) then
         create folder (item 1 to i of tTempPath)
         put the result into tResult
         if tResult is not empty then breakpoint
      end if
   end repeat
   
   set the itemDelimiter to comma
   
   repeat with i = 1 to 1  -- nImages ## changed for testing
      put the short name of image i into tImageFileName
      put tTempPath & "/" & the short name of image i & ".png" into tFilePath
      export image tImageFileName to file tFilePath as PNG
      put the result into tResult
   end repeat
end mouseUp
It first checks for the existence of a folder, if it not exists then it creates the folder(s) and only then exports the images to that folder.

Checking for the result after creating a folder makes sure that it worked. If successful the result is empty.

Kind regards
Bernd

rcmills
Posts: 73
Joined: Wed Nov 21, 2018 8:27 pm

Re: cutting irregular pieces from image for puzzle game

Post by rcmills » Fri Jul 11, 2025 10:05 pm

Thanks again! Even though I "thought" I had created the proper folders, going through the process of checking on them somehow fixed the problem!

bn
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 4184
Joined: Sun Jan 07, 2007 9:12 pm

Re: cutting irregular pieces from image for puzzle game

Post by bn » Wed Jul 16, 2025 8:55 pm

I made a script that arranges the Puzzle Pieces in correct order and position.
Consider it a "cheat" script or a final arrangement script since manual placement of puzzle pieces is difficult.

Code: Select all

on mouseUp
   local tMaxColNum, tMaxRowNum, tNumPieces
   local tCollect, tShortImgName, tExpectedNumPieces, tStartTL, tStartLeft, tStartTop
   local tPieceSize = 60, tPuzzleWidth, tPuzzleHeight
   local tImgColumn, tImgRow, tFudge, tTempLeft, tTempTop
   
   repeat with i = 1 to the number of images
      put the short name of image i into tShortImgName
      if tShortImgName begins with "PP" then
         put tShortImgName & return after tCollect
         put max(char 3 to -1 of item 1 of tShortImgName, tMaxColNum) into tMaxColNum
         put max(char 1 to -1 of item 2 of tShortImgName, tMaxRowNum) into tMaxRowNum
      end if
   end repeat
   delete char -1 of tCollect
   
   if tCollect is empty then 
      answer "No Puzzle Pieces found"
      exit mouseUp
   end if
   
   put tMaxColNum * tMaxRowNum into tExpectedNumPieces
   
   ## check for number of Puzzle Pieces and bail out if there are too few or too many
   if the number of lines of tCollect <> tExpectedNumPieces then
      answer "Not all or too many Puzzle Pieces found"
      exit mouseUp
   end if
   
   ## format of name is "PP" & column & comma & row
   ## this sorts the images by column and then by row
   ## PP1,1; PP2,1 etc
   ## PP1,2; PP2,2 etc
   sort tCollect numeric by char 3 to -1 of item 1 of each
   sort tCollect numeric by char 1 to -1 of item 2 of each
   
   put the topLeft of image line 1 of tCollect into tStartTL
   put item 1 of tStartTL into tStartLeft
   put item 2 of tStartTL into tStartTop
   
   ## check for space to arrange Puzzle Pieces; otherwise they could be placed beyond the card boundaries
   if tStartLeft + (tMaxColNum * tPieceSize) > the width of this card or \
         tStartTop + (tMaxRowNum * tPieceSize) > the height of this card then
      answer "Place top-left Puzzle Piece near the top left of the card"
      exit mouseUp
   end if
   
   repeat for each line anImage in tCollect
      put char 3 to -1 of item 1 of anImage into tImgColumn
      put char 1 to -1 of item 2 of anImage into tImgRow
      put the uMarginFudge of image anImage into tFudge
      put tStartLeft + ((tImgColumn - 1) * tPieceSize) into tTempLeft
      put tStartTop + ((tImgRow -1) * tPieceSize) into tTempTop
      put tTempLeft - item 1 of tFudge into tTempLeft
      put tTempTop - item 2 of tFudge into tTempTop
      set the topLeft of image anImage to tTempLeft, tTempTop
   end repeat
   
end mouseUp
use this script in a button on a card that contains all the pieces of one puzzle. Not more not less.

Kind regards
Bernd

PS if you are still using the outerglow for the script of the puzzle pieces when they are move by the mouse then I changed "outerglow" to "innerglow" because the outerglow overlaps the neighboring pieces whereas "innerglow" does not but still marks the moving piece.

bn
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 4184
Joined: Sun Jan 07, 2007 9:12 pm

Re: cutting irregular pieces from image for puzzle game

Post by bn » Wed Jul 23, 2025 7:34 pm

Hi rcmills,

In trying to do a puzzle I noticed that it is at times hard to place the puzzle pieces exactly where they belong using the mouse.

I thought it would be a nice option to move the puzzle pieces and make them "magnetic". By that I mean that if you come to within 2 pixel of the correct position the pieces would snap into place on mouseUp.

Here is a small stack with the script for "magnetism". Copy the script from the contained button to your puzzle pieces or copy the button to your Puzzle Stack and set the behavior of the puzzle pieces to the long id of the button.

I tested the script fairly extensively and it seems to do what it is supposed to do.

The script is not very straightforward (due to the complexity of the task) and if you have questions feel free to ask.

Kind regards
Bernd
Attachments
Script for magnetic Puzzle Pieces.livecode.zip
(2.91 KiB) Downloaded 1017 times

rcmills
Posts: 73
Joined: Wed Nov 21, 2018 8:27 pm

Re: cutting irregular pieces from image for puzzle game

Post by rcmills » Thu Jul 31, 2025 1:19 am

Thanks very much, Bernd. I will look this over, as I have indeed been having UI difficulties with moving the pieces.

I have been out of town, and left this fun task alone for a while, but am returning to it.

One thing I have learned in the past day is that in LC 10.0.2 the mobilePickPhoto "library" function no longer works properly in iOS. I use it to pick photos from my iPhone library to use in creating the puzzles. I reverted to compiling with 9.6.10, and it worked fine. Has anyone else noticed this, I wonder?

bn
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 4184
Joined: Sun Jan 07, 2007 9:12 pm

Re: cutting irregular pieces from image for puzzle game

Post by bn » Sat Aug 02, 2025 10:55 am

rcmills wrote:
Thu Jul 31, 2025 1:19 am
One thing I have learned in the past day is that in LC 10.0.2 the mobilePickPhoto "library" function no longer works properly in iOS. I use it to pick photos from my iPhone library to use in creating the puzzles. I reverted to compiling with 9.6.10, and it worked fine. Has anyone else noticed this, I wonder?
Maybe you better post that question to the iOS forum.
I have no idea about iOS

Kind regards
Bernd

Klaus
Posts: 14250
Joined: Sat Apr 08, 2006 8:41 am
Contact:

Re: cutting irregular pieces from image for puzzle game

Post by Klaus » Sat Aug 02, 2025 11:04 am

rcmills wrote:
Thu Jul 31, 2025 1:19 am
Thanks very much, Bernd. I will look this over, as I have indeed been having UI difficulties with moving the pieces.

I have been out of town, and left this fun task alone for a while, but am returning to it.

One thing I have learned in the past day is that in LC 10.0.2 the mobilePickPhoto "library" function no longer works properly in iOS. I use it to pick photos from my iPhone library to use in creating the puzzles. I reverted to compiling with 9.6.10, and it worked fine. Has anyone else noticed this, I wonder?
Please report this as a bug!
It will not get fixed if it is not reported, and this seems to be a critical issue!

rcmills
Posts: 73
Joined: Wed Nov 21, 2018 8:27 pm

Re: cutting irregular pieces from image for puzzle game

Post by rcmills » Fri Aug 22, 2025 9:44 pm

Thanks, Klaus. I have reported the bug - ID # 24734

bn
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 4184
Joined: Sun Jan 07, 2007 9:12 pm

Re: cutting irregular pieces from image for puzzle game

Post by bn » Mon Sep 01, 2025 9:07 am

Hi rcmills,

I do not know if you are still working on your Puzzle.
I made a version for puzzle pieces that lets you create them at different sizes. I removed the hardcoded values for the puzzle pieces and replaced them with variables. The mask pieces now have the necessary information as custom properties.

If you (or anybody else) is interested I can post it here.

Kind regards
Bernd

SparkOut
Posts: 2952
Joined: Sun Sep 23, 2007 4:58 pm

Re: cutting irregular pieces from image for puzzle game

Post by SparkOut » Mon Sep 01, 2025 9:33 am

Hi bn

I am super interested, although I doubt I would get a chance to explore it much. But I do love to see other coders work and examine different techniques. Anything you show would be appreciated by more than one, thank you.

bn
VIP Livecode Opensource Backer
VIP Livecode Opensource Backer
Posts: 4184
Joined: Sun Jan 07, 2007 9:12 pm

Re: cutting irregular pieces from image for puzzle game

Post by bn » Mon Sep 01, 2025 2:53 pm

Here are two stacks to

1. create image masks in the shape of a puzzle piece (actually 64 of them) stack "VariableImageMasks"
2. A stack that uses these masks to make puzzle pieces from an image using those masks stack "CreatePuzzleVariableSize".

Please feel free to indicate errors or suggestions for improvement.

Kind regards
Bernd
Attachments
CreatePuzzleVariableSize_1.livecode.zip
(102.67 KiB) Downloaded 840 times
VariableImageMasks_1.livecode.zip
(6.1 KiB) Downloaded 792 times

Post Reply