사용자 도구

사이트 도구


사이드바

카테고리

language:gamemaker:1-코딩하면서-남기는-메모

여기에 일단 적다가.. 언젠가 원래 있어야할 섹션으로 이동

view를 사용한 화면 전환 방식으로 작성한 것

  • 은근히 손이 많이 가고 신경 쓰이는게 많아서
  • room을 전환하는 방식으로 바꿔보려고 한다.

화면 부분, 부분을 분할해서 출력하는 용도가 아니면 룸이 아니어도 되지 않나 싶다. 아직은 활용을 제대로 못하고 있기 때문인지 좌표 때문에 손이 많이 가네.

with 를 사용할 때, 원래 인스턴스를 쓰려면

게임을 정지시키고 싶을때, 현재 화면에 보이는 것들(이것들만 정지시키도 되는 부분이라) instance_deactivate_object()로 필요한 것만 정지시켰으나…

뭔가 잘 안됐다. 여러번 반복하면 다운의 원인이 되었다.

어떤걸 잘못 쓴걸까.. 반면,

instance_deactivate_all(false)와 instance_activate_all()는 매우 잘 되었다.

주의할 점은 deactivate 하고나면 완전 스톱이기 때문에, (내부 로직상태도 멈춘다) 다시 상태 변경이 원활하게 하고 싶으면 먼저 활성화 하고 해야한다.

with 를 사용할 때, 원래 인스턴스를 쓰려면

with( some_inst )
{
  x = 1; y =1;
  id; // id값도 some_inst의 id 값이다. 당연하지만.
}

이 경우, with(..) 구문을 사용하는 오브젝트(인스턴스)의 변수나 속성을 사용하고 싶다면, other 키워드를 사용한다.

with( some_inst )
{
  x = 1; y =1;
  id; // id값도 some_inst의 id 값이다. 당연하지만.
  other.id; // 이 코드를 실행하는 인스턴스의 id를 가리킨다.
}

오브젝트에 있는 스프라이트의 크기

도움말에 있는 내용이지만,

  • sprite_width, sprite_height 는 인스턴스에 할당된 스프라이트의 크기를 리턴하는데,
  • image_xscale, image_yscale 만큼 확대/축소된 크기를 갖고 있다.
  • 스프라이트의 원래 크기를 얻으려면, sprite_get_width(), sprite_get_height()를 사용한다.

Parent 객체 설정

  • 부모 객체를 설정해서, 부모에서 설정된 기능을 그대로 따라 하는 것은 아주 편리한 기능.
  • 스프라이트까지 상속되지는 않는 모양.

특정 이벤트에서 부모 객체의 이벤트를 먼저 호출하고 싶으면,

  • DnD
    1. 이벤트를 선택하고 액션을 추가한다.
    2. 액션 : Control » CALL EVENT 를 액션 리스트에 갖다 놓는다.
  • code로 해결하려면,
    event_inherited();

Drawing 함수

  • draw_rectangle() 함수 마지막 파라미터가 true 면 테두리를, false 면 fill을.

DrawGUI 이벤트

화면 해상도 또는 뷰를 사용하는 화면이 스크롤 되어도, draw gui 이벤트로 그린 것들은 항상 그 자리에 남아 있다.

유용하게 잘 써먹자.

마우스 좌표

  • display_mouse_get_x / display_mouse_get_y : 현재 디바이스(모니터)의 좌표를 리턴한다.

폰트 사용

// 외부 전역 오브젝트에서, 프로그램이 첫 실행시 설정
draw_set_font( fntMain );
 
// 필요한 오브젝트에서 출력해보기 -- 처음설정한 폰트가 그대로 유지되는가?
// ** 한글 출력을 위해서는 ini 설정과 한글 스트링 로딩 작업이 필요.
draw_text_color( x, y, 'test string', c_lime, c_lime, c_green, c_reen, 1 );

적에게 체력 게이지 추가

health는 플레이어 캐릭터에만 쓸 수 있는 전역 변수라서, 인스턴스 변수를 선언.

  • (Events:Create) 추가할때 (Actions:control→Execute Code) 추가
    // 인스턴스 변수 추가
    myHealth = 40;
  • 충돌처리 이벤트에 (Events:Collision)
    // 충돌한 상대 인스턴스를 삭제
    with(other) instance_destroy();
    // 내 (적) 체력을 깍는다.
    myHealth -= global.currentBulletPower; // 전역 변수로 총알 파워가 10 이다,라고 설정
    // 체력이 0 이면 죽는 처리
    if( myHealth < 0 )
    {
        myHealth = 0;
        instance_create( x, y, obj_explosion1 );
        instance_create( x, y, obj_dropCoin );
        instance_destroy();
    }
  • 적 아래쪽에 체력 게이지 추가 (Events:Draw) 추가
  • (Events:Draw) 에 (Actions:draw→Draw Self) 추가, 적의 모습은 그려야 하므로.
  • (Events:Draw)에 (Actions:control→Execute Code) 추가해서 체력 게이지 그리기
    var x1, y2, x2, y2;
    // 적기 인스턴스를 중심으로 아래쪽에 작은 체력 게이지 영역을 구한다.
    // 인스턴스의 0,0을 사용하는 대신 (sprite_xoffset, sprite_yoffset)값을 활용해서 하단 위치를 구한다.
    x1 = x - sprite_xoffset;        
    y1 = y + (sprite_yoffset + 2);
    x2 = x + sprite_xoffset;
    y2 = y + sprite_yoffset + 6;
    // draw_healthbar()로 GM에서 기본으로 제공하는 체력 게이지를 그린다.
    draw_healthbar( x1, y1, x2, y2, myHealth, c_black, c_red, c_red, 0, true, true );

스피드

  1. pc에서 보는 움직이는 속도와 아이폰에서 느낌은 좀 다르다.
  2. 기본 속도를 4이상 잡아야 빠르게 움직이는 느낌이 난다.
    1. 프레임률과 룸의 스피드는 개념이 다르다.
  3. ip4에서는 4 –> 해상도가 세로로 960이나 되다 보니 프레임당 2,3픽셀 움직이는건 거의 안움직이는 것 처럼 보인다.

간단한 파티클

  • 오브젝트의 오른쪽의 액션 탭에서 'draw' 탭 → 'Other' → 'Create Effect'
  • 효과용으로 사전 정의된 파티클을 사용할 수 있다.

마우스

  • 마우스 이벤트는 오브젝트 영역 내에서만 인식
  • 전체 화면에서 클릭된 위치를 보려면, 일반 마우스 클릭이 아니라
  • 'Add Event' → 'Mouse' → 'Global' , 전역 마우스 클릭 이벤트를 설정해야 인식 된다.
  • 스프라이트를 포함하지 않는 컨트롤용 오브젝트 같은 곳에서 사용시 유의

set gravity

  • 오브젝트에 중력 값과 중력이 적용 되는 방향 (잡아 당기는 방향)을 설정한다.
/// 특정 오브젝트에 살짝 튀었다가 떨어지는 것을 설정
// 오브젝트 생성시 : 살짝 위로 가도록 생성, 생성하는 CreateObject 이벤트에 코드로 추가
direction = random_range( 70, 110 );
speed = 3;
/// 'Set the gravity' 액션을 추가
direction = 270 // 다른 direction 과 방향이 같다. ( 0 : right, 90 : up, 180 : left, 270 : down )
gravity = 0.2   // 숫자는 임의 입력이 가능하니 여러 숫자로 테스트. 
// 0.01도(아주 작은 수) 입력 가능. 
// 숫자가 커지면 더 빨리 떨어진다.
// check 'Relative' 중력 방향이 연결된 오브젝트에 영향을 받아 direction 값이 상대적으로 달라진다. 일반적으로 쓰려면 off.

룸(room)

  • 룸은 리소스 트리의 'Rooms' 트리에서 맨 위의 것이 자동 로딩 된다.

배경 사이에 스프라이트 그리기

  • 배경 사이에 스프라이트를 그리고 싶다면,
  • Backgroud[0-9] 를 사용할 때,
  • 스프라이트보다 먼저 보여질 배경에는 Foreground Image를 체크해주면 된다.

버튼과 같이 스프라이트 이미지 각각을 다른 용도로 쓰고 싶을때

우선, 스프라이트 애니메이션이 되지 않도록 설정

image_speed = 0; // 애니메이션 되지 않도록
image_index = 0; // 첫번째 이미지만 그려지도록

Step 이벤트에서 image_index에 스프라이트 번호 0..N을 할당하면 자동으로 이미지가 변경 된다.

// Step 이벤트에서 액션은.. 뭐 알아서. draw 라든지 draw_gui라든지.
image_index = 2; // 2 번 이미지를 그린다.
//.. 어쩌구 저쩌구.
image_index = 1; // 1번 이미지로 바꾼다.
language/gamemaker/1-코딩하면서-남기는-메모.txt · 마지막으로 수정됨: 2022/12/07 22:30 저자 kieuns