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

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

?? object2d.java

?? 計算機基本圖形的生成
?? JAVA
字號:
package graphics0;

import java.awt.*;
import java.awt.image.*;
import java.awt.color.*;
import java.util.Stack;

/**
 * <p>Title: computer graphics </p>
 * <p>Description: homeworks</p>
 * <p>Copyright: Copyright (c) 2004 </p>
 * <p>Company: shu</p>
 * @author dxf
 * @version 1.0
 */
abstract class Object2D {
  protected int LineWidth = 1;
  protected Color ForeColor = Color.BLACK, BackgroundColor = Color.WHITE;
  protected int LineStyle = 0;
  protected boolean Filled;

  static int cWidth = 1024;
  static int cHeight = 768;
  static int LEFT= 1,RIGHT= 2,BOTTOM= 4,TOP= 8;
  static String[] sLineStyle = {
      "11110000", "11111111", "11001100"};
  static int DemoWidth = 5;

  public void SetLineWidth(int width) {
    LineWidth = width;
  }

  public int GetLineWidth() {
    return (LineWidth);
  }

  public void SetFilled(boolean b) {
    Filled = b;
  }

  public boolean GetFilled() {
    return (Filled);
  }

  public void SetLineStyle(int l) {
    LineStyle = l;
  }

  public int GetLineStyle() {
    return (LineStyle);
  }

  public void SetForeColor(Color c1) {
    ForeColor = c1;
  }

  public Color GetForeColor() {
    return (ForeColor);
  }

  public void SetBackgroundColor(Color c1) {
    BackgroundColor = c1;
  }

  public Color GetBackgroundColor() {
    return (BackgroundColor);
  }

////////////////////////////////////////////////////////////////////////////
  static public void FloodFill4(int x, int y, Color fc, Color bc,
                                BufferedImage b, Graphics2D g) {
    if (! ( (x < 0) || (y < 0) || (x >= cWidth) || (y >= cHeight))) {
      if ( (b.getRGB(x, y) != fc.getRGB()) &&
          (b.getRGB(x, y) != bc.getRGB())) {
        g.setColor(bc);
        g.drawLine(x, y, x, y);
        FloodFill4(x, y + 1, fc, bc, b, g);
        FloodFill4(x, y - 1, fc, bc, b, g);
        FloodFill4(x - 1, y, fc, bc, b, g);
        FloodFill4(x + 1, y, fc, bc, b, g);
      }
    }
  }

///////////////////////////////////////////////////////////////////////////////
  static public void FloodFill8(int x, int y, Color fc, Color bc,
                                BufferedImage b, Graphics2D g) {
    if (! ( (x < 0) || (y < 0) || (x >= cWidth) || (y >= cHeight))) {
      if ( (b.getRGB(x, y) != fc.getRGB()) &&
          (b.getRGB(x, y) != bc.getRGB())) {
        g.setColor(bc);
        g.drawLine(x, y, x, y);
        FloodFill4(x, y + 1, fc, bc, b, g);
        FloodFill4(x, y - 1, fc, bc, b, g);
        FloodFill4(x - 1, y, fc, bc, b, g);
        FloodFill4(x + 1, y, fc, bc, b, g);

        FloodFill4(x - 1, y - 1, fc, bc, b, g);
        FloodFill4(x + 1, y - 1, fc, bc, b, g);
        FloodFill4(x - 1, y + 1, fc, bc, b, g);
        FloodFill4(x + 1, y + 1, fc, bc, b, g);

      }
    }
  }

/////////////////////////////////////////////////////////////////////////////////
  static public void ScanLineFill4(int x, int y, int iColor ,Color bc,
                                   BufferedImage b, Graphics2D g) {
    int xl, xr, i;
    boolean spanNeedFill;
    Point pt = new Point(0, 0);
    Stack stack0 = new Stack();
    Point p0;

    stack0.empty();
    pt.x = x;
    pt.y = y;

    stack0.push(pt); //將前面生成的區段壓入堆棧

    while (!stack0.isEmpty()) { //檢查堆棧狀態,空返回F,否則返回T
      pt = (Point) stack0.pop(); //取堆棧頂元素
      y = pt.y;
      x = pt.x;
      while (b.getRGB(x, y) == iColor) {
        g.setColor(bc);
        g.drawLine(x, y, x, y);
        x++;
      }
      xr = x - 1;
      x = pt.x - 1;

      while (b.getRGB(x, y) == iColor) { //向左填充
        g.setColor(bc);
        g.drawLine(x, y, x, y);
        x--;
      }
      xl = x + 1;

      x = xl;
      y = y + 1; //處理上面一條掃描線

      while (x < xr) {
        spanNeedFill = false;

        while (b.getRGB(x, y) == iColor) {
          spanNeedFill = true;         x++;
        }

        if (spanNeedFill) {
          p0 = new Point(0, 0);
          p0.x = x - 1;          p0.y = y;
          stack0.push(p0);
          spanNeedFill = false;
        }

        while (b.getRGB(x, y) != iColor && x < xr)  x++;
      } //End of while(x<xr)

      //處理下面一條掃描線
      x = xl;
      y = y - 2;
      while (x < xr) {
        spanNeedFill = false;

        while (b.getRGB(x, y) == iColor) {
          spanNeedFill = true;        x++;
        }

        if (spanNeedFill) {
          p0 = new Point(0, 0);
          p0.x = x - 1;          p0.y = y;
          stack0.push(p0);
          spanNeedFill = false;
        }

        while (b.getRGB(x, y) != iColor && x < xr)       x++;

      } //End of while(x<xr)

    } //End of while(!isstackempty())

  }
////////////////////////////////////////////////////////////////////////////////
//求兩點間距離
  static public float distance2(float x1,float y1,float x2,float y2) {
    return ((x1 - x2)*(x1 - x2)+(y1 - y2)*(y1 - y2));

  }

//////////////////////////////////////////////////////////////////////////////
  //lint mid clip
  static public void Mid_LineClip(Point lsp,Point lep,
                                 Point wsp,Point wep,
                                  Color bk,Graphics2D g){
    int code1, code2;
    int XL, XR, YB, YT;
    int  x1 = lsp.x, x2 = lep.x, y1 = lsp.y, y2 = lep.y;

    g.setColor(bk);
    if (wsp.x > wep.x) {
      XR = wsp.x; XL = wep.x;
    }
    else {
      XR = wep.x;  XL = wsp.x;
    }
    if (wsp.y > wep.y) {
      YB = wsp.y;  YT = wep.y;
    }
    else {
      YB = wep.y; YT = wsp.y;
    }

    code1 = encode(x1, y1, XL, XR, YB, YT);
    code2 = encode(x2, y2, XL, XR, YB, YT);

    if ((code1&code2) !=0) {//顯然不可見
      x1=x2=y1=y2=0;
    }
    else if ((code1==0)&&(code2==0)) {//顯然可見
      g.drawLine(x1,y1,x2,y2);
    }
    else {//其它
      Point sp = new Point(0,0),ep = new Point(0,0);
      sp = midPoint( x1, y1, x2, y2, XL,XR,YB,YT) ;
      ep = midPoint( x2, y2, x1, y1, XL,XR,YB,YT) ;
      g.drawLine(sp.x,sp.y,ep.x,ep.y);
   }

  }
///////////////////////////////////////////////////////////////////////////
  //midpoint
  static Point midPoint(float x1,float y1,float x2,float y2,
                        int XL,int XR,int YB,int YT) {

    float xn,yn;
    int code1, code2;
    float delta = (float)0.25;
    while (true){
      xn = (x1 + x2) / 2;
      yn = (y1 + y2) / 2;

      if (distance2(xn, yn, x2, y2) < delta) {
        break;
      }
      else {
        code1 = encode(x1, y1, XL, XR, YB, YT);
        code2 = encode(xn, yn, XL, XR, YB, YT);
        if ( (code1 & code2) != 0) {
          x1 = xn; y1 =yn;
        }
        else {
          x2 =xn; y2 = yn;
        }
      }
    } //end of while(true)
    Point p0 = new Point(0,0);
    p0.x = Math.round(xn); p0.y = Math.round(yn);
    return (p0);
  }
////////////////////////////////////////////////////////////////////////////
  static int encode(int x,int y,int XL,int XR,int YB,int YT) {
    int c=0;
    if(x<XL) c|=LEFT;
    if(x>XR) c|=RIGHT;
    if(y>YB) c|=BOTTOM;
    if(y<YT) c|=TOP;
    return c ;
}
////////////////////////////////////////////////////////////////////////////
  static int encode(float x,float y,int XL,int XR,int YB,int YT) {
    int c=0;
    if(x<XL) c|=LEFT;
    if(x>XR) c|=RIGHT;
    if(y>YB) c|=BOTTOM;
    if(y<YT) c|=TOP;
    return c ;
}

//////////////////////////////////////////////////////////////////////////////
  //line cs clip
  static public void CS_LineClip(Point lsp,Point lep,
                                 Point wsp,Point wep,
                                 Color bk,Graphics2D g){
    int code1,code2,code;
    int XL,XR,YB,YT,x=0,y=0;
    int x1=lsp.x,x2=lep.x,y1=lsp.y,y2=lep.y;
    if (wsp.x>wep.x) {
      XR=wsp.x;XL=wep.x;
    }
    else {
      XR=wep.x;XL=wsp.x;
    }
    if (wsp.y>wep.y) {
      YB=wsp.y;YT=wep.y;
    }
    else {
      YB=wep.y;YT=wsp.y;
    }

    code1= encode(x1,y1,XL,XR,YB,YT);
    code2= encode(x2,y2,XL,XR,YB,YT);

     while(code1!=0 ||code2!=0)
     {
       if ((code1&code2) !=0) {
         x1=x2=y1=y2=0;
         break;
       }

       code = code1;

       if(code1==0) code = code2;

       if((LEFT&code) !=0)  {
         x=XL;
         y=y1+(y2-y1)*(XL-x1)/(x2-x1);

       }
       else if ((RIGHT&code) !=0) {
           x=XR;
           y=y1+(y2-y1)*(XR-x1)/(x2-x1);
         }
       else if((BOTTOM&code) !=0) {
         y=YB;
         x=x1+(x2-x1)*(YB-y1)/(y2-y1);
        }
       else if((TOP & code) !=0)  {
         y=YT;
         x=x1+(x2-x1)*(YT-y1)/(y2-y1);
        }

        if(code ==code1)   {
          x1=x; y1=y;
          code1 =encode(x,y,XL,XR,YB,YT);
        }
        else    {
          x2=x;y2=y;
          code2 =encode(x,y,XL,XR,YB,YT);
        }

     }

     g.setColor(bk);
     g.drawLine(x1,y1,x2,y2);

  }

  abstract void draw(Graphics Canvas);

  abstract void drawDemo(Graphics Canvas);

  abstract boolean IsInside(Point p0);

  abstract void scale(double sx, double sy);
  abstract void rotate(double theta, int x, int y) ;
  abstract void translate(int x, int y);

  public Object2D() {
  }

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区在线视频| 日本道免费精品一区二区三区| 亚洲欧美日韩小说| 日本欧美一区二区在线观看| 国产99一区视频免费| 欧美日韩一级二级| 亚洲色图欧洲色图| 成人福利在线看| 久久综合久久久久88| 日韩电影免费在线看| 欧美亚洲动漫制服丝袜| 亚洲三级小视频| 99久久精品国产精品久久| 欧美国产一区二区| 国产精品99久久久久久有的能看| 欧美一级一区二区| 男女视频一区二区| 欧美老女人在线| 人禽交欧美网站| 日韩网站在线看片你懂的| 午夜婷婷国产麻豆精品| 欧美日韩国产不卡| 日韩电影免费在线看| 日韩一卡二卡三卡国产欧美| 日韩国产欧美在线观看| 91精品欧美福利在线观看| 日韩专区欧美专区| 日韩欧美成人激情| 国产一区二区成人久久免费影院| 久久综合九色综合欧美亚洲| 国产一区二区调教| 国产精品久久久久一区| 99国产精品一区| 亚洲在线中文字幕| 91精品国产高清一区二区三区| 日韩中文欧美在线| 久久夜色精品一区| 99视频在线精品| 亚洲一区二区中文在线| 制服丝袜亚洲播放| 国产自产视频一区二区三区| 中文字幕乱码日本亚洲一区二区 | 美女网站色91| 亚洲精品在线免费观看视频| 国产精品一区二区91| 国产精品国产三级国产普通话99| 色综合中文字幕国产 | 久久精品免费观看| 日日摸夜夜添夜夜添国产精品 | 国产精品传媒视频| 欧美性受xxxx黑人xyx性爽| 蜜桃av一区二区三区电影| 久久精品一区二区三区四区| 99久久伊人网影院| 日本亚洲电影天堂| 国产精品久久毛片av大全日韩| 在线一区二区三区| 激情av综合网| 一区二区三区在线视频免费| 日韩一卡二卡三卡四卡| a在线播放不卡| 美女精品自拍一二三四| 国产精品久久精品日日| 欧美一区二区三区人| 成人黄色777网| 日韩av网站免费在线| 中文字幕一区二区三| 日韩久久免费av| 色综合久久久久综合体| 免费成人小视频| 怡红院av一区二区三区| 精品福利av导航| 欧美视频三区在线播放| 成人免费毛片高清视频| 日本不卡高清视频| 一区二区三区在线影院| 欧美国产精品一区二区| 欧美一级在线免费| 欧美性猛片aaaaaaa做受| 国产成人久久精品77777最新版本| 亚洲福利国产精品| 亚洲人xxxx| 国产精品水嫩水嫩| 久久综合九色综合97_久久久| 91黄色在线观看| 成人aaaa免费全部观看| 激情久久久久久久久久久久久久久久| 亚洲午夜私人影院| 亚洲啪啪综合av一区二区三区| 久久精品视频一区二区| 欧美大尺度电影在线| 欧美日韩1区2区| 欧美亚洲动漫精品| 26uuu成人网一区二区三区| 在线播放/欧美激情| 欧洲精品在线观看| 91美女福利视频| 不卡的av网站| www.在线欧美| 粉嫩aⅴ一区二区三区四区 | 久久99国产精品免费| 亚洲国产另类精品专区| 夜夜嗨av一区二区三区网页| 亚洲伦理在线精品| 自拍偷在线精品自拍偷无码专区 | 99久久精品国产精品久久| 国产v综合v亚洲欧| 东方欧美亚洲色图在线| 成人福利在线看| av资源网一区| 色婷婷综合久久久久中文一区二区 | 97国产精品videossex| 92精品国产成人观看免费| 国产成人午夜精品影院观看视频 | 粉嫩高潮美女一区二区三区| 国产剧情在线观看一区二区| 国产乱子伦一区二区三区国色天香| 日本午夜一区二区| 九九视频精品免费| 国内精品伊人久久久久av一坑 | 久久国产尿小便嘘嘘尿| 国模套图日韩精品一区二区| 国产精品一区二区三区99| 成人一区二区三区在线观看| 成人激情免费视频| 日本丶国产丶欧美色综合| 欧美三级电影一区| 日韩一区二区三区在线视频| 久久综合色鬼综合色| 黄色资源网久久资源365| 粉嫩一区二区三区性色av| 97精品国产露脸对白| 欧美日韩成人综合| 欧美精品一区二区三区久久久| 中文字幕精品—区二区四季| 亚洲综合精品自拍| 中文字幕一区在线| 日韩av在线免费观看不卡| 国产高清无密码一区二区三区| 不卡的av中国片| 欧美军同video69gay| 国产无一区二区| 亚洲成人av电影在线| 国产一区二区三区免费播放| 一本色道久久综合亚洲aⅴ蜜桃| 欧美精品久久天天躁| 国产女人水真多18毛片18精品视频| 亚洲精品老司机| 久久99精品久久久久久| 一本一道综合狠狠老| 日韩一区二区三区视频| 国产精品国产馆在线真实露脸| 天堂va蜜桃一区二区三区| 国产suv精品一区二区三区| 欧美日韩综合不卡| 国产精品伦理一区二区| 蜜桃视频在线观看一区| 91福利精品视频| 国产欧美日韩精品一区| 日本欧美肥老太交大片| 色综合天天综合网国产成人综合天| 欧美成人video| 亚洲一区二区在线视频| 成人av资源站| 久久综合资源网| 日本欧美大码aⅴ在线播放| 一本大道久久a久久精品综合| 精品99999| 日韩国产精品大片| 欧美综合天天夜夜久久| 国产精品国产三级国产a| 国产综合色在线| 日韩亚洲欧美综合| 亚洲gay无套男同| 色婷婷激情一区二区三区| 国产精品美女久久久久久久久久久 | 国产一区激情在线| 3d成人h动漫网站入口| 亚洲免费伊人电影| 91在线观看地址| 国产欧美中文在线| 国产一区二区三区免费播放 | 悠悠色在线精品| 93久久精品日日躁夜夜躁欧美| 国产欧美精品一区aⅴ影院 | 国产综合久久久久久鬼色| 欧美一级一级性生活免费录像| 亚洲18女电影在线观看| 欧美日韩激情在线| 亚洲国产精品综合小说图片区| 91电影在线观看| 亚洲电影一区二区| 欧美日韩亚洲综合一区二区三区 | 欧美一区二区三区视频免费播放| 亚洲v精品v日韩v欧美v专区| 欧美三级中文字| 亚洲.国产.中文慕字在线| 欧美人与性动xxxx| 蜜桃在线一区二区三区| 日韩美一区二区三区|