SWT1-Üb4 Zusammenfassung

SWT1-Üb4 Zusammenfassung

1. java.awt & Swing

Window

setLocationRelativeTo

public void setLocationRelativeTo(Component c)
  • 设置窗口相对于指定组件的位置。
  • 如果组件当前未显示,或者 c 为 null,则此窗口将置于屏幕的中央。中点可以使用 GraphicsEnvironment.getCenterPoint 确定。
  • 如果该组件的底部在屏幕外,则将该窗口放置在 Component 最接近窗口中心的一侧。因此,如果 Component 在屏幕的右部,则 Window 将被放置在左部,反之亦然。
  • 参数:
    c - 确定窗口位置涉及的组件

add an image to JPanel

  • from StackOverflow
BufferedImage myPicture = ImageIO.read(new File("path-to-file"));

JLabel picLabel = new JLabel(new ImageIcon(myPicture));

add(picLabel);

2.FileFilter

==FileNameExtensionFilter==

API:
https://docs.oracle.com/javase/7/docs/api/javax/swing/filechooser/FileNameExtensionFilter.html


public FileNameExtensionFilter(String description, String... extensions)
  • Creates a FileNameExtensionFilter with the specified description and file name extensions. The returned FileNameExtensionFilter will accept all directories and any file with a file name extension contained in extensions.
  • Parameters:
    description - textual description for the filter, may be null
    extensions - the accepted file name extensions
  • Throws:
    IllegalArgumentException - if extensions is null, empty, contains null, or contains an empty string

3.Scale(resize) a bufferedImage

  1. from StackOverflow

    Using imgscalr – Java Image Scaling Library:

    BufferedImage image = Scalr.resize(originalImage, 
        Scalr.Method.BALANCED, newWidth, newHeight);
    
  2. 教授给的答案(假设现在resize后的image时600 * 600)

public BufferedImage getResizedMasterImage() { 

    int newWidth, newHeight;
    int maxSideLength = (int) (600 /
        Math.sqrt(parameters.getText().length()));

    //neue Breite und Höhe bestimmen
    int newWidth = masterImage.getWidth();
    int newHeight = masterImage.getHeight();


    if (masterImage.getWidth() > masterImage.getHeight()
      && masterImage.getWidth() > maxSideLength) {

        newWidth = maxSideLength;
        newHeight = (int) ((double) masterImage.getHeight() /
            masterImage.getWidth() * maxSideLength);

    } else if (masterImage.getHeight() > maxSideLength) { 
        newWidth = (int) ((double) masterImage.getWidth() /
            masterImage.getHeight() * maxSideLength); 
        newHeight = maxSideLength;
    }  

    BufferedImage newImage = new BufferedImage(newWidth, 
            newHeight,masterImage.getType());
    Graphics g = newImage.createGraphics(); 
    g.drawImage(masterImage, 0, 0, newWidth, newHeight, null);
    g.dispose();
    return newImage;
}

重点在最后六行!

4.JFileChooser

Tutorial:

  1. http://www.java2s.com/Tutorial/Java/0240__Swing/UsingJFileChooser.htm

  2. Oracle:https://docs.oracle.com/javase/tutorial/uiswing/components/filechooser.html

中文:

  1. http://blog.csdn.net/yahohi/article/details/6924732

  2. http://www.cnblogs.com/ning1121/p/3738065.html

    • 创建一个JFileChooser对象
    JFileChooser fileChooser = new JFileChooser();
  • 为这个JFileChooser对象添加文件选择器

例:

       FileFilter jpgFilter = new FileNameExtensionFilter(".jpg",  "jpg");
        FileFilter pngFilter = new FileNameExtensionFilter(".png", "png");
        chooser.addChoosableFileFilter(pngFilter);
        chooser.addChoosableFileFilter(jpgFilter);  
  • 选取文件:

例:

    int returnValue = fileChooser.showOpenDialog(null);
    if (returnValue == JFileChooser.APPROVE_OPTION) {
        File selectedFile = fileChooser.getSelectedFile();
        System.out.println(selectedFile.getName());
    }
  • saving image
    int returnVal = chooser.showSaveDialog(null);
    if (returnVal == JFileChooser.APPROVE_OPTION) {
        File f = chooser.getSelectedFile();

        try {
            ImageIO.write(toSaveImage, "png", f);
        } catch (IOException ioe) {
            System.out.println(ioe.getMessage());
        }
    }



Accessing Resource in JAR

参考:http://hxraid.iteye.com/blog/483115

不能用平时读本地文件的方法去读jar包里的资源

这是因为:

这主要是因为jar包是一个==单独的文件而非文件夹==,绝对不可能通过”file:/e:/…/ResourceJar.jar/resource /res.txt”这种形式的文件URL来定位res.txt。所以即使是相对路径,也无法定位到jar文件内的txt文件

如何实现:把资源打入jar包,无论ResourceJar.jar在系统的什么路径下,jar包中的字节码程序都可以找到该包中的资源?

可以用==类装载器(ClassLoader)==来做到这一点:

  1. ClassLoader 是类加载器的抽象类。它可以在运行时动态的获取加载类的运行信息。 可以这样说,当我们调用ResourceJar.jar中的Resource类时,JVM加载进Resource类,并记录下Resource运行时信息(包括Resource所在jar包的路径信息)。

    而ClassLoader类中的方法可以帮助我们动态的获取这些信息:

    • public URL getResource(String name)

      查找具有给定名称的资源。资源是可以通过类代码以与代码基无关的方式访问的一些数据(图像、声音、文本等)。并返回资源的URL对象。

    • public InputStream getResourceAsStream(String name)

      返回读取指定资源的输入流。这个方法很重要,可以直接获得jar包中文件的内容。

  2. ClassLoader是abstract的,不可能实例化对象,更加不可能通过ClassLoader调用上面两个方法。==所以我们真正写代码的时候,是通过Class类中的getResource()和getResourceAsStream()方法,这两个方法会委托ClassLoader中的getResource()和getResourceAsStream()方法==

获得URL之后,我们不能用常规操作文件的方法来读取ResourceJar.jar中的资源文件res.txt,但可以通过Class类的getResourceAsStream()方法来获取 (这种方法是如何读取jar中的资源文件的,这一点对于我们来说是透明的)。然后再用BufferedReader读取资源即可。

例1:从jar包中读取默认的image

    private BufferedImage accessImage(String path) {
        BufferedImage readImage = null;

        try {
            readImage = ImageIO.read(this.getClass().getResource(path));
        } catch (IOException e) {
            e.printStackTrace();
        }

        return readImage;
    }

例2:上面链接里的例子

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
SQLAlchemy 是一个 SQL 工具包和对象关系映射(ORM)库,用于 Python 编程语言。它提供了一个高级的 SQL 工具和对象关系映射工具,允许开发者以 Python 类和对象的形式操作数据库,而无需编写大量的 SQL 语句。SQLAlchemy 建立在 DBAPI 之上,支持多种数据库后端,如 SQLite, MySQL, PostgreSQL 等。 SQLAlchemy 的核心功能: 对象关系映射(ORM): SQLAlchemy 允许开发者使用 Python 类来表示数据库表,使用类的实例表示表中的行。 开发者可以定义类之间的关系(如一对多、多对多),SQLAlchemy 会自动处理这些关系在数据库中的映射。 通过 ORM,开发者可以像操作 Python 对象一样操作数据库,这大大简化了数据库操作的复杂性。 表达式语言: SQLAlchemy 提供了一个丰富的 SQL 表达式语言,允许开发者以 Python 表达式的方式编写复杂的 SQL 查询。 表达式语言提供了对 SQL 语句的灵活控制,同时保持了代码的可读性和可维护性。 数据库引擎和连接池: SQLAlchemy 支持多种数据库后端,并且为每种后端提供了对应的数据库引擎。 它还提供了连接池管理功能,以优化数据库连接的创建、使用和释放。 会话管理: SQLAlchemy 使用会话(Session)来管理对象的持久化状态。 会话提供了一个工作单元(unit of work)和身份映射(identity map)的概念,使得对象的状态管理和查询更加高效。 事件系统: SQLAlchemy 提供了一个事件系统,允许开发者在 ORM 的各个生命周期阶段插入自定义的钩子函数。 这使得开发者可以在对象加载、修改、删除等操作时执行额外的逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值