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


Java CubicCurve2D.Double方法代碼示例

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


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

示例1: chopStart

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
/** Chop the start of this curve. */
public void chopStart(double t) {
	int n = list.size();
	t = t * n;
	double di = StrictMath.floor(t);
	int i = (int) di;
	//
	if (i < 0)
		return;
	if (i >= n)
		list.clear();
	while (i > 0 && !list.isEmpty()) {
		list.remove(0);
		i--;
	}
	if (list.isEmpty()) {
		list.add(new CubicCurve2D.Double(startX = endX, startY = endY, endX, endY, endX, endY, endX, endY));
		return;
	}
	CubicCurve2D.Double tmp = new CubicCurve2D.Double();
	divide(t - di, list.get(0), new CubicCurve2D.Double(), tmp);
	list.get(0).setCurve(tmp);
	startX = tmp.x1;
	startY = tmp.y1;
}
 
開發者ID:AlloyTools,項目名稱:org.alloytools.alloy,代碼行數:26,代碼來源:Curve.java

示例2: drawSmoothly

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
/** Draws the given curve smoothly (assuming the curve is monotonic vertically) */
public void drawSmoothly(Curve curve) {
    final int smooth=15;
    double cx=0, cy=0, slope;
    for(int n=curve.list.size(), i=0; i<n; i++) {
        CubicCurve2D.Double c=new CubicCurve2D.Double(), c2=(i+1<n)?curve.list.get(i+1):null;
        c.setCurve(curve.list.get(i));
        if (i>0) { c.ctrlx1=cx; c.ctrly1=cy; }
        if (c2==null) { draw(c,false); return; }
        if ((c.x1<c.x2 && c2.x2<c2.x1) || (c.x1>c.x2 && c2.x2>c2.x1)) slope=0; else slope=(c2.x2-c.x1)/(c2.y2-c.y1);
        double tmp=c.y2-smooth, tmpx=c.x2-smooth*slope;
        if (tmp>c.ctrly1 && tmp<c.y2 && in(c.x1, tmpx, c.x2)) { c.ctrly2=tmp; c.ctrlx2=tmpx; }
        double tmp2=c2.y1+smooth, tmp2x=c2.x1+smooth*slope;
        if (tmp2>c2.y1 && tmp2<c2.ctrly2 && in(c2.x1, tmp2x, c2.x2)) { cy=tmp2; cx=tmp2x; } else { cy=c2.ctrly1; cx=c2.ctrlx1; }
        draw(c,false);
    }
}
 
開發者ID:ModelWriter,項目名稱:Tarski,代碼行數:18,代碼來源:Artist.java

示例3: divide

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
/**
 * Given 0<=t<=1 and an existing curve, divide it into two chunks and store
 * the two chunks into "first" and "second"
 */
public static void divide(double t, CubicCurve2D.Double curve, CubicCurve2D.Double first,
		CubicCurve2D.Double second) {
	// This algorithm uses de Casteljau's algorithm for chopping one bezier
	// curve into two bezier curves
	first.x1 = curve.x1;
	second.x2 = curve.x2;
	first.ctrlx1 = (1 - t) * curve.x1 + t * curve.ctrlx1;
	double x = (1 - t) * curve.ctrlx1 + t * curve.ctrlx2;
	second.ctrlx2 = (1 - t) * curve.ctrlx2 + t * curve.x2;
	first.ctrlx2 = (1 - t) * first.ctrlx1 + t * x;
	second.ctrlx1 = (1 - t) * x + t * second.ctrlx2;
	second.x1 = first.x2 = (1 - t) * first.ctrlx2 + t * second.ctrlx1;
	// now that we've computed the x coordinates, we now compute the y
	// coordinates
	first.y1 = curve.y1;
	second.y2 = curve.y2;
	first.ctrly1 = (1 - t) * curve.y1 + t * curve.ctrly1;
	double y = (1 - t) * curve.ctrly1 + t * curve.ctrly2;
	second.ctrly2 = (1 - t) * curve.ctrly2 + t * curve.y2;
	first.ctrly2 = (1 - t) * first.ctrly1 + t * y;
	second.ctrly1 = (1 - t) * y + t * second.ctrly2;
	second.y1 = first.y2 = (1 - t) * first.ctrly2 + t * second.ctrly1;
}
 
開發者ID:AlloyTools,項目名稱:org.alloytools.alloy,代碼行數:28,代碼來源:Curve.java

示例4: chopEnd

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
/** Chop the end of this curve. */
public void chopEnd(double t) {
    int n=list.size();
    t=t*n;
    double di=StrictMath.floor(t);
    int i=(int)di;
    //
    if (i<0) list.clear();
    if (i>=n) return;
    while(i+1<list.size()) list.remove(i+1);
    if (list.isEmpty()) { endX=startX; endY=startY; list.add(new CubicCurve2D.Double(endX,endY, endX,endY, endX,endY, endX,endY)); return; }
    CubicCurve2D.Double tmp=new CubicCurve2D.Double();
    divide(t-di, list.get(i), tmp, new CubicCurve2D.Double());
    list.get(i).setCurve(tmp);
    endX=tmp.x2;
    endY=tmp.y2;
}
 
開發者ID:ModelWriter,項目名稱:Tarski,代碼行數:18,代碼來源:Curve.java

示例5: test_drawCubicCurve

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
/**
 * Draws random cubic 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_drawCubicCurve(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 xc1 = (int) (Math.random() * (size.width - minSize));
      int yc1 = (int) (Math.random() * (size.height - minSize));
      int xc2 = (int) (Math.random() * (size.width - minSize));
      int yc2 = (int) (Math.random() * (size.height - minSize));
      int x2 = (int) (Math.random() * (size.width - minSize));
      int y2 = (int) (Math.random() * (size.height - minSize));

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

示例6: paint

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
@Override
protected void paint (Graphics2D g,
                      Params p,
                      Point location,
                      Alignment alignment)
{
    Point loc = alignment.translatedPoint(TOP_LEFT, p.rect, location);

    CubicCurve2D curve = new CubicCurve2D.Double(
            loc.x,
            loc.y + p.rect.height,
            loc.x + ((3 * p.rect.width) / 10),
            loc.y + (p.rect.height / 5),
            loc.x + (p.rect.width / 2),
            loc.y,
            loc.x + p.rect.width,
            loc.y);

    // Slur
    g.draw(curve);
}
 
開發者ID:Audiveris,項目名稱:audiveris,代碼行數:22,代碼來源:SlurSymbol.java

示例7: test_drawCubicCurve

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
/**
 * Draws random cubic 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_drawCubicCurve(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 xc1 = (int) (Math.random() * (size.width - minSize));
      int yc1 = (int) (Math.random() * (size.height - minSize));
      int xc2 = (int) (Math.random() * (size.width - minSize));
      int yc2 = (int) (Math.random() * (size.height - minSize));
      int x2 = (int) (Math.random() * (size.width - minSize));
      int y2 = (int) (Math.random() * (size.height - minSize));

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

示例8: getCurveAt

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
public CubicCurve2D getCurveAt(int i){
	if (i < 0 || i >= N() - 1 ) throw 
	new IndexOutOfBoundsException(
			 String.format("Interpolation Class: cannot " +
			 		       "retrieve curve with index : %d" , i));
	CubicCurve2D.Double cubic = new CubicCurve2D.Double(
												  get(i).getX(),
												  get(i).getY(),
												  cP[2*i].getX(),
												  cP[2*i].getY(),
												  cP[2*i+1].getX(),
												  cP[2*i+1].getY(), 
							                      get(i+1).getX(), 
							                      get(i+1).getY());
	return cubic;
}
 
開發者ID:asolis,項目名稱:curveFitting,代碼行數:17,代碼來源:Interpolation.java

示例9: getCurves

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
public ArrayList<Shape> getCurves(){
	  ArrayList<Shape> s = new ArrayList<Shape>();
	
	  for (int i = 0; i < N()-1; i++)
	  {        	
		  CubicCurve2D.Double cubic = new CubicCurve2D.Double(get(i).getX(),
				  											  get(i).getY(),
				  											  cP[2*i].getX(),
															  cP[2*i].getY(),
															  cP[2*i+1].getX(),
															  cP[2*i+1].getY(), 
				                                              get(i+1).getX(), 
				                                              get(i+1).getY());
		  s.add(cubic);
	  }	    	  
        
      return s;
}
 
開發者ID:asolis,項目名稱:curveFitting,代碼行數:19,代碼來源:Interpolation.java

示例10: manageRect

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
private DotPath manageRect(Rectangle2D start, Rectangle2D end) {
	final List<CubicCurve2D.Double> list = new ArrayList<CubicCurve2D.Double>(this.beziers);
	while (true) {
		if (BezierUtils.isCutting(list.get(0), start) == false) {
			throw new IllegalStateException();
		}
		if (BezierUtils.dist(list.get(0)) <= 1.0) {
			break;
		}
		final CubicCurve2D.Double left = new CubicCurve2D.Double();
		final CubicCurve2D.Double right = new CubicCurve2D.Double();
		list.get(0).subdivide(left, right);
		list.set(0, left);
		list.add(1, right);
		if (BezierUtils.isCutting(list.get(1), start)) {
			list.remove(0);
		}
	}
	return new DotPath(list);
}
 
開發者ID:Banno,項目名稱:sbt-plantuml-plugin,代碼行數:21,代碼來源:DotPath.java

示例11: dup

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
/** Make a deep copy of this Curve object. */
public Curve dup() {
	Curve ans = new Curve(startX, startY);
	ans.endX = endX;
	ans.endY = endY;
	for (CubicCurve2D.Double x : list) {
		CubicCurve2D.Double c = new CubicCurve2D.Double();
		c.setCurve(x);
		ans.list.add(c);
	}
	return ans;
}
 
開發者ID:AlloyTools,項目名稱:org.alloytools.alloy,代碼行數:13,代碼來源:Curve.java

示例12: getRegiao

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
@Override
public Shape getRegiao() {
    if (Regiao == null) {
        final int v1 = getHeight() / 3;
        final int h1 = getWidth() / 2;
        final int repo = v1 / 3;
        final int L = getLeft();
        final int T = getTop();
        final int TH = T + getHeight() - repo;
        final int LW = L + getWidth();

        CubicCurve2D c = new CubicCurve2D.Double();
        c.setCurve(LW, TH, LW - h1, TH - v1, L + h1, TH + v1, L, TH);
        CubicCurve2D c2 = new CubicCurve2D.Double();
        int v2 = v1 / 3;
        c2.setCurve(L, T + v2, L + h1, T + v1 + v2, LW - h1, T - v1 + v2, LW, T + v2);

        GeneralPath pa = new GeneralPath();
        pa.setWindingRule(GeneralPath.WIND_EVEN_ODD);
        pa.append(c2, true);
        pa.lineTo(LW, TH);
        pa.append(c, true);
        pa.lineTo(L,  T + v2);
        pa.closePath();
        
        Regiao = pa;
        int ptToMove = 3;
        this.reposicionePonto[ptToMove] = new Point(0, -repo);
        ptsToMove[ptToMove] = 1;
        ptToMove = 1;
        this.reposicionePonto[ptToMove] = new Point(0, repo);
        ptsToMove[ptToMove] = 1;
    }
    return Regiao;
}
 
開發者ID:chcandido,項目名稱:brModelo,代碼行數:36,代碼來源:FluxNota.java

示例13: dup

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
/** Make a deep copy of this Curve object. */
public Curve dup() {
    Curve ans = new Curve(startX, startY);
    ans.endX = endX;
    ans.endY = endY;
    for(CubicCurve2D.Double x:list) {
        CubicCurve2D.Double c = new CubicCurve2D.Double();
        c.setCurve(x);
        ans.list.add(c);
    }
    return ans;
}
 
開發者ID:ModelWriter,項目名稱:Tarski,代碼行數:13,代碼來源:Curve.java

示例14: getRegiaoNota

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
public Shape getRegiaoNota() {
    if (Regiao == null) {
        final int v1 = getHeight() / 3;
        final int h1 = getWidth() / 2;
        final int repo = v1 / 3;
        final int L = getLeft();
        final int T = getTop();
        final int TH = T + getHeight() - repo;
        final int LW = L + getWidth();
        CubicCurve2D c = new CubicCurve2D.Double();
        c.setCurve(LW, TH, LW - h1, TH - v1, L + h1, TH + v1, L, TH);
        CubicCurve2D c2 = new CubicCurve2D.Double();
        int v2 = v1 / 3;
        c2.setCurve(L, T + v2, L + h1, T + v1 + v2, LW - h1, T - v1 + v2, LW, T + v2);

        GeneralPath pa = new GeneralPath();
        pa.setWindingRule(GeneralPath.WIND_EVEN_ODD);
        pa.append(c2, true);
        pa.lineTo(LW, TH);
        pa.append(c, true);
        pa.lineTo(L,  T + v2);
        pa.closePath();

        Regiao = pa;
        int ptToMove = 3;
        this.reposicionePonto[ptToMove] = new Point(0, -repo);
        ptsToMove[ptToMove] = 1;
        ptToMove = 1;
        this.reposicionePonto[ptToMove] = new Point(0, repo);
        ptsToMove[ptToMove] = 1;
    }
    return Regiao;
}
 
開發者ID:chcandido,項目名稱:brModelo,代碼行數:34,代碼來源:LivreBase.java

示例15: main

import java.awt.geom.CubicCurve2D; //導入方法依賴的package包/類
public static void main(String[] args) throws Exception {
    CubicCurve2D c = new CubicCurve2D.Double(50.0, 300.0,
                                             150.0, 166.6666717529297,
                                             238.0, 456.66668701171875,
                                             350.0, 300.0);
    Rectangle2D r = new Rectangle2D.Double(260, 300, 10, 10);

    if (!c.intersects(r)) {
        throw new Exception("The rectangle is contained. " +
                            "intersects(Rectangle2D) should return true");
    }
}
 
開發者ID:lambdalab-mirror,項目名稱:jdk8u-jdk,代碼行數:13,代碼來源:IntersectsTest.java


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