`
deepfuture
  • 浏览: 4332664 次
  • 性别: Icon_minigender_1
  • 来自: 湛江
博客专栏
073ec2a9-85b7-3ebf-a3bb-c6361e6c6f64
SQLite源码剖析
浏览量:79404
1591c4b8-62f1-3d3e-9551-25c77465da96
WIN32汇编语言学习应用...
浏览量:68361
F5390db6-59dd-338f-ba18-4e93943ff06a
神奇的perl
浏览量:101484
Dac44363-8a80-3836-99aa-f7b7780fa6e2
lucene等搜索引擎解析...
浏览量:281140
Ec49a563-4109-3c69-9c83-8f6d068ba113
深入lucene3.5源码...
浏览量:14597
9b99bfc2-19c2-3346-9100-7f8879c731ce
VB.NET并行与分布式编...
浏览量:65552
B1db2af3-06b3-35bb-ac08-59ff2d1324b4
silverlight 5...
浏览量:31311
4a56b548-ab3d-35af-a984-e0781d142c23
算法下午茶系列
浏览量:45199
社区版块
存档分类
最新评论

perl-opengl椭圆算法

 
阅读更多
#!/usr/bin/perl -w
use strict;
use warnings;
use OpenGL qw/ :all /;
use OpenGL::Config;   

glutInit();
glutInitDisplayMode(GLUT_RGB|GLUT_SINGLE);
glutInitWindowPosition(100,100);
glutInitWindowSize(400,400);
glutCreateWindow("my  OpenGL program");
glClearColor(0,0,0,255);
glClear(GL_COLOR_BUFFER_BIT);  
glMatrixMode(GL_PROJECTION);
gluOrtho2D(-100,100,-100,100);
glutDisplayFunc(\&mydis);
glutMainLoop();
return 0;

sub mydis()
{
  my $xcenter=5;
  my $ycenter=2;
  my $Rx=16;
  my $Ry=69;
  my $Rx2=$Rx*$Rx;
  my $Ry2=$Ry*$Ry;  
  my $twoRx2=2*$Rx2;
  my $twoRy2=2*$Ry2;
  my $p;
  my $x=0;
  my $y=$Ry;
  my $px=0;
  my $py=$twoRx2*$y;
  
  glPointSize(1);
  glColor3f(255,0,255);  
  
  &showpoints($xcenter,$ycenter,$x,$y);
  $p=round($Ry2-($Rx2*$Ry)+(0.25*$Rx2));
  for (;$px<$py;$x++)
  {
     $px+=$twoRy2;
	 if ($p<0)
	 {
	    $p+=$Ry2+$px;
	 }
	 else
	 {
	    $y--;
		$py-=$twoRx2;
		$p+=$Ry2+$px-$py;		
	 }
	&showpoints($xcenter,$ycenter,$x,$y);
  }
  
  $p=round($Ry2*(($x+0.5)**2)+$Rx2*(($y-1)**2)-$Rx2*$Ry2);
  for (;$y>0;$y--)
  {
     $py-=$twoRx2;
	 if ($p>0)
	 {
	    $p+=$Rx2-$py;
	 }
	 else
	 {
	    $x++;
		$px+=$twoRy2;
		$p+=$Rx2-$py+$px;		
	 }
	&showpoints($xcenter,$ycenter,$x,$y);
  } 
  glFlush();
  glColor3f(0,255,0);
  glBegin(GL_LINES);
  glVertex2f(-100,0);
  glVertex2f(100,0); 
  glEnd();
  glBegin(GL_LINES);
  glVertex2f(0,-100);
  glVertex2f(0,100); 
  glEnd();  
  glFlush();
}

sub showpoints()
{
  my ($xcenter,$ycenter,$x,$y)=@_;
  glBegin(GL_POINTS);
  glVertex2f($xcenter+$x,$ycenter+$y);
  glVertex2f($xcenter-$x,$ycenter+$y);
  glVertex2f($xcenter+$x,$ycenter-$y);
  glVertex2f($xcenter-$x,$ycenter-$y);
  glEnd(); 
}

sub round()
{
   return  int($_[0]+0.5);
}

 

 



 

  • 大小: 32.6 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics