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

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

?? viewcanvas.java

?? 用java語言編寫的日歷源碼
?? JAVA
字號:
package at.ac.uni_linz.tk.vchat;

import at.ac.uni_linz.tk.vchat.engine.*;

import java.awt.*;
import java.awt.event.*;
import java.util.*;


/**
 * Displayes the User's three-dimensional view on the Room, other Users and their
 * messages.
 *
 * @author      Arno Huetter
 * (C)opyright by the Institute for Computer Science, Telecooperation Department, University of Linz
 */

public class ViewCanvas extends Canvas implements Runnable {

  private static final int ROOM_HEIGHT = 30;
  private static final int SPACE_BUFFER = 5;
  private static final int GRID_SIZE = 10;

  private Image bufferImage;

  private ChatApplet chatApplet;

  private Object3D world;
  private Light light;
  private Plane3D frustum[];

/**
 * Constructs the ViewCanvas.
 *
 * @param chatParam      the ChatApplet which administrates the
 *                                Users
 * @param repositoryParam         the ChatRepository, where commonly used objects
 *                                are being stored
 */

  public ViewCanvas(ChatApplet chatAdministratorParam) {
    boolean toggle = true;
    chatApplet = chatAdministratorParam;

    world = new Object3D();
    light = new Light();
    frustum = new Plane3D[5];

    Vertex3D avertex[] = new Vertex3D[4];
    createFrustum();
    light = new Light(-2, 2, -2);
    for (int i = -SPACE_BUFFER; i < ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER; i+=GRID_SIZE) {
      for (int j = -SPACE_BUFFER; j < ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER; j+=GRID_SIZE) {
        if (toggle) {
          Polygon3D s = new Polygon3D();
          s.addPoint(new Vertex3D(i, 0, j));
          s.addPoint(new Vertex3D(i, 0, j + GRID_SIZE));
          s.addPoint(new Vertex3D(i + GRID_SIZE, 0, j + GRID_SIZE));
          s.addPoint(new Vertex3D(i + GRID_SIZE, 0, j));
          s.normVec = new Vertex3D(0, 1, 0);
          s.col = Color.white;
          world.add(s);
        }
        toggle=!toggle;
      }
      toggle=!toggle;
    }
    Polygon3D p = new Polygon3D();
    p.addPoint(new Vertex3D(-SPACE_BUFFER, 0, -SPACE_BUFFER));
    p.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, 0, -SPACE_BUFFER));
    p.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, 0, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    p.addPoint(new Vertex3D(-SPACE_BUFFER, 0, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    p.normVec = new Vertex3D(0, 1, 0);
    p.col = Color.lightGray;
    world.add(p);

    world.add(new Cube3D(new Vertex3D(-SPACE_BUFFER, 0, -SPACE_BUFFER), new Vertex3D(0, ROOM_HEIGHT, 0), Color.red));
    world.add(new Cube3D(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, 0, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER), new Vertex3D(ChatRepository.ROOM_DIMENSION.width, ROOM_HEIGHT, ChatRepository.ROOM_DIMENSION.height), Color.blue));
    world.add(new Cube3D(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, 0, -SPACE_BUFFER), new Vertex3D(ChatRepository.ROOM_DIMENSION.width, ROOM_HEIGHT, 0), Color.yellow));
    world.add(new Cube3D(new Vertex3D(-SPACE_BUFFER, 0, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER), new Vertex3D(0, ROOM_HEIGHT, ChatRepository.ROOM_DIMENSION.height), Color.green));

    Polygon3D w;
    Color wCol = new Color (239, 239, 239);
    w = new Polygon3D();
    w.addPoint(new Vertex3D(-SPACE_BUFFER, 0, -SPACE_BUFFER));
    w.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, 0, -SPACE_BUFFER));
    w.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, ROOM_HEIGHT, -SPACE_BUFFER));
    w.addPoint(new Vertex3D(-SPACE_BUFFER, ROOM_HEIGHT, -SPACE_BUFFER));
    w.normVec = new Vertex3D(0, 0, 1);
    w.col = wCol;
    world.add(w);
    w = new Polygon3D();
    w.addPoint(new Vertex3D(-SPACE_BUFFER, 0, -SPACE_BUFFER));
    w.addPoint(new Vertex3D(-SPACE_BUFFER, 0, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    w.addPoint(new Vertex3D(-SPACE_BUFFER, ROOM_HEIGHT, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    w.addPoint(new Vertex3D(-SPACE_BUFFER, ROOM_HEIGHT, -SPACE_BUFFER));
    w.normVec = new Vertex3D(1, 0, 0);
    w.col = wCol;
    world.add(w);
    w = new Polygon3D();
    w.addPoint(new Vertex3D(-SPACE_BUFFER, 0, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    w.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width, 0, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    w.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width, ROOM_HEIGHT, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    w.addPoint(new Vertex3D(-SPACE_BUFFER, ROOM_HEIGHT, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    w.normVec = new Vertex3D(0, 0, -1);
    w.col = wCol;
    world.add(w);
    w = new Polygon3D();
    w.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, 0,  -SPACE_BUFFER));
    w.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, 0, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    w.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, ROOM_HEIGHT, ChatRepository.ROOM_DIMENSION.height + SPACE_BUFFER));
    w.addPoint(new Vertex3D(ChatRepository.ROOM_DIMENSION.width + SPACE_BUFFER, ROOM_HEIGHT, -SPACE_BUFFER));
    w.normVec = new Vertex3D(-1, 0, 0);
    w.col = wCol;
    world.add(w);

  }

  public Dimension getPreferredSize() {
    if (getParent() == null) {
      return super.getPreferredSize();
    }
    else {
      return new Dimension(getParent().getSize().width - getParent().getInsets().left - getParent().getInsets().right, getParent().getSize().height - getParent().getInsets().top - getParent().getInsets().bottom);
    }
  }


/**
 * Updates the ViewCanvas. Clearing the ViewCanvas is not necessary, as it uses
 * double-buffering.
 *
 * @param g       the graphics context
 */

  public void update(Graphics g) {
    paint(g);
  }

/**
 * Paints the ViewCanvas.
 *
 * @param g       the graphics context
 */

  public synchronized void paint(Graphics g) {
    Object3D clippedworld;
    Graphics bufferGraphics;
    Image image, userBackPortrait;

    Hashtable userTable;
    User user, currentUser;
    Vector vecCurrentSituation;
    int distance, angle;
    int canvasWidth, canvasHeight;

    Point pntPosition;

    HistoryEntry histEntry;

    currentUser = chatApplet.getCurrentUser();
    pntPosition = currentUser.getPosition();

    canvasWidth = getSize().width;
    canvasHeight = getSize().height;

    if (bufferImage == null || bufferImage.getWidth(this) != canvasWidth || bufferImage.getHeight(this) != canvasHeight)
      bufferImage = createImage(canvasWidth, canvasHeight);

    bufferGraphics = bufferImage.getGraphics();

    vecCurrentSituation = chatApplet.historyMode() ? chatApplet.getHistoryEntryVector(chatApplet.getHistoryDate()) : chatApplet.getCurrentSituationVector();

    for (int i = 0; i < vecCurrentSituation.size(); i++) {
      user = chatApplet.getUser(((HistoryEntry)vecCurrentSituation.elementAt(i)).userId);
      if (user == null || !chatApplet.inVisualRange(currentUser.getId(), ((HistoryEntry)vecCurrentSituation.elementAt(i)).position)) {
        vecCurrentSituation.removeElementAt(i);
        i--;
      }
    }
    Vector tmpVec = new Vector(vecCurrentSituation.size());
    /* Heap-Sort - should be enough for this purpose, not too much overhead... */
    for (int i = 0; i < vecCurrentSituation.size(); i++) {
      int dist = 0;
      int delta = tmpVec.size() / 2;
      int j = delta;
      boolean done = false;
      while (!done) {
        dist = chatApplet.getDistance(currentUser.getId(), ((HistoryEntry)vecCurrentSituation.elementAt(i)).position);
        delta = Math.max(1, delta / 2);
        if ((j - delta) >= 0 && dist > chatApplet.getDistance(currentUser.getId(), ((HistoryEntry)tmpVec.elementAt(j - 1)).position)) {
          j -= delta;
        }
        else if ((j + delta) <= tmpVec.size() && dist < chatApplet.getDistance(currentUser.getId(), ((HistoryEntry)tmpVec.elementAt(j)).position)) {
          j += delta;
        }
        else {
          done = true;
        }
      }
      tmpVec.insertElementAt(vecCurrentSituation.elementAt(i), j);
    }

    vecCurrentSituation = tmpVec;

    bufferGraphics.setColor(Color.white);
    bufferGraphics.fillRect(0, 0, canvasWidth, canvasHeight);
    ViewPoint viewPoint;
    Object3D viewedWorld = getTransformedWorld(viewPoint = new ViewPoint(new Vertex3D(pntPosition.x, ChatRepository.USER_HEIGHT - 1, pntPosition.y), new Orientation(0, currentUser.getHeading() + 90, 0)));

    clippedworld = viewedWorld.clip(frustum);
    clippedworld.bringToScreen(getSize().width, getSize().height, light, true);
    clippedworld.orderByDepth();
    clippedworld.paint(bufferGraphics);

    for (int i = 0; i < vecCurrentSituation.size(); i++) {
      histEntry = (HistoryEntry)vecCurrentSituation.elementAt(i);
      user = chatApplet.getUser(histEntry.userId);
      if (user != null && histEntry.userId != chatApplet.getCurrentUserId()) {
        image = chatApplet.getUserAvatar(user.getId(), ((HistoryEntry)vecCurrentSituation.elementAt(i)).mood);
        Object3D userObj = new Object3D();
        Polygon3D polyWorld = new Polygon3D();
        int width = image.getWidth(this) * ChatRepository.USER_HEIGHT / image.getWidth(this);
        polyWorld.addPoint(new Vertex3D(histEntry.position.x - width / 2, 0, histEntry.position.y));
        polyWorld.addPoint(new Vertex3D(histEntry.position.x - width / 2, ChatRepository.USER_HEIGHT, histEntry.position.y));
        polyWorld.addPoint(new Vertex3D(histEntry.position.x + width / 2, ChatRepository.USER_HEIGHT, histEntry.position.y));
        polyWorld.addPoint(new Vertex3D(histEntry.position.x + width / 2, 0, histEntry.position.y));

        Object3D littleWorld = new Object3D(getTransformedPoly(polyWorld, viewPoint)).clip(frustum);

        littleWorld = littleWorld.clip(frustum);
        littleWorld.bringToScreen(getSize().width, getSize().height, light, true);
        // littleWorld.paint(bufferGraphics);
        if (littleWorld.getNrOfPolygons() == 1) {
          Polygon3D poly = littleWorld.getPolygon(0);

          if (!chatApplet.inVisualRange(histEntry.position, histEntry.heading, currentUser.getPosition())) {
            image = chatApplet.getUserBackAvatar(user.getId());
          }

          new Image3D(poly, image, user.getName(), histEntry.text, user.getColor()).paint(bufferGraphics);
            if (chatApplet.historyMode() && histEntry.userId == chatApplet.getCurrentUserId()) {
              (new Balloon(new Rectangle(canvasWidth * 2 / 3, 10, canvasWidth * 1 / 3 - 10, canvasHeight - 20), histEntry.text, currentUser.getColor(), Balloon.FACING_LEFT)).paint(bufferGraphics);
            }
          }
        }
      }
      bufferGraphics.setColor(Color.black);
      bufferGraphics.setFont(ChatRepository.BOLD_FONT);
      bufferGraphics.drawString(chatApplet.getCurrentRoom().getName(), 10, getFontMetrics(getFont()).getMaxAscent() + 10);
      bufferGraphics.setFont(ChatRepository.STANDARD_FONT);

      g.drawImage(bufferImage, 0, 0, this);
    }

    private void createFrustum() {
      frustum[0] = new Plane3D();
      frustum[0].normVec = new Vertex3D(0.0D, -Math.sqrt(2D), Math.sqrt(2D));
      frustum[0].dist = 0.0D;
      frustum[1] = new Plane3D();
      frustum[1].normVec = new Vertex3D(-Math.sqrt(2D), 0.0D, Math.sqrt(2D));
      frustum[1].dist = 0.0D;
      frustum[2] = new Plane3D();
      frustum[2].normVec = new Vertex3D(Math.sqrt(2D), 0.0D, Math.sqrt(2D));
      frustum[2].dist = 0.0D;
      frustum[3] = new Plane3D();
      frustum[3].normVec = new Vertex3D(0.0D, Math.sqrt(2D), Math.sqrt(2D));
      frustum[3].dist = 0.0D;
      frustum[4] = new Plane3D();
      frustum[4].normVec = new Vertex3D(0.0D, 0.0D, 1.0D);
      frustum[4].dist = 2D;
    }

    private Polygon3D getTransformedPoly(Polygon3D poly, ViewPoint viewpoint) {
      Polygon3D myPoly = new Polygon3D(poly);
      myPoly.translate(new Vertex3D(-viewpoint.from.x, -viewpoint.from.y, -viewpoint.from.z));
      myPoly.rotate(viewpoint.orient);
      return myPoly;
    }

    private Object3D getTransformedWorld(ViewPoint viewpoint) {
      Object3D viewworld = new Object3D(world);
      viewworld.translate(new Vertex3D(-viewpoint.from.x, -viewpoint.from.y, -viewpoint.from.z));
      viewworld.rotate(viewpoint.orient);
      return viewworld;
    }

    public void run() {
    }



}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久婷婷二区次| 在线不卡的av| 免费观看成人鲁鲁鲁鲁鲁视频| 亚洲手机成人高清视频| 亚洲欧洲综合另类| 亚洲精品成人悠悠色影视| 亚洲男人天堂av网| 亚洲精品一二三四区| 一区二区三区在线播放| 亚洲小少妇裸体bbw| 亚洲成人免费看| 美腿丝袜亚洲一区| 成人妖精视频yjsp地址| 色综合天天综合色综合av | 国产精品麻豆久久久| 精品伦理精品一区| 日韩精品在线网站| 久久久久久综合| 亚洲日本在线a| 亚洲三级在线播放| 国产成人自拍网| 国产性色一区二区| 懂色中文一区二区在线播放| 欧美网站大全在线观看| 亚洲自拍偷拍九九九| 加勒比av一区二区| 欧美午夜不卡在线观看免费| 亚洲韩国精品一区| 日韩视频在线一区二区| 久久精品国产第一区二区三区| 精品一区二区三区免费播放| 成人网在线播放| 精品视频在线视频| 国产欧美精品一区二区色综合朱莉| 亚洲欧美国产三级| 精品一区二区免费| 在线视频一区二区三区| 精品国产一区a| 亚洲一区中文日韩| 国内成人自拍视频| 欧美日韩国产中文| 国产精品福利电影一区二区三区四区 | 亚洲精品久久7777| 久久国产视频网| 在线国产电影不卡| 国产欧美精品日韩区二区麻豆天美| 一区二区三区在线视频免费观看| 国产一区二区在线观看免费| 在线观看三级视频欧美| 日本一区免费视频| 久久99热狠狠色一区二区| 欧美私模裸体表演在线观看| 国产日韩精品久久久| 老司机精品视频线观看86| 91蝌蚪国产九色| 欧美激情综合在线| 国产精品一区二区久久不卡 | 舔着乳尖日韩一区| 91麻豆精品视频| 国产欧美日韩激情| 国产在线播精品第三| 日韩三级伦理片妻子的秘密按摩| 亚洲精品欧美激情| 91视频在线看| 亚洲人妖av一区二区| 国产成a人无v码亚洲福利| 欧美精品一区二区三区久久久| 性做久久久久久免费观看欧美| 99re免费视频精品全部| 亚洲国产精品99久久久久久久久 | 国产三级欧美三级| 久久精品噜噜噜成人88aⅴ| 欧美中文字幕久久| 一区二区成人在线观看| 色94色欧美sute亚洲线路二 | 欧美一级二级在线观看| 亚洲午夜久久久久久久久电影院| 成人一区二区在线观看| 国产精品高潮久久久久无| jvid福利写真一区二区三区| 最新久久zyz资源站| 91一区二区三区在线观看| 亚洲黄色在线视频| 欧美日韩精品一区二区在线播放| 亚洲成av人片一区二区三区| 日韩一区二区三区免费看 | 成人av在线资源| 国产精品青草久久| 色欧美片视频在线观看| 亚洲国产视频一区| 欧美成人高清电影在线| 国产精品一区二区久久精品爱涩| 国产精品久久免费看| 不卡一区二区中文字幕| 亚洲午夜免费电影| 精品入口麻豆88视频| 成人av动漫在线| 亚洲小少妇裸体bbw| 精品免费日韩av| 成人免费视频国产在线观看| 亚洲美女一区二区三区| 91精品啪在线观看国产60岁| 国产麻豆午夜三级精品| 一区二区三区四区在线播放| 欧美成人一区二区三区片免费| 国产成人一区在线| 91精品国产色综合久久不卡电影 | 不卡av在线网| 亚洲电影视频在线| 久久综合一区二区| 在线亚洲精品福利网址导航| 美国一区二区三区在线播放| 亚洲欧洲日产国产综合网| 欧美日韩国产精品自在自线| 久久精品国产精品亚洲精品| 亚洲日本一区二区三区| 精品国产1区二区| 欧美色老头old∨ideo| 国产suv精品一区二区三区| 图片区小说区国产精品视频| 国产校园另类小说区| 欧美一区日韩一区| 91蜜桃传媒精品久久久一区二区| 免费av网站大全久久| 亚洲乱码国产乱码精品精98午夜| 欧美成人伊人久久综合网| 色综合天天综合| 国产精品一区二区你懂的| 视频在线观看国产精品| 国产精品久久久久久久第一福利| 日韩免费高清电影| 欧美日韩情趣电影| 91在线观看下载| 国产91精品入口| 精品在线视频一区| 免费高清成人在线| 亚洲国产欧美日韩另类综合 | 欧美日韩精品免费观看视频| 91麻豆蜜桃一区二区三区| 成人永久免费视频| 国产精品自在欧美一区| 久热成人在线视频| 蜜桃91丨九色丨蝌蚪91桃色| 午夜视频久久久久久| 亚洲va国产天堂va久久en| 亚洲精品成人天堂一二三| 亚洲欧美一区二区三区国产精品| 国产喷白浆一区二区三区| 久久综合中文字幕| 久久品道一品道久久精品| 精品国产百合女同互慰| 精品国产电影一区二区| 337p日本欧洲亚洲大胆精品| 欧美精品一区二区三区四区| 久久网这里都是精品| 久久影院午夜片一区| 国产日韩欧美亚洲| 综合精品久久久| 亚洲视频电影在线| 亚洲一区二区综合| 亚洲一区二区视频| 日韩中文字幕亚洲一区二区va在线| 五月综合激情网| 青青草视频一区| 国产麻豆精品久久一二三| 国产999精品久久久久久绿帽| 成人黄页在线观看| 色综合欧美在线| 欧美另类videos死尸| 欧美不卡视频一区| 日本一区免费视频| 亚洲一区二区美女| 日本女优在线视频一区二区| 国模套图日韩精品一区二区 | 69堂国产成人免费视频| 精品国产一区二区精华| 亚洲国产精品成人久久综合一区 | 欧美丰满一区二区免费视频| 日韩欧美的一区二区| 国产欧美视频一区二区| 亚洲一区二区在线视频| 久久精品国产色蜜蜜麻豆| 成人综合在线网站| 欧美亚洲动漫制服丝袜| 亚洲精品一区二区三区香蕉| 自拍视频在线观看一区二区| 日韩av中文字幕一区二区| 成人开心网精品视频| 欧美日韩一区二区欧美激情 | 亚洲成av人片| 国产电影一区在线| 欧美日韩精品一区二区三区四区 | 99久久伊人精品| 日韩写真欧美这视频| 亚洲精品视频在线观看网站| 久久国产福利国产秒拍| 色猫猫国产区一区二在线视频| 日韩美女主播在线视频一区二区三区| 亚洲欧洲另类国产综合| 美国十次了思思久久精品导航|