亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? imagecombiner.java

?? 源代碼使用說明 本書全部代碼全部在JDK中調試成功
?? JAVA
字號:
import java.awt.*;
import java.awt.image.*;
import java.awt.event.*;

/**
 * To use this program, first identify the two images
 * you want to merge.  Then run this program and give
 * the two image file names on the command line.  The
 * program will display both images and their combination.
 * To change the relative weights of the combination,
 * pass both the file names and the weights on the command
 * line.
 * <p>
 * For example: 
 * <tt>java ImageCombiner photo1.jpg 0.67 photo2.jpg 0.55</tt>
 */
public class ImageCombiner extends WindowAdapter {
    Image resultImage;
    Image img1;
    Image img2;
    Image imgr;
    ImageDisplay ic1;
    ImageDisplay ic2;
    ImageDisplay icr;
    int ccnt;

    public class ImageDisplay extends Canvas {
        private Image i;
        private Frame myframe;

        public ImageDisplay(Image img, boolean makeframe) {
            i = img;
            if (makeframe) {
                myframe = new Frame("Image");
                myframe.add(this, BorderLayout.CENTER);
                MediaTracker mt = new MediaTracker(this);
                mt.addImage(i, 1);
                try { mt.waitForAll(); } catch (Exception ie) { }
                setSize(i.getWidth(this), i.getHeight(this));
                myframe.pack();
            }
            else {
                myframe = null;
                setSize(i.getWidth(this), i.getHeight(this));
            }
        }
        public void paint(Graphics g) {
            g.drawImage(i, 0, 0, this);
        }

        public Frame getFrame() { return myframe; }

        public void placeAndShow(int x, int y) {
            if (myframe != null) { 
                myframe.setLocation(x,y);
                myframe.show();
            }
        }
    }

    /**
     * ImageMerger acts as an ImageProducer to
     * generate the merger of two images.  
     * When created, it expects to Image objects.
     * It extracts the pixels from these objects,
     * and merges them using a simple weighted 
     * addition in RGB space.  The width and height
     * of the result image are each the maximum of
     * the widths and heights of the input images.
     * Normally, you'll get best results when the
     * images are exactly the same size.
     */
    public class ImageMerger
    {
        protected double w1, w2;
        protected Image i1;
        protected Image i2;
        protected ColorModel cm;
    
        int rwid, rhgt;
        protected int results[];

        /**
         * Create in ImageMerger object to merge two
         * images.  This does not perform the merger,
         * that should be done by calling generate().
         * This constructors sets the weights to 
         * 0.5 and 0.5.
         */
        public ImageMerger(Image img1, Image img2) {
            cm = null;
            i1 = img1;
            i2 = img2;
            w1 = 0.5;
            w2 = 0.5;
            rwid = 0;
            rhgt = 0;
            results = null;
        }

        /**
         * Set the relative weights of the 
         * two images.  Usually, these should add
         * up to 1.0, but they don't have to.
         */
        public void setWeights(double img1weight, double img2weight) {
            w1 = img1weight;
            w2 = img2weight;
        }

        /**
         * Generate the merged image and store it 
         * for later hand-off to an ImageConsumer.
         * The caller must supply a Component c on which
         * the image will eventually be drawn.
         */
        public boolean generate(Component comp) {
            MediaTracker mt;
            mt = new MediaTracker(comp);
            mt.addImage(i1, 1);
            mt.addImage(i2, 2);
            try { mt.waitForAll(); } catch (Exception ie) { }

            int wid1, wid2;
            int hgt1, hgt2;

            wid1 = i1.getWidth(comp);
            wid2 = i2.getWidth(comp);
            hgt1 = i1.getHeight(comp);
            hgt2 = i2.getHeight(comp);

            rwid = Math.max(wid1, wid2);
            rhgt = Math.max(hgt1, hgt2);

            results = new int[rwid * rhgt];

            int [] p1 = new int[rwid * rhgt];
            int [] p2 = new int[rwid * rhgt];

            PixelGrabber pg1 = new PixelGrabber(i1, 0, 0, wid1, hgt1, p1, 0, rwid);
            try { pg1.grabPixels(); } catch (Exception ie1) { }

            PixelGrabber pg2 = new PixelGrabber(i2, 0, 0, wid2, hgt2, p2, 0, rwid);
            try { pg2.grabPixels(); } catch (Exception ie2) { }

            cm = ColorModel.getRGBdefault();

            int y, x, rp, rpi;
            int red1, red2, redr;
            int green1, green2, greenr;
            int blue1, blue2, bluer;
            int alpha1, alpha2, alphar;
            double wgt1, wgt2;

            for(y = 0; y < rhgt; y++) {
                for(x = 0; x < rwid; x++) {
                    rpi = y * rwid + x;
                    rp = 0;
                    blue1 = p1[rpi] & 0x00ff;
                    blue2 = p2[rpi] & 0x00ff;
                    green1 = (p1[rpi] >> 8) & 0x00ff;
                    green2 = (p2[rpi] >> 8) & 0x00ff;
                    red1 = (p1[rpi] >> 16) & 0x00ff;
                    red2 = (p2[rpi] >> 16) & 0x00ff;
                    alpha1 = (p1[rpi] >> 24) & 0x00ff;
                    alpha2 = (p2[rpi] >> 24) & 0x00ff;

                    // Computations for combining the pixels,
                    // perform this any way you like!
                    // Here we just use simple weighted addition.
                    wgt1 = w1 * (alpha1 / 255.0);
                    wgt2 = w2 * (alpha2 / 255.0);
                    redr = (int)(red1 * wgt1 + red2 * wgt2);
		    redr = (redr < 0)?(0):((redr>255)?(255):(redr));
                    greenr = (int)(green1 * wgt1 + green2 * wgt2);
		    greenr = (greenr < 0)?(0):((greenr>255)?(255):(greenr));
                    bluer = (int)(blue1 * wgt1 + blue2 * wgt2);
		    bluer =  (bluer < 0)?(0):((bluer>255)?(255):(bluer));
		    alphar = 255;

                    rp = (((((alphar << 8) + (redr & 0x0ff)) << 8) + (greenr & 0x0ff)) << 8) + (bluer & 0x0ff);

                    // save the pixel
                    results[rpi] = rp;
                }
            }
            return true;
        }

        /**
         * Simple approach to getting an image - just
         * create one using MemoryImageSource.
         */
        public Image getGeneratedImage() {
            Image ret;
            MemoryImageSource mis;
            if (results == null) {
                Frame dummy = new Frame();
                generate(dummy);
                dummy.dispose();
            }
            mis = new MemoryImageSource(rwid, rhgt, cm, results, 0, rwid);
            ret = Toolkit.getDefaultToolkit().createImage(mis);
            return ret;
        }

        /**
         * Call this to free up pixel storage allocated by
         * this ImageMerger object.
         */
        public void dispose() {
            results = null;
            return;
        }

    }


    public ImageCombiner(Image i1, double w1, Image i2, double w2) {
        ccnt = 0;
        img1 = i1;
        img2 = i2;

        ic1 = new ImageDisplay(img1, true);
        ic1.getFrame().addWindowListener(this);
        ic1.placeAndShow(50,50);

        ic2 = new ImageDisplay(img2, true);
        ic2.getFrame().addWindowListener(this);
        ic2.placeAndShow(100,90);

        ImageMerger imerge = new ImageMerger(i1, i2);
        imerge.setWeights(w1, w2);
        imerge.generate(ic2);
        imgr = imerge.getGeneratedImage();
        imerge.dispose();

        icr = new ImageDisplay(imgr, true);
        icr.getFrame().addWindowListener(this);
        icr.placeAndShow(200,180);
    }

    public void windowClosing(WindowEvent we) {
        we.getWindow().hide();
        we.getWindow().dispose();
        ccnt++;
        if (ccnt >= 3) System.exit(0);
    }

    public static void main(String [] args) {
        if (args.length < 2) {
            System.err.println("Too few command-line arguments!");
            System.err.println("Usage: java ImageCombiner imagefile1 imagefile2");
            System.err.println("Usage: java ImageCombiner imagefile1 weight1 imagefile2 weight2");
            System.exit(0);
        }

	String imgf1, imgf2;
	double w1 = 0.5;
	double w2 = 0.5;
	if (args.length < 4) {
	    imgf1 = args[0];
	    imgf2 = args[1];
	}
	else {
	    imgf1 = args[0];
	    w1 = Double.parseDouble(args[1]);
	    imgf2 = args[2];
	    w2 = Double.parseDouble(args[3]);
	}

        Image i1 = Toolkit.getDefaultToolkit().createImage(imgf1);
        Image i2 = Toolkit.getDefaultToolkit().createImage(imgf2);

        if (i1 == null) {
            System.err.println("Could not get image from " + imgf1);
            System.exit(1);
        }
        if (i2 == null) {
            System.err.println("Could not get image from " + imgf2);
            System.exit(2);
        }

        ImageCombiner icom = new ImageCombiner(i1, w1, i2, w2);
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产日韩av| 91在线精品一区二区三区| 国产久卡久卡久卡久卡视频精品| 成人免费av网站| 日韩午夜小视频| 一区二区在线看| 国产.欧美.日韩| 欧美大片在线观看| 亚洲成人免费在线| 色菇凉天天综合网| 日本一区二区综合亚洲| 久久99热狠狠色一区二区| 欧美日韩一区二区在线观看| 国产精品高潮呻吟| 国产成人av电影免费在线观看| 91麻豆精品国产91久久久使用方法 | 日韩一区国产二区欧美三区| 亚洲欧洲综合另类在线| 国产麻豆精品视频| 精品国产免费人成电影在线观看四季 | 亚洲欧洲精品一区二区三区不卡| 精品一区二区三区影院在线午夜| 在线观看91视频| 国产精品电影院| 国产**成人网毛片九色| 久久久久国色av免费看影院| 奇米影视在线99精品| 欧美三级午夜理伦三级中视频| 亚洲欧美视频在线观看| 色综合网色综合| 亚洲精品视频免费观看| 色综合久久久久久久久| 综合分类小说区另类春色亚洲小说欧美 | 91影院在线观看| 国产精品视频观看| 丁香天五香天堂综合| 久久久电影一区二区三区| 久久超碰97人人做人人爱| 日韩欧美亚洲国产精品字幕久久久| 天天色综合天天| 8x8x8国产精品| 免费亚洲电影在线| 欧美不卡一区二区| 国产成人精品亚洲午夜麻豆| 国产日韩欧美亚洲| av中文字幕不卡| 一级日本不卡的影视| 欧美美女bb生活片| 日韩制服丝袜av| 欧美一区二区三区系列电影| 久久成人免费网站| 国产精品色婷婷久久58| 色先锋资源久久综合| 亚洲一级二级三级在线免费观看| 欧美私人免费视频| 麻豆91在线看| 国产精品美女久久久久aⅴ| 色婷婷综合在线| 日韩成人午夜精品| 国产欧美日韩在线看| 一本色道a无线码一区v| 日韩电影网1区2区| 中文一区在线播放| 欧美视频日韩视频在线观看| 美女视频网站黄色亚洲| 中文字幕一区日韩精品欧美| 欧美性色黄大片手机版| 国内精品伊人久久久久av影院| 日本一区二区三区dvd视频在线| 色婷婷狠狠综合| 精品午夜久久福利影院| 亚洲六月丁香色婷婷综合久久 | 免费看欧美美女黄的网站| 国产色婷婷亚洲99精品小说| 欧美在线视频你懂得| 久草在线在线精品观看| 亚洲日本在线a| 精品国产乱码久久| 在线视频观看一区| 国产一区二区不卡在线| 午夜欧美在线一二页| 欧美激情中文字幕| 日韩西西人体444www| 色嗨嗨av一区二区三区| 高清在线成人网| 久久不见久久见免费视频1| 亚洲人成在线播放网站岛国| 久久免费看少妇高潮| 欧美三级在线视频| 色伊人久久综合中文字幕| 成人小视频在线| 精品制服美女丁香| 午夜一区二区三区在线观看| 国产精品毛片大码女人| 久久亚洲精品小早川怜子| 欧美精品丝袜中出| 色94色欧美sute亚洲线路一ni| 国产宾馆实践打屁股91| 黄色小说综合网站| 精品在线播放免费| 青青草成人在线观看| 亚洲国产欧美另类丝袜| 亚洲特级片在线| 国产精品乱人伦中文| 久久久不卡影院| 久久蜜桃香蕉精品一区二区三区| 欧美成人精品高清在线播放 | 精油按摩中文字幕久久| 日韩精品欧美成人高清一区二区| 一区二区欧美在线观看| 一区二区三区不卡视频| 亚洲综合一区在线| 一区二区不卡在线视频 午夜欧美不卡在| 中文字幕中文字幕一区| 国产精品大尺度| 国产精品久久午夜夜伦鲁鲁| 国产精品盗摄一区二区三区| 亚洲人被黑人高潮完整版| 亚洲欧洲日韩av| 亚洲视频图片小说| 亚洲激情男女视频| 一区二区三区国产精华| 一二三区精品视频| 午夜视频一区二区三区| 亚洲午夜精品久久久久久久久| 日韩理论片中文av| 亚洲精选在线视频| 午夜亚洲国产au精品一区二区| 日韩国产欧美在线播放| 理论电影国产精品| 国产精品一区二区久久精品爱涩| 国产一区二区久久| av亚洲精华国产精华| 在线观看日韩电影| 日韩欧美中文字幕制服| 国产欧美精品一区| 国产精品美女久久久久av爽李琼| 亚洲天堂av老司机| 日韩电影免费在线观看网站| 国产在线播放一区二区三区| 91视频你懂的| 欧美一级理论片| 国产农村妇女精品| 亚洲图片欧美色图| 精品一区二区三区不卡| 高清视频一区二区| 欧美丰满嫩嫩电影| 国产精品午夜免费| 亚洲第一福利一区| 国产美女精品在线| 欧美视频一区二区三区在线观看| 日韩欧美中文一区| 国产精品久久久久久久久果冻传媒 | 蜜臀av性久久久久蜜臀aⅴ流畅| 国产麻豆精品一区二区| 欧美四级电影网| 国产欧美一区二区三区鸳鸯浴| 亚洲自拍偷拍图区| 国产精品夜夜爽| 555www色欧美视频| 亚洲精品伦理在线| 国产一区二区三区在线看麻豆| 91首页免费视频| 国产欧美日韩在线| 久久爱另类一区二区小说| 色婷婷综合激情| 中文一区二区在线观看| 日本女人一区二区三区| 粉嫩aⅴ一区二区三区四区五区 | 国产无人区一区二区三区| 亚洲国产视频a| 成人精品在线视频观看| 日韩欧美中文一区二区| 亚洲午夜免费电影| 色久优优欧美色久优优| 中文字幕亚洲区| 成人综合日日夜夜| 欧美精品一区在线观看| 日韩和欧美一区二区| 在线一区二区视频| 亚洲三级小视频| 波多野结衣视频一区| 久久午夜色播影院免费高清| 日韩av电影天堂| 欧美日韩三级视频| 亚洲影院理伦片| 91啦中文在线观看| 国产精品不卡在线| 成人美女在线视频| 中文字幕一区二区在线播放| 国产精品1区2区| 久久蜜桃av一区二区天堂| 蜜桃视频一区二区| 欧美精品高清视频| 日韩精品乱码免费| 日韩欧美国产成人一区二区| 久久成人综合网| 国产亚洲成年网址在线观看| 精品一区二区三区不卡 | 亚洲精品久久久蜜桃|