테트리스 짜보다가 질문입니다.,,
햇햇
void InitBlockPos(int x, int y)
{
if(x0 || y0)
return ;
CurPosX=x;
CurPosY=y;
SetCurrentCursorPos(CurPosX, CurPosY);
}
void ChooseBlock(void)
{
srand((unsigned int)time(NULL));
BlockIdx=(rand()%NUM_OF_BLOCK)*4;
}
int GetCurrentBlockIdx(void)
{
return BlockIdx+RotateIdx;
}
void BlockDown(void)
{
DeleteBlock(blockModel[GetCurrentBlockIdx()]);
CurPosY+=1;
SetCurrentCursorPos(CurPosX, CurPosY);
ShowBlock(blockModel[GetCurrentBlockIdx()]);
}
void DeleteBlock(char blockModel[][4])
{
int y,x;
point curPos=GetCurrentCursorPos();
for(y=0; y4; y++)
{
for(x=0; x4; x++)
{
SetCurrentCursorPos(curPos.x+(2*x), curPos.y+y);
if(blockModel[y][x]==1)
printf( );
}
}
SetCurrentCursorPos(curPos.x, curPos.y);
}
void ShowBlock(char blockModel[][4])
{
int y,x;
point curPos=GetCurrentCursorPos();
for(y=0; y4; y++)
{
for(x=0; x4; x++)
{
SetCurrentCursorPos(curPos.x+(2*x),curPos.y+y);
if(blockModel[y][x]==1)
printf(■);
}
}
SetCurrentCursorPos(curPos.x, curPos.y);
}
void BlockLeftRotate(void)
{
int nextRotSte;
DeleteBlock(blockModel[GetCurrentBlockIdx()]);
nextRotSte=RotateIdx+1;
nextRotSte%=4;
RotateIdx=nextRotSte;
SetCurrentCursorPos(CurPosX, CurPosY);
ShowBlock(blockModel[GetCurrentBlockIdx()]);
}
void BlockLeftMove(void)
{
DeleteBlock(blockModel[GetCurrentBlockIdx()]);
CurPosX-=2;
SetCurrentCursorPos(CurPosX, CurPosY);
ShowBlock(blockModel[GetCurrentBlockIdx()]);
}
void BlockRightMove(void)
{
DeleteBlock(blockModel[GetCurrentBlockIdx()]);
CurPosX+=2;
SetCurrentCursorPos(CurPosX, CurPosY);
ShowBlock(blockModel[GetCurrentBlockIdx()]);
}
void DrawGameBoard(void)
{
int x, y;
for(y=0; y=GBOARD_HEIGHT; y++)
{
SetCurrentCursorPos(GBOARD_ORIGIN_X, GBOARD_ORIGIN_Y+y);
if(y==GBOARD_HEIGHT)
printf(┗);
else
printf(┃);
}
for(y=0; y=GBOARD_HEIGHT; y++)
{
SetCurrentCursorPos(GBOARD_ORIGIN_X+ (GBOARD_WIDTH+1)*2, GBOARD_ORIGIN_Y+y);
if(y==GBOARD_HEIGHT)
printf(┛);
else
printf(┃);
}
for(x=1; xGBOARD_WIDTH+1; x++)
{
SetCurrentCursorPos(GBOARD_ORIGIN_X+x*2, GBOARD_ORIGIN_Y+GBOARD_HEIGHT);
printf(━);
}
SetCurrentCursorPos(0,0);
}
void InitgameBoardInfo(void)
{
int i,j;
for(i=0; iGBOARD_HEIGHT; i++)
{
gameBoardInfo[i][0]=1; //왼쪽 경계면 초기화
gameBoardInfo[i][GBOARD_WIDTH+2]=1; //오른쪽 경계면 초기화
}
for(i=0; iGBOARD_WIDTH+2; i++)
gameBoardInfo[GBOARD_HEIGHT+1][i]=1; // 바닥 경계면 초기화
}
int DetectCollision(int posX, int posY, char blockModel[][4])
{
int x,y;
int arrX=(posX-GBOARD_ORIGIN_X)/2;
int arrY=posY-GBOARD_ORIGIN_Y;
for(x=0; x4; x++)
{
for(y=0; x4; y++)
{
if(blockModel[y][x]==1 && gameBoardInfo[arrY+y][arrX+x]==1)
return 0;
}
}
return 1;
} - 이 함수가 충돌을 검사한다는데 왜 blockModel[y][x]정보를 검사하는지 잘 모르겠습니다...이중 for문을 도는 저부분이 이해가 가질 않네요.. 고수님들의 친절한 설명부탁드려요~~~
-
이거이름임
아 감사합니다~~ 이해가 되네용^^^^
-
양자리
테트리스는 4 * 4 의 정사각형 모양의 투명한 셀로판 위에서 6가지 종류의 블록 모양을 구성해야 합니다. 이 블록은 하좌우, 모양변경을 할 수 있는데 이때 이동할 수 있는지 없는지 체크를 합니다. 4 * 4 는 현재 블록이 존재하는 곳에서 점유 가능한 최대한의 면적입니다. 그 안에서 테트리스 블록은 모양, 방향에 상관없이 항상 존재합니다. 그래서 모두 체크해야 하는 겁니다. x, y 는 산수에서 그래프 그릴때 좌표를 뜻하는 것으로 보입니다. 그냥 보통
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2698882 | 프로그래밍좀 짜주세요 (3) | 황예 | 2025-06-21 |
2698855 | 카프-라빈 알고리즘 코딩 분석좀 도와주세요.. | 꽃봄 | 2025-06-20 |
2698829 | 학점계산기 (7) | MyWay | 2025-06-20 |
2698782 | 기초적인 함수 질문이요ㅠㅠㅠㅠ | 내담 | 2025-06-20 |
2698749 | 프로그램 짜던 도중 패닉입니다...ㅜ | 파랑 | 2025-06-19 |
2698719 | 조건부컴파일 질문입니다.~ (2) | 큐트 | 2025-06-19 |
2698693 | 재귀 함수 에러 | 바닐라 | 2025-06-19 |
2698673 | 고민이있는데 들어좀주세요!! (1) | 초코맛캔디 | 2025-06-19 |
2698644 | 1부터 n까지의 합을 구하는데 엄청긴숫자의 합을 구할때는 어떻게 해야하나요? (4) | 슬우 | 2025-06-18 |
2698616 | 다른 함수로 안넘어갑니다..;;; | 도1도캣 | 2025-06-18 |
2698587 | 배열하다 막혀서... (3) | WhiteCat | 2025-06-18 |
2698559 | 문자열을 비우는방법 (2) | 하늘 | 2025-06-18 |
2698528 | 착하고 친절한 선생씌구해염~ㅋㅋ (4) | 옆집언니야 | 2025-06-17 |
2698502 | 자료구조 큐 | 캔서 | 2025-06-17 |
2698477 | 실행화면 배경문의요 | 선아 | 2025-06-17 |
2698430 | 변수의 값이 저장이 않되네요;; (4) | 피네 | 2025-06-16 |
2698404 | C#을 배울려고 하는데 C나 C++을 알아야 하나요 ?? (1) | 신당 | 2025-06-16 |
2698342 | 프로그램 질문점녀 (4) | 데빌의눈물 | 2025-06-16 |
2698318 | 파일 입출력 질문입니다~ (2) | 꽃 | 2025-06-15 |
2698291 | 문자 출력 함수 : putchar, fputc에 관하여. | 으뜸 | 2025-06-15 |