Tải bản đầy đủ (.docx) (6 trang)

Chương 10 Một số chương trình hướng đối tượng trên C++ Lớp hình học

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (55.11 KB, 6 trang )

Lớp hình học
Chương trình dưới đây gồm:
+ Lớp “hinh” là lớp cơ sở trừu tượng
+ Và 3 lớp dẫn suất từ lớp “hình” là:
- Lớp “khoihop” biểu thị các khối hộp lập phương
- Lớp “duong” biểu thị các đoạn thẳng qua 2 điểm
- Lớp “tron” biểu thị các đường tròn
Chương trình minh hoạ cách dùng tượng ứng bội và phương thức ảo. Nội dung
chương trình như sau:
+ Khi chạy chương trình sẽ thấy xuất hiện một khối hộp lập phương.
+ Có thể di chuyển khối hộp bằng các phím mũi tên.
+ Bấm phím Q sẽ xuất hiện một đoạn thẳng.
+ Có thể di chuyển đoạn thẳng bằng các phím mũi tên.
+ Bấm phím Q sẽ xuất hiện một đường tròn.
+ Có thể di chuyển đường tròn bằng các phím mũi tên.
+ Bấm phím Q sẽ kết thúc chương trình.
/*
CT10_03.CPP
LOP hinh hoc
Minh hoa cach dung:
+ lop co so truu tuong
+ Tuong ung boi va phuong thuc ao
*/
#include <graphics.h>
#include <process.h>
#include <stdio.h>
#include <conio.h>
char getkey(int &dx,int &dy);
class hinh
{
protected:


int mau;
public:
hinh(void)
{
mau=0;
}
518
hinh(int m)
{
mau=m;
}
virtual void dchuyen(int b)=0;
};
class khoihop : public hinh
{
private:
int x,y;
int a ;
public:
khoihop(void):hinh()
{
x=y=a=0;
}
khoihop(int m,int x1,int y1, int a1):hinh(m)
{
x=x1;
y=y1;
a=a1;
}
virtual void dchuyen(int b);

void hien(void)
{
setfillstyle(1,mau);
bar3d(x,y,x+a,y+a,a/2,1);
}
void an(void)
{
setfillstyle(1,getbkcolor());
bar(x,y-a/2,x+a+a/2,y+a+a/2);
}
};
class duong:public hinh
{
private:
int x1,y1,x2,y2;
520
public:
duong(void):hinh()
{
x1=x2=y1=y1=0;
}
duong(int m,int a,int b,int c,int d):hinh(m)
{
x1=a;y1=b;x2=c;y2=d;
}
virtual void dchuyen(int b);
void hien(void)
{
setcolor(mau);
line(x1,y1,x2,y2);

}
void an(void)
{
setcolor(getbkcolor());
line(x1,y1,x2,y2);
}
};
class tron:public hinh
{
private:
int x,y,r;
public:
tron(void):hinh()
{
x=y=r=0;
}
tron(int m,int a,int b,int d):hinh(m)
{
x=a; y=b; r=d;
}
virtual void dchuyen(int b);
void hien(void)
{
setcolor(mau);
circle(x,y,r);
}
void an(void)
{
setcolor(getbkcolor());
circle(x,y,r);

}
};
char getkey(int &dx,int &dy)
{
int ch1,ch2;
dx=dy=0;
while (1)
{
ch1=getch();
if (ch1==0)
ch2=getch();
if (ch1=='q'||ch1=='Q') return('q');
if ((ch1==0&&(ch2==80||ch2==72||ch2==75||ch2==77)))
{
if (ch2==80) dy=1;
else if (ch2==72) dy=-1;
else if (ch2==77) dx=1;
else dx=-1;
return(0);
}
}
}
void khoihop::dchuyen(int b)
{
int dx,dy;
while (1)
{
hien();
if (getkey(dx,dy)=='q') break;
an();

x+=b*dx;
y+=b*dy;
}
}
void duong::dchuyen(int b)
522
{
int dx,dy;
while (1)
{
hien();
if (getkey(dx,dy)=='q') break;
an();
x1+=b*dx;
x2+=b*dx;
y1+=b*dy;
y2+=b*dy;
}
}
void tron::dchuyen(int b)
{
int dx,dy;
while (1)
{
hien();
if (getkey(dx,dy)=='q') break;
an();
x+=b*dx;
y+=b*dy;
}

}
void main()
{
int mh=0,mode=0;
initgraph(&mh,&mode,"");
if (graphresult())
{
printf("\n LOI");
getch();
exit(0);
}
setbkcolor(0);
// setwritemode(0);
hinh *h[3];
khoihop M(4,300,200,15);
duong D(10,10,10,60,60);
524

×