⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 derivedimagedescriptor.java

📁 jfa2ce 源码帮助开发人员更好的理解运用
💻 JAVA
字号:
/******************************************************************************* * Copyright (c) 2005, 2006 IBM Corporation and others. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: *     IBM Corporation - initial API and implementation *******************************************************************************/package org.eclipse.jface.resource;import org.eclipse.swt.SWTException;import org.eclipse.swt.graphics.Device;import org.eclipse.swt.graphics.Image;import org.eclipse.swt.graphics.ImageData;import org.eclipse.swt.widgets.Display;/** * An image descriptor which creates images based on another ImageDescriptor, but with * additional SWT flags. Note that this is only intended for compatibility.  *  * @since 3.1 */final class DerivedImageDescriptor extends ImageDescriptor {    private ImageDescriptor original;    private int flags;        public DerivedImageDescriptor(ImageDescriptor original, int swtFlags) {        this.original = original;        flags = swtFlags;    }        public Object createResource(Device device) throws DeviceResourceException {        try {            return internalCreateImage(device);        } catch (SWTException e) {            throw new DeviceResourceException(this, e);        }    }        public Image createImage(Device device) {        return internalCreateImage(device);    }        public int hashCode() {        return original.hashCode() + flags;    }        public boolean equals(Object arg0) {        if (arg0 instanceof DerivedImageDescriptor) {            DerivedImageDescriptor desc = (DerivedImageDescriptor)arg0;                        return desc.original == original && flags == desc.flags;        }                return false;    }        /**     * Creates a new Image on the given device. Note that we defined a new     * method rather than overloading createImage since this needs to be     * called by getImageData(), and we want to be absolutely certain not     * to cause infinite recursion if the base class gets refactored.      *     * @param device device to create the image on     * @return a newly allocated Image. Must be disposed by calling image.dispose().     */    private final Image internalCreateImage(Device device) {        Image originalImage = original.createImage(device);        Image result = new Image(device, originalImage, flags);        original.destroyResource(originalImage);        return result;    }        public ImageData getImageData() {        Image image = internalCreateImage(Display.getCurrent());        ImageData result = image.getImageData();        image.dispose();        return result;    }}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -