Java实现的图片转HTML

 偶然在网上看到一个.net的将图片转成html代码的方法,想来java也可以轻松实现。遂试之....
 
  
import java.awt.image.BufferedImage;
import java.awt.image.ColorModel;
import java.awt.image.Raster;
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
 
import javax.imageio.ImageIO;
 
public class Image2Html {
 
public static void main(String[] args) throws Exception {
File file = new File("E:\\Desert.jpg");
File destFile = new File("E:\\image.html");
BufferedWriter bos = new BufferedWriter(new FileWriter(destFile));
BufferedImage image = ImageIO.read(file);
Raster raster = image.getData();
int height = raster.getHeight();
int width = raster.getWidth();
// ColorModel model = image.getColorModel();
ColorModel model = ColorModel.getRGBdefault();
bos.write("<html><head>");
bos.write("<style>");
bos.write("#pic {width:" + width + "px;height:" + height + "px;}");
bos.write("#pic div{float:left;height:1px;overflow:hidden;width:1px;}");
bos.write("</style>");
bos.write("</head>");
bos.write("<body><div id=\"pic\">");
StringBuilder sb = new StringBuilder();
for (int i = 0; i < width; i++) {
sb.delete(0, sb.length());
for (int j = 0; j < height; j++) {
int rgb = image.getRGB(i, j);
int r = model.getRed(rgb);
int g = model.getGreen(rgb);
int b = model.getBlue(rgb);
sb.append("<div style=\"background:#")
.append(Integer.toHexString(r))
.append(Integer.toHexString(g))
.append(Integer.toHexString(b)).append(";\"></div>");
// int newRgb = model.getRGB(rgb);
// System.out.print(Integer.toHexString(newRgb) + " ");
}
bos.write(sb.toString());
}
bos.write("</div></body></html>");
bos.close();
}
}
注意:图片不能太大,否则会显示不出来。性能有大问题,目测娱乐下还是可以。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
以下是使用html2canvas插件实现Javahtml图片的示例代码: ```java import java.awt.image.BufferedImage; import java.io.File; import java.io.IOException; import java.util.concurrent.ExecutionException; import javax.imageio.ImageIO; import org.apache.commons.io.FileUtils; import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.openqa.selenium.WebElement; import org.openqa.selenium.chrome.ChromeDriver; import org.openqa.selenium.chrome.ChromeOptions; import org.openqa.selenium.remote.Augmenter; import org.openqa.selenium.remote.DesiredCapabilities; import org.openqa.selenium.remote.RemoteWebDriver; import org.openqa.selenium.support.ui.ExpectedConditions; import org.openqa.selenium.support.ui.WebDriverWait; import com.google.common.base.Function; import io.github.bonigarcia.wdm.WebDriverManager; import net.sf.image4j.codec.ico.ICODecoder; public class HtmlToImage { public static void main(String[] args) throws IOException, InterruptedException, ExecutionException { // 设置ChromeDriver路径 WebDriverManager.chromedriver().setup(); // 创建ChromeDriver实例 ChromeOptions options = new ChromeOptions(); options.addArguments("--headless", "--disable-gpu", "--no-sandbox"); DesiredCapabilities capabilities = DesiredCapabilities.chrome(); capabilities.setCapability(ChromeOptions.CAPABILITY, options); WebDriver driver = new ChromeDriver(capabilities); // 打开html页面 driver.get("http://www.example.com"); // 等待页面加载完成 WebDriverWait wait = new WebDriverWait(driver, 30); wait.until((Function<WebDriver, Boolean>) d -> ((JavascriptExecutor) d).executeScript("return document.readyState").equals("complete")); // 调用html2canvas插件生成图片 WebElement element = driver.findElement(By.tagName("body")); File screenshot = ((TakesScreenshot) new Augmenter().augment(driver)).getScreenshotAs(OutputType.FILE); FileUtils.copyFile(screenshot, new File("screenshot.png")); // 关闭ChromeDriver实例 driver.quit(); } } ``` 上述代码使用了Selenium WebDriver和html2canvas插件来实现Javahtml图片的功能。其中,Selenium WebDriver用于打开html页面和截取屏幕截图,html2canvas插件用于将html页面换为图片。具体实现过程如下: 1. 首先,需要设置ChromeDriver的路径,并创建ChromeDriver实例。 2. 然后,使用ChromeDriver打开html页面,并等待页面加载完成。 3. 接着,使用html2canvas插件生成图片。这里使用了Selenium WebDriver的截图功能,将页面截图保存为文件。 4. 最后,关闭ChromeDriver实例。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值