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

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

?? roboproto.java

?? 一個由c轉成java的3D robot 仿真平臺
?? JAVA
?? 第 1 頁 / 共 5 頁
字號:
	   String result = new String(String.valueOf(number));	   int length = result.length();		   switch(length)	     {		case 4: return result + ")   ";		case 3: return result + ")    ";		case 2: return result + ")     ";		case 1: return result + ")      ";		default: return result + ")  ";	     }	}	private void updateManualLabel(int no)	{	  if ((no >= 0) && (no < 6))	    {	      String blank = null; // behind the first number, a blank is		    // necessary for angle no. 4 and 5 (they're too short)	      if (no == 4 || no == 5)	        blank = "  ";	      else	   	blank = "";  	      manualLabels[no].setText(String.valueOf(		        Math.round(angles[no].min * 180 / Math.PI)) + blank  			+ "   Angle" + String.valueOf(no + 1) + " (" +			formatTo5(Math.round(angles[no].act * 180 / Math.PI)) 			+ "        " + String.valueOf(Math.round(			angles[no].max * 180 / Math.PI)));	   }	} 	private void updateLinkLabel(int no)	{	  if ((no >= 0) && (no < 3))	    linkLabels[no].setText(String.valueOf(			roundTo2(linkMin[no])) +			"   Linklength" + String.valueOf(no + 1) + " (" +			formatTo5(roundTo2(linkLengths[no])) + "      " +			String.valueOf(roundTo2(linkMax[no])));	}	private void updateOldLinkLabel(int no, double actValue)	// this method is called, if the linkLenth is changed, but the change	// is not yet executed	{	  if ((no >= 0) && (no < 3))	    linkLabels[no].setText(String.valueOf(			roundTo2(linkMin[no])) +			"   Linklength" + String.valueOf(no + 1) + " (" +			formatTo5(roundTo2(actValue)) + "      " +			String.valueOf(roundTo2(linkMax[no])));	}	private void updateAutoLabel(int no)	{	  if ((no >= 0) && (no < 3))	    {	      String[] labelHead = { new String("X-Value"), 			new String("Y-Value"), new String("Z-Value") };	      autoLabels[no].setText(String.valueOf(-autoScrollRange) + 			"       " + labelHead[no] + " (" + 			formatTo5(roundTo2(target[no]))			+ "           " + String.valueOf(autoScrollRange));	    }	}	private void updateScrolledAutoLabel(int no)	// this method is called, if an auto scrollbar has been used, but the	// robot hasn't yet moved to the new position, because the execute	// button has to be pushed to make him do that	{	  if ((no >= 0) && (no < 3))	    {	      String[] labelHead = { new String("X-Value"), 			new String("Y-Value"), new String("Z-Value") };	      autoLabels[no].setText(String.valueOf(-autoScrollRange) + 			"       " + labelHead[no] + " (" + 			formatTo5(roundTo2(input[no]))			+ "           " + String.valueOf(autoScrollRange));	    }	}	public void writeError(String text)	{	    errWin = new ErrorWindow(text, this);	}	private void actualizeAutoPanel()	{	  CinematicCalculations.calculatePos(angles, pos, this);	  for (int kl = 0; kl < 3; kl++)	    {	      target[kl] = pos[kl];	      autoScrolls[kl].setValue(autoScrollScale * (int) target[kl]);	      updateAutoLabel(kl);	    }	}	public void manualInput(double newAngles[])	// the read angle dates are interpreted	{	   if (robotIsReal)	     {	       newAngles[3] = 0.0;	       newAngles[5] = 0.0;	     }	   if (! ((newAngles[0] == angles[0].act) &&		  (newAngles[1] == angles[1].act) && 		  (newAngles[2] == angles[2].act) &&		  (newAngles[3] == angles[3].act) && 		  (newAngles[4] == angles[4].act) &&		  (newAngles[5] == angles[5].act)))	     {	       manualChange(newAngles);	       for (int i = 0; i < 6; i++)	         manualScrolls[i].setValue(manualScrollScale * 	      					(int) angles[i].act); 	     }	}	public void linkLengthInput(double newLength[])	{	   if (robotIsReal)	     return;	   linkLengthChange(newLength);	   for (int j = 0; j < 3; j++)	     { 	       linkScrolls[j].setValue(linkScrollScale * (int) linkLengths[j]);	       updateLinkLabel(j);	     }		}	private void linkLengthChange(double newLength[])	{	   int i;	   double[] remindNewLengths = { newLength[0], newLength[1],					 newLength[2] };	   boolean link1NotChanged = false;	   if ( newLength[0] < linkMin[0] || newLength[1] < linkMin[1] ||                newLength[2] < linkMin[2] || newLength[0] > linkMax[0] ||                newLength[1] > linkMax[1] || newLength[2] > linkMax[2] ||		((newLength[0] == linkLengths[0]) &&  		 (newLength[1] == linkLengths[1]) &&		 (newLength[2] == linkLengths[2]))     )	     return;  // at least one of the new lengths is wrong	   if (newLength[0] == linkLengths[0])	     link1NotChanged = true;	   if ( fFile == 0 )             {    // Test, if location of view has to be adjusted 	       locationNew[0] = 0.0;               locationNew[1] = 0.0;               locationNew[2] = d;               x = -angleX;               y = -angleY;               AllAboutMoving.calculateLocation(locationNew,y,x);                                                    x = location[1];               y = newLength[0] + newLength[1] + newLength[2] + linkLengths[3] 		   + 2.0;               if ( x < y )                 {                   x = 0.0;                   y = newLength[0] + newLength[1] + newLength[2] + 	               linkLengths[3] + 2.0;                   z = 0.0;                                       x = Math.sqrt(locationNew[0] * locationNew[0] + 		    	         locationNew[2] * locationNew[2]);                   y = newLength[1] + newLength[2] + linkLengths[3] + 2.0;                   s_wx = Math.sin(angleX);                   z = s_wx * y ;                   if ( z >= ( d-2.0) || x < y)                      {		       writeError("This change isn't executable.");		       for (int kl = 0; kl < 3; kl++)			 {			   linkScrolls[kl].setValue((int) linkLengths[kl]							  * linkScrollScale);			   updateLinkLabel(kl);			 }                       return;                           }                 }             }  // endif f_file == 0                               // the arms get changed:           for ( i=0 ; i<6 ; i++ )  	     {               angleOld[i] = angles[i].act;               angles[i].act = 0.0;             }	   for (i = 0; i < 3; i++)	     {               h = linkLengths[i];               linkLengths[i] = newLength[i];                newLength[i] = h - newLength[i];	     }	   for ( i=48 ; i<78 ; i++ )	     PL[i].y = PL[i].y - newLength[0];           for ( i=78 ; i<108 ; i++ ) 	     {	       PL[i].y = PL[i].y - newLength[0];               PL[i].x = PL[i].x - newLength[1];             }           for ( i=108 ; i<numberOfPoints ; i++ ) 	     {               PL[i].y = PL[i].y - newLength[0] + newLength[2];               PL[i].x = PL[i].x - newLength[1];             }           AllAboutMoving.copyPointList(PL, pl, this);               angleNew[0] = 0.0;           angleNew[1] = -Math.PI/2;           angleNew[2] = angleNew[1];           angleNew[3] = 0.0;           angleNew[4] = 0.0;           angleNew[5] = 0.0;           AllAboutMoving.PosRobo(pl, angleNew, angles, this);// angles get							// their new values	   angleOld[1] = angleOld[1] + (Math.PI/2);           angleOld[2] = angleOld[2] + (Math.PI/2);	   // Creation of variables of primitive data type needed as 	   // call-by-reference variables:	   RefInt refError = new RefInt(errorcode);	   RefDouble refAngleY = new RefDouble(angleY);	   RefDouble refAngleX = new RefDouble(angleX);	   RefDouble refD = new RefDouble(d);	   RefInt refIndx = new RefInt(indx);           AllAboutMoving.MoveRobo (showTheMove, pl, line, angleOld, angles, 			45,refError, refAngleY, refAngleX, refD,0, refIndx,			location, this);           errorcode = refError.in;	   angleY = refAngleY.in;	   angleX = refAngleX.in;	   indx = refIndx.in;	   d = refD.in;	   if (showTheMove)	     repaint();	   for (int k = 0; k < 3; k++)	     linkLengths[k] = remindNewLengths[k];		   if (!link1NotChanged)	     {	       manualChange(0, angles[0].act + 0.1);	       manualChange(0, angles[0].act - 0.1);	       // The first change of 'linkLength1' is only	       // executed, if angle 0 gets changed (I don't know why).	       // Thus I make this angle change every time, 'linkLength1'	       // gets changed.	     }	   for (int kl = 0; kl < 6; kl++)	     {	       updateManualLabel(kl);	       manualScrolls[kl].setValue((int)angles[kl].act					   * manualScrollScale);	     }	}      private void errorDo()        {	   if (!crashIsActive)	     writeError("This angle change would cause a crash.");	   crashIsActive = true;	   for (int i = 0; i < 6; i++)	     {	       updateManualLabel(i);	       manualScrolls[i].setValue((int) (angles[i].act * 						manualScrollScale));	     }  	}      private boolean crashTest(double dummies[])	{ // Tests, if a manual change would cause a crash with the floor	  double[] position = new double[3];	  AngleDates[] helper = new AngleDates[6];	  for (int i = 0; i < 6; i++)	    helper[i] = new AngleDates(angles[i].max, angles[i].min,					 dummies[i]);	  CinematicCalculations.calculatePos(helper, pos, this);	  if (pos[1] <= 0)	    {	      if (!crashIsActive)	        writeError("This angle change would cause a crash.");	      crashIsActive = true;	      return false;	    }	  return true;	}		  	private void manualChange(double newValues[])	{	  reminder = 1;	  for (int j = 0; j < 6; j++)	    {	      input[j] = 0;              angleNew[j] = angles[j].act;	    }	  for (int j = 0; j < 6; j++)	    {	      if (newValues[j] >= angles[j].max)// Test,if newValue has got an		{ 	          newValues[j] = angles[j].max;   // allowed value	          anglesLeftExtreme[j] = true;	        }	      else 	        if (newValues[j] <= angles[j].min)	          {		    newValues[j] = angles[j].min;		    anglesLeftExtreme[j] = true;		  }	    } 	  if (!crashTest(newValues))	    {	       // Reparation of the robot:	      for (int i=0 ; i<6 ; i++ )  	        {                  angleOld[i] = angles[i].act;                  angles[i].act = 0.0;                }	      AllAboutMoving.copyPointList(PL, pl, this);                  angleNew[0] = 0.0;              angleNew[1] = -Math.PI/2;              angleNew[2] = angleNew[1];              angleNew[3] = 0.0;              angleNew[4] = 0.0;              angleNew[5] = 0.0;              AllAboutMoving.PosRobo(pl, angleNew, angles, this);// angles get							// their new values	      angleOld[1] = angleOld[1] + (Math.PI/2);              angleOld[2] = angleOld[2] + (Math.PI/2);	      // Creation of variables of primitive data type needed as 	      // call-by-reference variables:	      RefInt refError = new RefInt(errorcode);	      RefDouble refAngleY = new RefDouble(angleY);	      RefDouble refAngleX = new RefDouble(angleX);	      RefDouble refD = new RefDouble(d);	      RefInt refIndx = new RefInt(indx);              AllAboutMoving.MoveRobo (showTheMove, pl, line, angleOld, 			angles,	15,refError, refAngleY, refAngleX, refD, 0, 		        refIndx, location, this);              errorcode = refError.in;	      angleY = refAngleY.in;	      angleX = refAngleX.in;	      indx = refIndx.in;	      d = refD.in;	      for (int i = 0; i < 6; i++)	        manualScrolls[i].setValue((int)(manualScrollScale * 						angles[i].act));	      crashIsActive = false;	      return; // this change would cause a bad crash	    }	  // input is the difference between the old and the new	  // angle 	  for (int j = 0; j < 6; j++)	    {	      input[j] = newValues[j] - angles[j].act;	      angleNew[j] = angles[j].act + input[j];	    }	  RefInt refN = new RefInt(n);        // copies of the variables	  RefInt refSteps = new RefInt(steps);// which are objects	  AllAboutMoving.calculateAngle(input, wB, wE, refN, 				refSteps, this);	  n = refN.in;	  steps = refSteps.in;	  // reference variables for the following MoveRobo-	  // methods exactly representing the primitive data-	  // type variables:	  RefInt refError = new RefInt(errorcode);	  RefDouble refAngleY = new RefDouble(angleY);	  RefDouble refAngleX = new RefDouble(angleX);	  RefDouble refD = new RefDouble(d);	  RefInt refIndx = new RefInt(indx);	  for (int j = 1; j < n + 1; j++)	    {	      for (int k = 0; k < 6; k++)	      hw[k] = wB[k] * j;	      AllAboutMoving.MoveRobo(showTheMove, pl, line, hw, angles, 1,				refError, refAngleY, refAngleX, refD, 1, 				refIndx, location, this);			  	      if (refError.in == 1)		{		  errorDo();	          break;		}  	      errorcode = refError.in;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产三级欧美三级日产三级99| 蜜桃视频在线观看一区| 亚洲一区二区在线观看视频 | 欧美主播一区二区三区美女| 欧美猛男男办公室激情| 国产女人水真多18毛片18精品视频 | 国产精品黄色在线观看| 日韩不卡一区二区| 在线影视一区二区三区| 国产女主播在线一区二区| 免费成人小视频| 欧美日韩五月天| 亚洲欧美一区二区视频| 国产一区在线精品| 欧美一级免费观看| 亚洲va中文字幕| 色丁香久综合在线久综合在线观看| 欧美精品一区二区三区蜜桃视频| 亚洲在线中文字幕| 一本一道久久a久久精品综合蜜臀 一本一道综合狠狠老 | 精品电影一区二区| 日韩精品久久久久久| 欧美亚洲自拍偷拍| 一区二区三区精品| 欧美影院一区二区| 亚洲国产成人高清精品| 日本高清不卡aⅴ免费网站| 欧美激情一区二区三区在线| 国产91精品一区二区麻豆亚洲| 91精品麻豆日日躁夜夜躁| 亚洲图片一区二区| 欧美影院午夜播放| 日韩国产在线观看| 欧美成人乱码一区二区三区| 美女国产一区二区三区| 精品日韩在线一区| 国产一区欧美二区| 国产精品毛片久久久久久| 成人美女视频在线观看18| 国产精品婷婷午夜在线观看| 国产成人av电影在线| 欧美国产综合一区二区| 99久久99久久综合| 午夜欧美电影在线观看| 欧美一区二区三区视频免费| 国产一区二区三区日韩| 亚洲国产成人午夜在线一区 | 亚洲卡通动漫在线| 欧美三级韩国三级日本三斤| 天天综合天天综合色| 日韩欧美久久一区| 成人高清视频在线观看| 日韩久久一区二区| 欧美肥妇free| 国产一区二区免费视频| 国产精品久久久久久久久快鸭| 色8久久人人97超碰香蕉987| 午夜精品久久久久久久久| 精品噜噜噜噜久久久久久久久试看| 国产毛片精品视频| 亚洲最大的成人av| 欧美一区二区日韩| www.欧美色图| 丝袜国产日韩另类美女| 久久精品视频一区二区| 一本色道久久综合亚洲aⅴ蜜桃 | 国产一区二区三区免费| 一区二区在线观看免费| 日韩欧美二区三区| 91蜜桃在线观看| 麻豆精品一区二区综合av| 亚洲欧洲日韩综合一区二区| 欧美电影在哪看比较好| 国产激情视频一区二区在线观看 | 亚洲欧美一区二区视频| 日韩美一区二区三区| 91丝袜美腿高跟国产极品老师| 三级在线观看一区二区| 中文字幕欧美一| 欧美变态tickling挠脚心| 色综合咪咪久久| 成人小视频在线| 久久国产精品99精品国产| 一级中文字幕一区二区| 国产精品入口麻豆原神| 91精品国产乱码久久蜜臀| 色欧美乱欧美15图片| 懂色av一区二区三区蜜臀| 日本不卡不码高清免费观看| 亚洲激情中文1区| 国产三区在线成人av| 26uuuu精品一区二区| 在线观看视频一区二区 | 欧美少妇性性性| a美女胸又www黄视频久久| 激情深爱一区二区| 五月天网站亚洲| 亚洲一级片在线观看| 国产精品不卡一区| 久久久久久久一区| 日韩精品一区二区三区视频在线观看 | 国产成人精品综合在线观看 | av不卡一区二区三区| 国产成人精品三级麻豆| 精品一区二区三区免费视频| 视频一区二区国产| 香蕉乱码成人久久天堂爱免费| 一区二区三区精品在线| 亚洲日本韩国一区| 一区视频在线播放| 亚洲图片欧美激情| 一区二区三区中文字幕| 一区二区三区中文字幕在线观看| 亚洲欧洲中文日韩久久av乱码| 国产精品日日摸夜夜摸av| 国产精品福利电影一区二区三区四区| 国产欧美日韩精品一区| 中文字幕高清不卡| 中文字幕一区二区三| 亚洲欧美视频在线观看视频| 亚洲码国产岛国毛片在线| 亚洲精选视频在线| 伊人开心综合网| 日韩在线一二三区| 美洲天堂一区二卡三卡四卡视频| 麻豆视频观看网址久久| 国产一区欧美一区| 99久久精品免费| 欧美丰满一区二区免费视频 | 51午夜精品国产| 欧美大黄免费观看| 国产视频在线观看一区二区三区| 中文字幕免费不卡| 亚洲一区二区三区不卡国产欧美 | 欧美一区二区三区系列电影| 精品国产伦一区二区三区免费| 久久免费电影网| 亚洲免费资源在线播放| 三级不卡在线观看| 国产自产v一区二区三区c| 波多野结衣亚洲| 欧美日韩中文字幕精品| 91精品国产综合久久福利 | 日韩欧美一二三| 亚洲国产精品ⅴa在线观看| 亚洲影院免费观看| 九色|91porny| 色综合久久久网| 欧美电影免费观看高清完整版在线| 国产人伦精品一区二区| 亚洲国产精品久久不卡毛片 | 免费在线观看日韩欧美| 国产精品18久久久久久久网站| 91丨porny丨户外露出| 欧美日韩国产高清一区二区| 久久美女艺术照精彩视频福利播放| 亚洲精品中文在线| 国产一区激情在线| 欧美日韩激情一区二区| 国产亚洲欧美日韩日本| 日韩成人午夜精品| 色老头久久综合| 久久久久国产精品人| 天天操天天色综合| 99精品偷自拍| 国产女同互慰高潮91漫画| 日本中文字幕一区二区有限公司| 成人18视频日本| 精品成人在线观看| 首页欧美精品中文字幕| 色婷婷久久久久swag精品| 久久精品一区八戒影视| 美脚の诱脚舐め脚责91| 欧美日韩一级二级| 18成人在线观看| 成人做爰69片免费看网站| 日韩视频一区二区三区在线播放| 一区二区三区在线视频免费观看| 成人午夜视频网站| 欧美va在线播放| 麻豆成人久久精品二区三区红| 欧美午夜电影网| 亚洲大片一区二区三区| 91黄色在线观看| 亚洲美女精品一区| 91丝袜呻吟高潮美腿白嫩在线观看| 日本一区二区三区视频视频| 韩国精品久久久| 欧美精品一区二区精品网| 麻豆精品国产传媒mv男同| 日韩视频123| 亚洲不卡一区二区三区| 国产日韩精品一区二区三区在线| 久久99国产精品免费| 色老汉av一区二区三区| 国产精品电影院| 成人在线视频一区二区| 国产精品二三区| 91在线观看一区二区| 国产精品二区一区二区aⅴ污介绍|