Example showing how to reset the ordering of ImageReaderSpis in Image I/O : 图像输入输出 « 图形用户界面 « Java

En
Java
1. 图形用户界面
2. 三维图形动画
3. 高级图形
4. 蚂蚁编译
5. Apache类库
6. 统计图
7. 
8. 集合数据结构
9. 数据类型
10. 数据库JDBC
11. 设计模式
12. 开发相关类
13. EJB3
14. 电子邮件
15. 事件
16. 文件输入输出
17. 游戏
18. 泛型
19. GWT
20. Hibernate
21. 本地化
22. J2EE平台
23. 基于J2ME
24. JDK-6
25. JNDI的LDAP
26. JPA
27. JSP技术
28. JSTL
29. 语言基础知识
30. 网络协议
31. PDF格式RTF格式
32. 映射
33. 常规表达式
34. 脚本
35. 安全
36. Servlets
37. Spring
38. Swing组件
39. 图形用户界面
40. SWT-JFace-Eclipse
41. 线程
42. 应用程序
43. Velocity
44. Web服务SOA
45. 可扩展标记语言
Java 教程
Java » 图形用户界面 » 图像输入输出屏幕截图 
Example showing how to reset the ordering of ImageReaderSpis in Image I/O
Example showing how to reset the ordering of ImageReaderSpis in Image I/O
  

/*
 * Copyright (c) 2005 Sun Microsystems, Inc. All Rights Reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * -Redistributions of source code must retain the above copyright notice, this
 * list of conditions and the following disclaimer.
 *
 * -Redistribution in binary form must reproduce the above copyright notice,
 * this list of conditions and the following disclaimer in the documentation
 * and/or other materials provided with the distribution.
 *
 * Neither the name of Sun Microsystems, Inc. or the names of contributors may
 * be used to endorse or promote products derived from this software without
 * specific prior written permission.
 *
 * This software is provided "AS IS," without a warranty of any kind. ALL
 * EXPRESS OR IMPLIED CONDITIONS, REPRESENTATIONS AND WARRANTIES, INCLUDING ANY
 * IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR
 * NON-INFRINGEMENT, ARE HEREBY EXCLUDED. SUN AND ITS LICENSORS SHALL NOT BE
 * LIABLE FOR ANY DAMAGES SUFFERED BY LICENSEE AS A RESULT OF USING, MODIFYING
 * OR DISTRIBUTING THE SOFTWARE OR ITS DERIVATIVES. IN NO EVENT WILL SUN OR ITS
 * LICENSORS BE LIABLE FOR ANY LOST REVENUE, PROFIT OR DATA, OR FOR DIRECT,
 * INDIRECT, SPECIAL, CONSEQUENTIAL, INCIDENTAL OR PUNITIVE DAMAGES, HOWEVER
 * CAUSED AND REGARDLESS OF THE THEORY OF LIABILITY, ARISING OUT OF THE USE OF
 * OR INABILITY TO USE SOFTWARE, EVEN IF SUN HAS BEEN ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGES.
 *
 * You acknowledge that Software is not designed,licensed or intended for use in
 * the design, construction, operation or maintenance of any nuclear facility.
 */
import java.util.Iterator;

import javax.imageio.spi.IIORegistry;
import javax.imageio.spi.ImageReaderSpi;
import javax.imageio.spi.ServiceRegistry;

/**
 * Example showing how to reset the ordering of ImageReaderSpis in Image I/O.
 * This is particularly applicable to the case where metadata handling is a
 * requirement and is of special importance for the JPEG format as the
 * JAI-Image I/O JPEG plug-ins do not handle metadata and have a higher
 * priority setting in the IIORegistry than do the core J2SE JPEG plug-ins.
 */
public class SetOrderingExample {
    public static void main(String[] args) {
        IIORegistry registry = IIORegistry.getDefaultInstance();

        // Print the initial ordered list of readers.
        System.out.println("- Initial list of readers -");
        Iterator providers =
            registry.getServiceProviders(ImageReaderSpi.class, true);
        while(providers.hasNext()) {
            ImageReaderSpi provider = (ImageReaderSpiproviders.next();
            System.out.println(provider.getPluginClassName());
        }
        System.out.println("");

        // Get the reader SPIs for JPEG.
        providers = registry.getServiceProviders(ImageReaderSpi.class,
                                                 new JPEGFilter(),
                                                 true);

        // Save reader SPIs for JPEG according to whether they support
        // native image metadata. This removes the dependence on knowing
        // the class name of the associated reader plug-in.
        ImageReaderSpi readerMetadataSPI = null;
        ImageReaderSpi readerNoMetadataSPI = null;
        while(providers.hasNext()) {
            ImageReaderSpi readerSPI = (ImageReaderSpi)providers.next();
            if(readerSPI.getNativeImageMetadataFormatName() != null) {
                readerMetadataSPI = readerSPI;
            else {
                readerNoMetadataSPI = readerSPI;
            }
        }

        // Update ordering if both metadata-capable and -incapable readers
        // are detected.
        if(readerMetadataSPI != null && readerNoMetadataSPI != null) {
            // Remove ordering that places metadata-capable reader last.
            boolean unsetResult = registry.unsetOrdering(ImageReaderSpi.class,
                                                         readerNoMetadataSPI,
                                                         readerMetadataSPI);

            // Add ordering that places metadata-capable reader first.
            boolean setResult = registry.setOrdering(ImageReaderSpi.class,
                                                     readerMetadataSPI,
                                                     readerNoMetadataSPI);
        }

        // Print the final ordered list of readers.
        System.out.println("- Final list of readers -");
        providers = registry.getServiceProviders(ImageReaderSpi.class, true);
        while(providers.hasNext()) {
            ImageReaderSpi provider = (ImageReaderSpiproviders.next();
            System.out.println(provider.getPluginClassName());
        }
    }
}

/**
 * Filter which returns <code>true</code> if and only if the provider is
 * an <code>ImageReaderSpi</code> which supports the JPEG format.
 */
class JPEGFilter implements ServiceRegistry.Filter {
    JPEGFilter() {}

    public boolean filter(Object provider) {
        if(!(provider instanceof ImageReaderSpi)) {
            return false;
        }

        ImageReaderSpi readerSPI = (ImageReaderSpi)provider;
        String[] formatNames = readerSPI.getFormatNames();
        for(int i = 0; i < formatNames.length; i++) {
            if(formatNames[i].equalsIgnoreCase("JPEG")) {
                return true;
            }
        }

        return false;
    }
}

           
         
    
  
Related examples in the same category
1. 显示ImageIO支持的图像
2. 打印图像直接打印
3. 列出所有读和写格式支持ImageIO
4. 显示可用ImageReaders和ImageWriters的图像格式和MIME类型显示可用ImageReaders和ImageWriters的图像格式和MIME类型
5. Write an image of a given format
6. Read an image
7. Simple, functional ImageReaderSpi used to understand how information
8. Simple, functional ImageWriterSpi used to understand how information
9. 使用mediatracker预先加载图片
10. Get list of unique supported read formats
11. Get list of unique supported write formats
12. Get list of unique MIME types that can be read
13. Get list of unique MIME types that can be written
14. 返回true如果指定的格式名称可以读取
15. 返回true如果指定格式的名称可以是可写
16. 返回true如果指定的文件扩展名可以读取
17. 返回true如果指定的文件扩展名可以写
18. 返回true如果指定的MIME类型可以读取
19. 返回true如果指定的MIME类型可以写
20. 查看ImageIO信息
21. 查看图像不同类型
22. 加载图像文件从一个文件夹或JAR文件:使用javax.imageio.ImageIO级阅读图像文件
www.java2java.com | Contact Us
Copyright 2010 - 2030 Java Source and Support. All rights reserved.
All other trademarks are property of their respective owners.