當前位置: 首頁>>代碼示例>>Java>>正文


Java QuadCurve2D類代碼示例

本文整理匯總了Java中java.awt.geom.QuadCurve2D的典型用法代碼示例。如果您正苦於以下問題:Java QuadCurve2D類的具體用法?Java QuadCurve2D怎麽用?Java QuadCurve2D使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


QuadCurve2D類屬於java.awt.geom包,在下文中一共展示了QuadCurve2D類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: createTopTabShape

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
/**
 * Creates the shape for a top tab.
 *
 * @param x
 * @param y
 * @param w
 * @param h
 * @param rTop
 * @param addBottom
 *            if {@code false}, the bottom line below the tab will not be added to the shape
 * @return
 */
private static Path2D createTopTabShape(int x, int y, int w, int h, double rTop, boolean addBottom) {
	Path2D path = new Path2D.Double();
	path.append(new Line2D.Double(x, y + h - 1, x, y + rTop), true);

	QuadCurve2D curve = new QuadCurve2D.Double(x, y + rTop, x, y, x + rTop, y);
	path.append(curve, true);

	path.append(new Line2D.Double(x + rTop, y, x + w - rTop, y), true);

	curve = new QuadCurve2D.Double(x + w - rTop, y, x + w, y, x + w, y + rTop);
	path.append(curve, true);

	path.append(new Line2D.Double(x + w, y + rTop, x + w, y + h), true);

	if (addBottom) {
		path.append(new Line2D.Double(x + w, y + h - 1, x, y + h - 1), true);
	}
	return path;
}
 
開發者ID:transwarpio,項目名稱:rapidminer,代碼行數:32,代碼來源:TabbedPaneUI.java

示例2: createLeftTabShape

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
/**
 * Creates the shape for a left tab.
 *
 * @param x
 * @param y
 * @param w
 * @param h
 * @param rLeft
 * @param addSide
 *            if {@code false}, the closing side line right of the tab will not be added to the
 *            shape
 * @return
 */
private static Path2D createLeftTabShape(int x, int y, int w, int h, double rLeft, boolean addSide) {
	Path2D path = new Path2D.Double();
	path.append(new Line2D.Double(x + w, y + h, x + rLeft, y + h), true);

	QuadCurve2D curve = new QuadCurve2D.Double(x + rLeft, y + h, x, y + h, x, y + h - rLeft);
	path.append(curve, true);

	path.append(new Line2D.Double(x, y + h - rLeft, x, y + rLeft), true);

	curve = new QuadCurve2D.Double(x, y + rLeft, x, y, x + rLeft, y);
	path.append(curve, true);

	path.append(new Line2D.Double(x + rLeft, y, x + w, y), true);

	if (addSide) {
		path.append(new Line2D.Double(x + w, y, x + w, y + h - 1), true);
	}
	return path;
}
 
開發者ID:transwarpio,項目名稱:rapidminer,代碼行數:33,代碼來源:TabbedPaneUI.java

示例3: contains

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
/**
    * @see ring.gui.vis2.Visel#contains(double, double)
    */
public boolean contains(double x, double y) {
	if (shape instanceof QuadCurve2D) {
		QuadCurve2D curve = (QuadCurve2D) shape;
		
		return (
			Line2D.ptLineDist(
				curve.getX1(),
				curve.getY1(),
				curve.getCtrlX(),
				curve.getCtrlY(),
				x,
				y
			) < 5 || Line2D.ptLineDist(
				curve.getX2(),
				curve.getY2(),
				curve.getCtrlX(),
				curve.getCtrlY(),
				x,
				y
			) < 5
		);
	}
	return shape.contains(new Point2D.Double(x,y));
}
 
開發者ID:guilhebl,項目名稱:routerapp,代碼行數:28,代碼來源:CurvedLineVisel.java

示例4: getHorizontalParams

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
public static int getHorizontalParams(double c0, double cp0,
                                      double cp1, double c1,
                                      double ret[]) {
    if (c0 <= cp0 && cp0 <= cp1 && cp1 <= c1) {
        return 0;
    }
    c1 -= cp1;
    cp1 -= cp0;
    cp0 -= c0;
    ret[0] = cp0;
    ret[1] = (cp1 - cp0) * 2;
    ret[2] = (c1 - cp1 - cp1 + cp0);
    int numroots = QuadCurve2D.solveQuadratic(ret, ret);
    int j = 0;
    for (int i = 0; i < numroots; i++) {
        double t = ret[i];
        // No splits at t==0 and t==1
        if (t > 0 && t < 1) {
            if (j < i) {
                ret[j] = t;
            }
            j++;
        }
    }
    return j;
}
 
開發者ID:SunburstApps,項目名稱:OpenJSharp,代碼行數:27,代碼來源:Order3.java

示例5: createCoulombIcon

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
private static ImageIcon createCoulombIcon( Color color ) {
    final int w = 20;
    final int h = 20;
    BufferedImage bi = new BufferedImage( w, h, BufferedImage.TYPE_INT_ARGB );
    Graphics2D g2 = bi.createGraphics();
    g2.setRenderingHint( RenderingHints.KEY_ANTIALIASING, RenderingHints.VALUE_ANTIALIAS_ON );
    QuadCurve2D curve1 = new QuadCurve2D.Double();
    QuadCurve2D curve2 = new QuadCurve2D.Double();
    curve1.setCurve( 0, 4, 8, 5, 7, 16 );
    curve2.setCurve( 10, 16, 11, 5, 17, 4 );
    g2.setStroke( ICON_STROKE );
    g2.setPaint( color );
    g2.draw( curve1 );
    g2.draw( curve2 );
    return new ImageIcon( bi );
}
 
開發者ID:mleoking,項目名稱:PhET,代碼行數:17,代碼來源:BSWellComboBox.java

示例6: getHorizontalParams

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
public static int getHorizontalParams(double c0, double cp0,
			double cp1, double c1,
			double ret[]) {
		if (c0 <= cp0 && cp0 <= cp1 && cp1 <= c1) {
			return 0;
		}
		c1 -= cp1;
		cp1 -= cp0;
		cp0 -= c0;
		ret[0] = cp0;
		ret[1] = (cp1 - cp0) * 2;
		ret[2] = (c1 - cp1 - cp1 + cp0);
		int numroots = QuadCurve2D.solveQuadratic(ret, ret);
		int j = 0;
		for (int i = 0; i < numroots; i++) {
			double t = ret[i];
//			No splits at t==0 and t==1
			if (t > 0 && t < 1) {
				if (j < i) {
					ret[j] = t;
				}
				j++;
			}
		}
		return j;
	}
 
開發者ID:mickleness,項目名稱:pumpernickel,代碼行數:27,代碼來源:Order3X.java

示例7: getMinMax

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
private void getMinMax(double p1, double p2,
                       double p3, double p4,
                       double [] minMax) {
    if (p4 > p1){
        minMax[0] = p1; minMax[1] = p4;
    } else {
        minMax[0] = p4; minMax[1] = p1;
    }

    double c0 = 3*(p2-p1);
    double c1 = 6*(p3-p2);
    double c2 = 3*(p4-p3);
    double [] eqn = { c0, c1-2*c0, c2-c1+c0 };
    int roots = QuadCurve2D.solveQuadratic(eqn);
    for (int r=0; r<roots; r++) {
        double tv = eqn[r];
        if ((tv <= 0) || (tv >= 1)) continue;
        tv = ((1-tv)*(1-tv)*(1-tv)*p1 +
                3*tv*(1-tv)*(1-tv)*p2 +
                3*tv*tv*(1-tv)*p3 +
                tv*tv*tv*p4);
        if      (tv < minMax[0]) minMax[0] = tv;
        else if (tv > minMax[1]) minMax[1] = tv;
    }
}
 
開發者ID:git-moss,項目名稱:Push2Display,代碼行數:26,代碼來源:Cubic.java

示例8: test_drawQuadCurve

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
/**
 * Draws random quadratic curves within the given dimensions.
 *
 * @param g The Graphics2D object that is used to paint.
 * @param size The size of the canvas.
 */
private void test_drawQuadCurve(Graphics2D g, Dimension size)
{
  int maxTests = testSize;
  int minSize = 10;
  long startTime = System.currentTimeMillis();
  for (int i = 0; i < maxTests; i += 1)
    {
      setRandom(g, size);
      int x1 = (int) (Math.random() * (size.width - minSize));
      int y1 = (int) (Math.random() * (size.height - minSize));
      int xc = (int) (Math.random() * (size.width - minSize));
      int yc = (int) (Math.random() * (size.height - minSize));
      int x2 = (int) (Math.random() * (size.width - minSize));
      int y2 = (int) (Math.random() * (size.height - minSize));

      QuadCurve2D curve = new QuadCurve2D.Double(x1, y1, xc, yc, x2, y2);
      g.draw(curve);
    }
  long endTime = System.currentTimeMillis();
  recordTest("draw(QuadCurve2D.Double) " + maxTests + " times",
             (endTime - startTime));
}
 
開發者ID:vilie,項目名稱:javify,代碼行數:29,代碼來源:J2dBenchmark.java

示例9: getDisplacedSegments

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
/**
 * Get the "top" and "bottom" segments of a given segment.
 * First array element is p0 + normal, second is p0 - normal.
 */
public Segment[] getDisplacedSegments(double radius)
{
  this.radius = radius;
  double x0 = P1.getX();
  double y0 = P1.getY();
  double x1 = cp.getX();
  double y1 = cp.getY();
  double x2 = P2.getX();
  double y2 = P2.getY();

  QuadCurve2D left = new QuadCurve2D.Double();
  QuadCurve2D right = new QuadCurve2D.Double();
  QuadCurve2D orig = new QuadCurve2D.Double(x0, y0, x1, y1, x2, y2);
  orig.subdivide(left, right);

  QuadSegment s1 = offsetSubdivided(left, true);
  QuadSegment s2 = offsetSubdivided(left, false);

  s1.add( offsetSubdivided(right, true) );
  s2.add( offsetSubdivided(right, false) );

  return new Segment[]{s1, s2};
}
 
開發者ID:vilie,項目名稱:javify,代碼行數:28,代碼來源:QuadSegment.java

示例10: dibujar

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
/**
 * Implementacion del metodo abstracto de la clase padre. Dibuja la figura
 * en el grafico pasado como parametro.
 *
 * @param g Graphics donde se desea dibujar la figura.
 */
@Override
public void dibujar(Graphics g) {
    Graphics2D g2 = (Graphics2D) g;

    //Variable que nos sirve para reestablecer la forma original posteriormente
    AffineTransform actual = g2.getTransform();

    //Aplicamos la transformacion del objeto si la tiene
    if (!this.transformaciones.isIdentity()) {
        g2.transform(this.transformaciones);
    }

    QuadCurve2D quad = new QuadCurve2D.Double(this.puntoInicial.x, this.puntoInicial.y, this.ptoControl.x, this.ptoControl.y, this.puntoFinal.x, this.puntoFinal.y);

    g2.setStroke(this.cg.getEstiloLinea());

    //Dibujamos la linea
    g2.setColor(this.cg.getColorLinea());
    g2.draw(quad);

    //Recuperamos la forma original que tenia antes de la transformacion
    g2.setTransform(actual);
}
 
開發者ID:sephierot,項目名稱:paintmultimedia,代碼行數:30,代碼來源:Curva1Dibujable.java

示例11: test_drawQuadCurve

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
/**
 * Draws random quadratic curves within the given dimensions.
 * 
 * @param g The Graphics2D object that is used to paint.
 * @param size The size of the canvas.
 */
private void test_drawQuadCurve(Graphics2D g, Dimension size)
{
  int maxTests = testSize;
  int minSize = 10;
  long startTime = System.currentTimeMillis();
  for (int i = 0; i < maxTests; i += 1)
    {
      setRandom(g, size);
      int x1 = (int) (Math.random() * (size.width - minSize));
      int y1 = (int) (Math.random() * (size.height - minSize));
      int xc = (int) (Math.random() * (size.width - minSize));
      int yc = (int) (Math.random() * (size.height - minSize));
      int x2 = (int) (Math.random() * (size.width - minSize));
      int y2 = (int) (Math.random() * (size.height - minSize));

      QuadCurve2D curve = new QuadCurve2D.Double(x1, y1, xc, yc, x2, y2);
      g.draw(curve);
    }
  long endTime = System.currentTimeMillis();
  recordTest("draw(QuadCurve2D.Double) " + maxTests + " times",
             (endTime - startTime));
}
 
開發者ID:nmldiegues,項目名稱:jvm-stm,代碼行數:29,代碼來源:J2dBenchmark.java

示例12: getCurvedLine

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
protected QuadCurve2D getCurvedLine(int index) {
  double x1 = from.drawx;
  double x2 = to.drawx;
  double y1 = from.drawy;
  double y2 = to.drawy;
  double midx = calculateMidPointBetween(x1, x2);
  double midy = calculateMidPointBetween(y1, y2);
  
  int weight = index / 2;
  if (index % 2 == 1) {
    weight++;
    weight = -weight;
  }
  Dimension offset = calculateOffset(x1, x2, y1, y2, LOADING * weight);
  QuadCurve2D curve = new QuadCurve2D.Double(x1, y1,
      midx-offset.width, midy+offset.height,
      x2, y2);
  return curve;
}
 
開發者ID:ontopia,項目名稱:ontopia,代碼行數:20,代碼來源:TMAbstractEdge.java

示例13: paintClouds

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
private void paintClouds(Graphics2D g, Graphics2D gstroke, double x0,
		double y0, double x1, double y1, double distanceToConvexHull) {
	// System.out.println("double=" + x0+ ", double=" + y0+ ", double=" +
	// x1+ ", double=" + y1);
	double x2, y2, dx, dy;
	dx = x1 - x0;
	dy = y1 - y0;
	double length = Math.sqrt(dx * dx + dy * dy);
	// nothing to do for length zero.
	if (length == 0f)
		return;
	double dxn, dyn;
	dxn = dx / length;
	dyn = dy / length;
	x2 = x0 + .5f * dx - distanceToConvexHull * dyn;
	y2 = y0 + .5f * dy + distanceToConvexHull * dxn;
	// System.out.println("Line from " + x0+ ", " +y0+ ", " +x2+ ", " +y2+
	// ", " +x1+ ", " +y1+".");
	Shape shape = new QuadCurve2D.Double(x0, y0, x2, y2, x1, y1);
	g.fill(shape);
	gstroke.draw(shape);
}
 
開發者ID:iwabuchiken,項目名稱:freemind_1.0.0_20140624_214725,代碼行數:23,代碼來源:CloudView.java

示例14: findCubicZeros

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
private static int findCubicZeros(double zeros[], double cur, double cp0,
		double cp1, double end) {
	// The polynomial form of the Cubic is:
	// eqn[0] = cur;
	// eqn[1] = (cp0 - cur) * 3.0;
	// eqn[2] = (cp1 - cp0 - cp0 + cur) * 3.0;
	// eqn[3] = end + (cp0 - cp1) * 3.0 - cur;
	// Since we want the derivative, we can calculate it in one step:
	zeros[0] = (cp0 - cur) * 3.0;
	zeros[1] = (cp1 - cp0 - cp0 + cur) * 6.0;
	zeros[2] = (end + (cp0 - cp1) * 3.0 - cur) * 3.0;
	int num = QuadCurve2D.solveQuadratic(zeros);
	int ret = 0;
	for (int i = 0; i < num; i++) {
		double t = zeros[i];
		if (t > 0 && t < 1) {
			zeros[ret] = t;
			ret++;
		}
	}
	return ret;
}
 
開發者ID:iwabuchiken,項目名稱:freemind_1.0.0_20140624_214725,代碼行數:23,代碼來源:PathBBox.java

示例15: paint

import java.awt.geom.QuadCurve2D; //導入依賴的package包/類
@Override
void paint(Graphics2D g) {
    Point prevCtrl = pointList.get(0);
    Point currCtrl = pointList.get(1);
    Point pt1 = new Point((prevCtrl.x+currCtrl.x)/2, (prevCtrl.y+currCtrl.y)/2);
    g.drawLine(prevCtrl.x, prevCtrl.y, pt1.x, pt1.y);
    if (pointList.size()>2) for (int i = 2; i < pointList.size(); i++) {
        Point nextCtrl = pointList.get(i);
        Point pt2 = new Point((currCtrl.x+nextCtrl.x)/2, (currCtrl.y+nextCtrl.y)/2);
        QuadCurve2D.Double s = new QuadCurve2D.Double(pt1.x, pt1.y, currCtrl.x, currCtrl.y, pt2.x, pt2.y);
        g.draw(s);
        currCtrl = nextCtrl;
        pt1 = pt2;
    }
    g.drawLine(pt1.x, pt1.y, currCtrl.x, currCtrl.y);
}
 
開發者ID:hlg,項目名稱:billie,代碼行數:17,代碼來源:Java2dFactory.java


注:本文中的java.awt.geom.QuadCurve2D類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。