java 载入图片的几种常用方法

载入图片的几种常用方法
/**
* <p>Title: PaintPanel</p>
* <p>Description:此程序演示如何载入图片,并让其作为panel的背景</p>
* <p>Copyright: Copyright (c) 2005</p>
* <p>Company: gift2u</p>
* @author liwu chinajavaworld
* @version 1.0
*/
import javax.swing.*;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.Image;
import java.net.URL;
import java.net.*;

import java.awt.MediaTracker;
import java.io.File;
import javax.imageio.ImageIO;
import java.io.*;
import java.awt.Toolkit;

public class PaintPanel
    extends JPanel {
  Image image = null;

  /**
   * PaintPanel
   * 外部给图片,直接载入
   * @param image Image
   */
  public PaintPanel(Image image) {
    this.image = image;
  }

  /**
   * PaintPanel
   * 外部给出file引用,通过ImageIO载入
   * @param file File
   */
  

public PaintPanel(File file) {
    try {
      Image readImage = ImageIO.read(file);
      this.image = readImage;
    }
    catch (IOException ex) {
    }
  }
 
/**
   * PaintPanel
   *外部给出string路径,通过Toolkit载入
   * @param string String
   */
  public PaintPanel(String string) {
    URL url = null;
    try {
      url = new URL(string);
    }
    catch (MalformedURLException ex) {
    }
    image = Toolkit.getDefaultToolkit().getImage(url);

    MediaTracker tracker = new MediaTracker(this);
    tracker.addImage(image, 0);
    try {
      tracker.waitForID(0);
    }
    catch (InterruptedException ie) {
    }

  }

  /**
   * PaintPanel
   *外部给出ImageIcon,利用ImageIcon载入
   * @param icon ImageIcon
   */
  public PaintPanel(ImageIcon icon) {
    this.image = icon.getImage();
  }

  /**
   * PaintPanel
   * 外部给出URL,利用ImageIcon载入
   * @param icon url
   */
  public PaintPanel(URL url) {
    ImageIcon icon = new ImageIcon(url);
    this.image = icon.getImage();
  }

  public void paintComponent(Graphics g) {
    super.paintComponent(g);
    Graphics2D g2d = (Graphics2D) g;
    if (image != null) {
      g2d.drawImage(image, 0, 0, this);
    }
  }
}

  测试代码:

import javax.swing.JFrame;
import java.net.URL;
import javax.swing.ImageIcon;
import java.awt.MediaTracker;
import java.awt.Image;
import java.net.MalformedURLException;
import java.awt.GridLayout;
import javax.swing.JDialog;
import java.io.File;

public class TestPaintPanel  {
  public static void main(String[] args) {
    JFrame fr = new JFrame();
    fr.setTitle("GIFT-PaintPanel-演示载入图片的方法");
    String urlstr = "http://photo.sohu.com/20040823/Img221677764.jpg";
    String filestr="D://a.jpg";
//如果是自己的机器上...un comment following......
//   String urlstr="file:///D://a.jpg";
    URL url = null;
    try {
      url = new URL(urlstr);
    }
    catch (MalformedURLException ex) {
    }

    ImageIcon icon = new ImageIcon(url);

    //loadimage//
    Image image = fr.getToolkit().getImage(url);
    MediaTracker tracker = new MediaTracker(fr);
    tracker.addImage(image, 0);
    try {
      tracker.waitForID(0);
    }
    catch (InterruptedException ie) {}
    
    fr.getContentPane().setLayout(new GridLayout(2, 2));
    fr.setSize(500, 600);

    fr.getContentPane().add(new PaintPanel(image));
    fr.getContentPane().add(new PaintPanel(urlstr));
    fr.getContentPane().add(new PaintPanel(icon));
    fr.getContentPane().add(new PaintPanel(url));
    //this is a litter different...
    JDialog dialog = new JDialog(fr, "GIFT-演示让图片成为背景", true);
    //本机上的文件...
    dialog.getContentPane().add(new PaintPanel(new File(filestr)));
    dialog.setSize(200, 200);

    fr.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);
    fr.setVisible(true);
    dialog.setVisible(true);
    fr.validate();
  }

}
: 运行图:

 
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 1. 使用 `java.sql.Statement` 类的 `setMaxRows` 和 `setFetchSize` 方法来设置每页的记录数,然后使用 `java.sql.ResultSet` 类的 `absolute` 方法来跳转到指定页。 2. 使用 `java.sql.PreparedStatement` 类的 `setMaxRows` 和 `setFetchSize` 方法来设置每页的记录数,然后使用 `java.sql.ResultSet` 类的 `absolute` 方法来跳转到指定页。 3. 使用 `SELECT` 语句的 `LIMIT` 和 `OFFSET` 子句来限制查询返回的行数。 4. 使用 `java.sql.Statement` 或 `java.sql.PreparedStatement` 对象的 `executeQuery` 方法执行带有 `LIMIT` 和 `OFFSET` 子句的 `SELECT` 语句,然后使用 `java.sql.ResultSet` 类的 `next` 方法来遍历查询结果。 5. 使用数据库的特定功能(如 MySQL 的 `LIMIT` 子句)来实现分页。这种方法的实现方式取决于数据库的类型。 ### 回答2: Java实现分页查询的几种常用方法有: 1.使用SQL语句的LIMIT关键字:在查询数据库时,可以使用LIMIT关键字来指定查询结果的起始位置和数量。通过计算页号PageNum和每页数量PageSize,可以得到SQL语句中的LIMIT子句,从而实现分页查询。 2.使用MyBatis的分页插件:MyBatis是一种优秀的持久化框架,在其配置文件中可以配置分页插件,并使用插件提供的分页功能完成分页查询。通过在Mapper接口中定义查询方法,并在配置文件中配置插件,可以方便地实现分页逻辑。 3.使用Spring Data JPA的分页查询:Spring Data JPA是一种简化数据库操作的框架,可以通过定义Repository接口来实现数据的增删改查操作。在查询方法中,可以使用Pageable参数来指定查询结果的起始位置和数量,从而实现分页查询。 4.使用PageHelper插件:PageHelper是一种基于MyBatis的分页插件,提供了丰富的分页查询功能。在查询方法中,可以通过调用PageHelper.startPage方法来指定页号和每页数量,PageHelper会自动在SQL语句中添加LIMIT子句,从而实现分页查询。 5.使用自定义工具类:可以自定义一个工具类来实现分页查询逻辑。通过传入查询结果集合、页号和每页数量,可以在工具类中进行计算,得到分页查询的结果集合。 以上是Java实现分页查询的几种常用方法,根据项目的需求和使用的框架,可以选择适合的方法来实现分页功能。 ### 回答3: Java实现分页查询有多种方法,以下是几种常见的实现方式: 1. 使用数据库的分页查询:在SQL语句中使用LIMIT关键字,通过设置偏移量和每页显示的数据条数,实现分页效果。例如,使用MySQL数据库时,可以通过"SELECT * FROM table_name LIMIT offset, limit"语句来实现分页查询。 2. 使用集合分页:将查询结果全部加载到内存中的集合中,然后通过对集合进行切片操作,截取指定页的数据,实现分页效果。常见的集合类如List、ArrayList等都提供了subList方法,可以方便地实现分页。 3. 使用ORM框架:ORM(Object-Relational Mapping)框架如Hibernate、MyBatis等,提供了丰富的分页查询功能。通常只需在查询方法中传入页码和每页显示的数据数量,框架会自动生成对应的分页查询SQL语句,并返回分页查询结果。 4. 使用第三方库:有一些开源的分页查询库可以直接使用,如PageHelper、Spring Data JPA等。这些库提供了简单易用的API,可以快速实现分页查询功能。 需要注意的是,无论使用哪种方法实现分页查询,都要考虑性能和数据量。当处理大数据量时,应尽量减少数据库查询次数,避免一次性加载全部数据;同时,合理使用缓存、索引等技术,提高查询效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值