| ... | ... |
@@ -6,6 +6,7 @@ |
| 6 | 6 |
* |
| 7 | 7 |
* History: |
| 8 | 8 |
* 28/06/2019 Creation |
| 9 |
+ * 27/01/2024 Support transparency |
|
| 9 | 10 |
* |
| 10 | 11 |
* Author: Dario Rodriguez dario@softhome.net |
| 11 | 12 |
* This program is distributed under the terms of the GNU GPL v2.1+ |
| ... | ... |
@@ -19,7 +20,9 @@ main(int argc, array(string) argv) |
| 19 | 20 |
string origfilename; |
| 20 | 21 |
string resprefix; |
| 21 | 22 |
int x,y,total; |
| 22 |
- Image.Image img,cropped; |
|
| 23 |
+ mapping imagemapping; |
|
| 24 |
+ Image.Image image,alpha,cropped,croppedalpha; |
|
| 25 |
+ Image.Layer l; |
|
| 23 | 26 |
string outfilename; |
| 24 | 27 |
if(argc<4 || (argc>1 && argv[1]=="--help")) {
|
| 25 | 28 |
Stdio.werror("Syntax: "+argv[0]+" <width_in_a4pages> <height_in_a4_pages> <origimage.png>\n");
|
| ... | ... |
@@ -32,16 +35,21 @@ main(int argc, array(string) argv) |
| 32 | 35 |
origfilename=argv[3]; |
| 33 | 36 |
resprefix=(origfilename/".png")[0]; |
| 34 | 37 |
write("* Loading "+origfilename+"...\n");
|
| 35 |
- img=Image.load(origfilename); |
|
| 36 |
- px=img->xsize()/a4w; |
|
| 37 |
- py=img->ysize()/a4h; |
|
| 38 |
+ imagemapping=Image._load(origfilename); |
|
| 39 |
+ image=imagemapping["image"]; |
|
| 40 |
+ alpha=imagemapping["alpha"]; |
|
| 41 |
+ px=image->xsize()/a4w; |
|
| 42 |
+ py=image->ysize()/a4h; |
|
| 38 | 43 |
for(total=0,y=0;y<a4h;y++) {
|
| 39 | 44 |
for(x=0;x<a4w;x++) {
|
| 40 | 45 |
total++; |
| 41 |
- cropped=img->copy(x*px,y*py,(x+1)*px-1,(y+1)*py-1,255,255,255); |
|
| 46 |
+ cropped=image->copy(x*px,y*py,(x+1)*px-1,(y+1)*py-1,255,255,255); |
|
| 47 |
+ croppedalpha=alpha->copy(x*px,y*py,(x+1)*px-1,(y+1)*py-1,255,255,255); |
|
| 48 |
+ l=Image.Layer(cropped,croppedalpha,"normal"); |
|
| 49 |
+ l->set_offset(0,0); |
|
| 42 | 50 |
outfilename=sprintf("%s_%05d.png",resprefix,total);
|
| 43 | 51 |
write("* Writing "+outfilename+"...\n");
|
| 44 |
- Stdio.write_file(outfilename,Image.PNG.encode(cropped)); |
|
| 52 |
+ Stdio.write_file(outfilename,Image.PNG.encode(l->image(),(["alpha":l->alpha()]))); |
|
| 45 | 53 |
} |
| 46 | 54 |
} |
| 47 | 55 |
write(""+total+" slices written. Process finished.\n");
|
| 1 | 1 |
new file mode 100755 |
| ... | ... |
@@ -0,0 +1,50 @@ |
| 1 |
+#!/usr/bin/pike |
|
| 2 |
+/* |
|
| 3 |
+ * slicer.pike |
|
| 4 |
+ * |
|
| 5 |
+ * Slices a png in NxM different pngs |
|
| 6 |
+ * |
|
| 7 |
+ * History: |
|
| 8 |
+ * 28/06/2019 Creation |
|
| 9 |
+ * |
|
| 10 |
+ * Author: Dario Rodriguez dario@softhome.net |
|
| 11 |
+ * This program is distributed under the terms of the GNU GPL v2.1+ |
|
| 12 |
+ */ |
|
| 13 |
+ |
|
| 14 |
+int |
|
| 15 |
+main(int argc, array(string) argv) |
|
| 16 |
+{
|
|
| 17 |
+ int a4w,a4h; |
|
| 18 |
+ int px,py; |
|
| 19 |
+ string origfilename; |
|
| 20 |
+ string resprefix; |
|
| 21 |
+ int x,y,total; |
|
| 22 |
+ Image.Image img,cropped; |
|
| 23 |
+ string outfilename; |
|
| 24 |
+ if(argc<4 || (argc>1 && argv[1]=="--help")) {
|
|
| 25 |
+ Stdio.werror("Syntax: "+argv[0]+" <width_in_a4pages> <height_in_a4_pages> <origimage.png>\n");
|
|
| 26 |
+ Stdio.werror("Example: "+argv[0]+" 4 2 orig.png\n");
|
|
| 27 |
+ Stdio.werror("Example result: orig_0001.png ... orig_0008.png\n");
|
|
| 28 |
+ return(1); |
|
| 29 |
+ } |
|
| 30 |
+ a4w=(int)argv[1]; |
|
| 31 |
+ a4h=(int)argv[2]; |
|
| 32 |
+ origfilename=argv[3]; |
|
| 33 |
+ resprefix=(origfilename/".png")[0]; |
|
| 34 |
+ write("* Loading "+origfilename+"...\n");
|
|
| 35 |
+ img=Image.load(origfilename); |
|
| 36 |
+ px=img->xsize()/a4w; |
|
| 37 |
+ py=img->ysize()/a4h; |
|
| 38 |
+ for(total=0,y=0;y<a4h;y++) {
|
|
| 39 |
+ for(x=0;x<a4w;x++) {
|
|
| 40 |
+ total++; |
|
| 41 |
+ cropped=img->copy(x*px,y*py,(x+1)*px-1,(y+1)*py-1,255,255,255); |
|
| 42 |
+ outfilename=sprintf("%s_%05d.png",resprefix,total);
|
|
| 43 |
+ write("* Writing "+outfilename+"...\n");
|
|
| 44 |
+ Stdio.write_file(outfilename,Image.PNG.encode(cropped)); |
|
| 45 |
+ } |
|
| 46 |
+ } |
|
| 47 |
+ write(""+total+" slices written. Process finished.\n");
|
|
| 48 |
+ return(0); |
|
| 49 |
+} |
|
| 50 |
+ |