Merge branch 'master' of https://github.com/stefanhaustein/TerminalImageViewer
This commit is contained in:
		| @@ -20,6 +20,7 @@ public class TerminalImageViewer { | |||||||
|  |  | ||||||
|   static boolean grayscale = false; |   static boolean grayscale = false; | ||||||
|   static int mode = Ansi.MODE_24BIT; |   static int mode = Ansi.MODE_24BIT; | ||||||
|  |   static boolean html = false; | ||||||
|  |  | ||||||
|  |  | ||||||
|   /** |   /** | ||||||
| @@ -52,6 +53,8 @@ public class TerminalImageViewer { | |||||||
|         mode = (mode & ~Ansi.MODE_24BIT) | Ansi.MODE_256; |         mode = (mode & ~Ansi.MODE_24BIT) | Ansi.MODE_256; | ||||||
|       } else if (option.equals("-grayscale")) { |       } else if (option.equals("-grayscale")) { | ||||||
|         grayscale = true; |         grayscale = true; | ||||||
|  |       } else if (option.equals("-html")) { | ||||||
|  |         html = true; | ||||||
|       } else if (option.equals("-stdin")) { |       } else if (option.equals("-stdin")) { | ||||||
|         stdin = true; |         stdin = true; | ||||||
|       } |       } | ||||||
| @@ -159,6 +162,8 @@ public class TerminalImageViewer { | |||||||
|     System.out.print(imageData.dump(mode)); |     System.out.print(imageData.dump(mode)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|  |  | ||||||
|   /** |   /** | ||||||
|    * ANSI control code helpers |    * ANSI control code helpers | ||||||
|    */ |    */ | ||||||
| @@ -245,7 +250,7 @@ public class TerminalImageViewer { | |||||||
|      * Assumed bitmaps of the supported characters |      * Assumed bitmaps of the supported characters | ||||||
|      */ |      */ | ||||||
|     static int[] BITMAPS = new int[] { |     static int[] BITMAPS = new int[] { | ||||||
|         0x00000000, ' ', |         0x00000000, '\u00a0', | ||||||
|  |  | ||||||
|         // Block graphics |         // Block graphics | ||||||
|  |  | ||||||
| @@ -477,6 +482,9 @@ public class TerminalImageViewer { | |||||||
|       this.data = new byte[width * height * 4]; |       this.data = new byte[width * height * 4]; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     public String hex6(int r, int g, int b) { | ||||||
|  |       return Integer.toHexString((1 << 24) | ((r & 255) << 16) | ((g & 255) << 8) | (b & 255)).substring(1); | ||||||
|  |     } | ||||||
|     /** |     /** | ||||||
|      * Convert the image to an Ansi control character string setting the colors |      * Convert the image to an Ansi control character string setting the colors | ||||||
|      */ |      */ | ||||||
| @@ -486,24 +494,44 @@ public class TerminalImageViewer { | |||||||
|  |  | ||||||
|       for (int y = 0; y < height - 7; y += 8) { |       for (int y = 0; y < height - 7; y += 8) { | ||||||
|         int pos = y * width * 4; |         int pos = y * width * 4; | ||||||
|         String lastFg = ""; |         if (html) { | ||||||
|         String lastBg = ""; |           String last = ""; | ||||||
|         for (int x = 0; x < width - 3; x += 4) { |           for (int x = 0; x < width - 3; x += 4) { | ||||||
|           blockChar.load(data, pos, width * 4); |             blockChar.load(data, pos, width * 4); | ||||||
|           String fg = Ansi.color(Ansi.FG|mode, blockChar.fgColor[0], blockChar.fgColor[1], blockChar.fgColor[2]); |             String fg = hex6(blockChar.fgColor[0], blockChar.fgColor[1], blockChar.fgColor[2]); | ||||||
|           String bg = Ansi.color(Ansi.BG|mode, blockChar.bgColor[0], blockChar.bgColor[1], blockChar.bgColor[2]); |             String bg = hex6(blockChar.bgColor[0], blockChar.bgColor[1], blockChar.bgColor[2]); | ||||||
|           if (!fg.equals(lastFg)) { |             String style = "background-color:#" + bg + ";color:#" + fg; | ||||||
|             sb.append(fg); |             if (!style.equals(last)) { | ||||||
|             lastFg = fg; |               if (!last.isEmpty()) { | ||||||
|  |                 sb.append("</tt>"); | ||||||
|  |               } | ||||||
|  |               sb.append("<tt style='").append(style).append("'>"); | ||||||
|  |               last = style; | ||||||
|  |             } | ||||||
|  |             sb.append("&#" + ((int) blockChar.character) + ";"); | ||||||
|  |             pos += 16; | ||||||
|           } |           } | ||||||
|           if (!bg.equals(lastBg)) { |           sb.append("</tt><br />\n"); | ||||||
|             sb.append(bg); |         } else { | ||||||
|             lastBg = bg; |           String lastFg = ""; | ||||||
|  |           String lastBg = ""; | ||||||
|  |           for (int x = 0; x < width - 3; x += 4) { | ||||||
|  |             blockChar.load(data, pos, width * 4); | ||||||
|  |             String fg = Ansi.color(Ansi.FG | mode, blockChar.fgColor[0], blockChar.fgColor[1], blockChar.fgColor[2]); | ||||||
|  |             String bg = Ansi.color(Ansi.BG | mode, blockChar.bgColor[0], blockChar.bgColor[1], blockChar.bgColor[2]); | ||||||
|  |             if (!fg.equals(lastFg)) { | ||||||
|  |               sb.append(fg); | ||||||
|  |               lastFg = fg; | ||||||
|  |             } | ||||||
|  |             if (!bg.equals(lastBg)) { | ||||||
|  |               sb.append(bg); | ||||||
|  |               lastBg = bg; | ||||||
|  |             } | ||||||
|  |             sb.append(blockChar.character); | ||||||
|  |             pos += 16; | ||||||
|           } |           } | ||||||
|           sb.append(blockChar.character); |           sb.append(Ansi.RESET).append("\n"); | ||||||
|           pos += 16; |  | ||||||
|         } |         } | ||||||
|         sb.append(Ansi.RESET).append("\n"); |  | ||||||
|       } |       } | ||||||
|       return sb.toString(); |       return sb.toString(); | ||||||
|     } |     } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Stefan Haustein
					Stefan Haustein