2011년 6월 16일 목요일

제 4 장 스크린 초기화, 변수 및 타이머 1 (준비단계 및 학습소개)

제 장 스크린 초기화, 변수 및 연속 동작

1. 만들고자 하는 앱

앱인벤터를 사용하여 인사하는 문구를 연속적으로 나타내는 간단한 앱을 만든다.

2. 준비하기

1. 인사말을 나타내는 장면을 만들기 위해 컴퓨터에 그림파일을 4개 준비한다.












나중에 설명하는 바와 같이이들 그림파일을 디자이너 창에서 업로드한다.

참고 사항: 그림 파일은 jpg, png, gif 등을 사용할 수 있다일반적으로 png를 사용하는 것이 바람직하다 

2. 압축파일(MyIntroduction.zip)을 풀어서 폴더(assets)안에 있는 상기 그림파일을 사용하여도 된다.


3. 시작하기

앱인벤터 웹사이트에 액세스하여 새로운 프로젝트를 시작한다.   프로젝트 명칭을MyIntroduction으로 기재하고스크린의 타이틀을 인사말로 한다.   블록에디터를 열고에뮬레이터 또는 안드로이드폰을 접속한다.  이에 대해서는 이미 설명하였으므로 관련된 설명을 참조한다.

앱인벤터의 디자이너 창의 좌측에 위치하는 속성(Properties)컬럼에서 아래의 스크린샷과 같이 타이틀(Title)난에 인사말을 입력하면 타이틀바에 인사말이라고 적힌 글씨가 나타난다.


참고 사항: 속성(Properties)컬럼의 아이콘(Icon)은 앱파일의 아이콘이다일반적으로 그림파일을 업로딩하지 않는 경우에는 디폴트값으로 앱인벤터에서 제공하는 아이콘으로 표시된다.  경우에 따라서는아이콘의 그림파일을 업로딩하라는 경고표시를 하는 경우도 있다.

4. 학습소개

인사문구의 연속동작을 제어하는 앱을 디자인한다.

학습요지:
  1. 변수블록(def variable as)을 사용하여 이미지 리스트를 정의한다.
  2. 변수블록(def variable as)을 사용하여 인덱스변수를 정의한다.
  3. 이미지 리스트의 위치정보를 기록하는 인덱스변수를 사용하여이미지 리스트의 이미지파일을 일정한 순서로 호출한다.
  4. 앱을 실행할 때 초기화하는 방법에 대해 알아본다.
  5. 이미지의 연속적인 변화를 나타내기 위해 클록의 타이머를 이용한다.

참고사항: 상기에서 설명한 이미지 리스트, 인덱스변수, 스크린초기화 및 타이머 등의 블록은 다음의 스크린샷에 나타난 바와 같다. 이에 대해서는 제 4 장 스크린초기화, 변수 및 연속동작 3 (구성요소 활력 불어넣기)에서 나중에 상세하게 설명한다.










2011년 6월 15일 수요일

제 3 장 자기소개서 앱 만들기 3 (블록에디터창 작업)

6. 구성요소에 활력 불어넣기

1. 블록에디터의 좌측상부에는 내장블록(Built-In)과 사용자블록(My Blocks)이 있다이들 탭중에서 하나를 선택하면 복수의 드로워(Drawer)가 나타나고각각의 드로워안에는 구성요소에 활력을 불어넣기 위해 사용되는 다수의 블록이 있다.

내장블록(Built-In)측에는 앱인벤터 자체의 프로그램시에 미리 준비된 다수의 블록이 존재하고사용자블록(My Blocks)측에는 디자이너창에서 작업한 구성요소에 대응하여 생성된 다수의 블록이 존재한다.

2. 구체적으로는블록에디터를 오픈하고 좌측에 위치한 사용자 블록(My Blocks)을 선택하면 디자이너창에서 작업한 액티비티스타터, 브로그 버튼페이스북 버튼폰넘버 버튼, 4개의 캔버스폰콜 및 스크린(Screen1) 등에 각각 대응하는 복수의 드로워(Drawer)가 나타난다.  이외에도사용자정의(My Definitions)드로워가 나타난다.

 3. 이제부터는본 예제에서 실제로 사용되는 블록에 대해서 설명한다.

3-1. 폰넘버버튼(ButtonPhoneNumber)을 터치하여 클릭이벤트가 발생하면 텍스트블록에 기재된 번호를 전화번호로 설정하고자동으로 전화를 거는 기능블록을 가진 폰넘버버튼의 핸들러에 대해 설명한다.

3-1-1. 사용자블록(My Blocks)탭의 폰넘버버튼(ButtonPhoneNumber)드로워를 열고 폰넘버버튼의 클릭이벤트핸들러(when ButtonPhoneNumber.Click do)를 선택하여 작업영역으로 드래그한다.







3-1-2. 내장블록(Built-In)탭의 텍스트(Text)드로워를 열고 텍스트블록(text text)를 선택하여 작업영역으로 드래그하고 텍스트블록내의 우측하부에 위치한 text를 더블클릭하여 전화번호를 기재한다.


참고사항: 전화번호를 기재하기 위해 텍스트블록(text text)을 사용하지 않고 숫자블록(number 123)을 사용하여 123 0312441443을 기재하여 전화번호로 사용하면 앞에 숫자 0을 생략한312441443의 번호로 전화를 걸게 되어 통화할 수 없다.

3-1-3. 사용자블록(My Blocks)탭의 폰콜(PhoneCall1)드로워를 열고 폰콜의 폰넘버설정블록(set PhoneCall1.PhoneNumber to)을 선택하여 작업영역으로 드래그하고이 블록의 소켓(to)에 상기 텍스트블록을 플러그인한다.

상세하게는, 소망의 전화번호를 전화걸기의 전화번호로 설정한다.






3-1-4. 또한폰콜(PhoneCall1)드로워를 열고 폰콜의 전화걸기 호출블록(call PhoneCall1.MakePhoneCall)을 선택하여 작업영역에 드래그한다.

상세하게는, 전화번호버튼의 클릭이벤트시에, 상기와 같이 준비한 정보자료를 바탕으로 전화걸기를 실행하도록 하는 폰콜의 전화걸기기능을 호출한다.






3-1-5. 이와 같이 조합한 기능블록을 상기 폰넘버버튼의 클릭이벤트핸들러(when ButtonPhoneNumber.Click do)의 섹션(do)에 놓는다. 따라서, 버튼을 클릭하면 이벤트가 발생하여 전화번호를 설정하고 전화를 건다.










 3-2. 브로그버튼(ButtonBlog)을 터치하여 이벤트가 발생하면, 텍스트블록에 기재된 뷰의 액션을 화면전환의 액션으로 설정하고인터넷주소를 화면전환의 정보로서 설정하고, 이와같이 설정된 정보에 의거하여  액티비티스타터에 의해 화면전환을 개시하는 브로그버튼의 핸들러에 대해 설명한다.

3-2-1. 사용자블록(My Blocks)탭의 브로그버튼(ButtonBlog)드로워를 열고 브로그버튼의 클릭이벤트핸들러(when ButtonBlog.Click do)를 선택하여 작업영역으로 드래그한다 .





3-2-2. 내장블록(Built-In)탭의 텍스트(Text)드로워를 열고 텍스트블록(text text) 2회 선택하여 작업영역으로 드래그하고 텍스트블록내의 우측하부에 위치한 text를 더블클릭하여 
android.intent.action.VIEW 및 http://blog.naver.com/maeumsam을 각각 기재한다.


3-2-3. 사용자블록(My Blocks)탭의 액티비티스타터(ActivityStarter1)드로워를 열고 액티비티스타터의 액션 설정블록(set ActivityStarter1.Action to) 및 액티비티스타터의 Uri 데이터 설정블록(set ActivityStarter1.DataUri to)를 순차적으로 선택하여 작업영역으로 각각 드래그한다각각의 블록의 소켓(to)에 해당 텍스트블록을 플러그인한다

상세하게는, 인텐트라는 툴을 통하여 뷰의 액션을 화면전환의 액션으로 설정하고 인터넷주소를 뷰의 정보로 설정한다. 다시 말하면 브라우저를 런칭하여 인터넷주소를 브라우징하는 정보를 준비하는 과정을 말한다.




3-2-4. 또한상기 액티비티스타터(ActivityStarter1)드로워를 열고 액티비티스타터의 스타트액티비티 호출블록(call ActivityStarter1.StartActivity)을 작업영역에 드래그한다.

상세하게는, 브로그버튼의 클릭이벤트시에, 상기와 같이 준비한 정보자료를 바탕으로 화면전환을 개시하여 실행하도록 하는 액티비티스타터를 호출한다.


3-2-5. 이와 같이 조합한 기능블록을 상기 로그버튼의 클릭이벤트핸들러(when ButtonBlog.Click do)의 섹션(do)에 놓는다. 따라서, 브로그버튼의 클릭시에 이벤트를 발생하여 브라우저를 런칭하여 인터넷주소를 브라우징한다.


3-3. 페이스북버튼(ButtonFacebook)을 터치하여 이벤트가 발생하면, 브로그버튼과 마찬가지로,텍스트블록에 기재된 뷰의 액션을 화면전환의 액션으로 설정하고, 인터넷주소를 화면전환의 정보로서 설정하고, 이와같이 설정된 정보에 의거하여 액티비티스타터에 의해 화면전환을 개시하는 페이스북버튼의 핸들러에 대해 설명한다.

3-3-1. 사용자블록(My Blocks)탭의 페이스북버튼(ButtonFaceBook)드로워를 열고 페이스북버튼의 클릭이벤트핸들러(when ButtonFacebook.Click do)를 선택하여 작업영역으로 드래그한다.  


3-3-2. 내장블록(Built-In)탭의 텍스트(Text)드로워를 열고 텍스트블록(text text) 2회 선택하여 작업영역으로 드래그하고 텍스트블록내의 우측하부에 위치한 text를 더블클릭하여android.intent.action.VIEW 및 http://on.fb.me/e333fP를 각각 기재한다.



3-3-3. 사용자블록(My Blocks)탭의 액티비티스타터(ActivityStarter1)드로워를 열고 액티비티스타터의 액션 설정블록(set ActivityStarter1.Action to) 및 액티비티스타터의 Uri 데이터 설정블록(set ActivityStarter1.DataUri to)를 순차적으로 선택하여 작업영역으로 각각 드래그한다각각의 블록의 소켓(to)에 해당 텍스트블록을 플러그인한다.

상세하게는, 인텐트라는 툴을 통하여 정보로서 뷰의 액션을 화면전환의 액션으로 설정하고 인터넷주소를 뷰의 정보로 설정한다. 다시 말하면 브라우저를 런칭하여 인터넷주소를 브라우징하는 정보를 준비하는 과정을 말한다.




 3-3-4. 또한상기 액티비티스타터(ActivityStarter1)드로워를 열고 액티비티스타터의 스타트액티비티 호출블록(call ActivityStarter1.StartActivity)을 작업영역에 드래그한다.

상세하게는, 페이스북버튼의 클릭이벤트시에, 상기와 같이 준비한 정보자료를 바탕으로 화면전환을 개시하여 실행하도록 하는 액티비티스타터를 호출한다.


3-3-5. 이와 같이 조합한 기능블록을 상기 페이스북버튼의 클릭이벤트핸들러(when ButtonBlog.Click do)의 섹션(do)에 놓는다.  따라서, 페이스북버튼의 클릭시에 이벤트를 발생하여 브라우저를 런칭하여 인터넷주소를 브라우징한다.


3-4. 참고로서전화걸기 및 액티비티의 런칭을 블록의 말풍선을 사용하여 확인한다

3-4-1. 에뮬레이터 또는 안드로이드폰을 에디터블록창에 접속한 상태에서폰콜의 전화걸기 호출블록(call PhoneCall1.MakePhoneCall) 및 액티비티스타터의 스타트액티비티 호출블록(call ActivityStarter1.StartActivity)위에 각각 순차적으로 마우스커서를 올려놓고 마우스의 오른쪽버튼을 클릭하면 세로메뉴가 나타난다. 


3-4-2. 이 세로메뉴에서 메뉴(watch)를 선택하여 클릭하면 블록의 좌측상부에 백색의 사각형이 형성되고이 사각형을 더블클릭하면 말풍선이 나타난다.


3-4-3. 안드로이드폰에 해당 버튼을 터치하여 이벤트가 트리거되면 전화걸기가 시작되거나 소망의 웹브라우저가 런칭되어 소망의 블로그 또는 페이스북을 브라우징한다.



3-4-4. 한편전화걸기와 웹브라우저의 런칭이 시작되면서말풍선에는 “Done.”라고 하는 문자가 나타난다.




3-4-5. 라이브테스트가 완료되면폰콜의 전화걸기 호출블록(call PhoneCall1.MakePhoneCall)및 액티비티스타터의 스타트액티비티 호출블록(call ActivityStarter1.StartActivity)위에 각각 순차적으로 마우스커서를 올려놓고 마우스의 오른쪽버튼을 클릭하면 세로메뉴가 나타난다이 세로메뉴에서 메뉴(Stop Watching)를 선택하여 클릭하면 말풍선이 사라진다. 


참고사항: 상기 조합블록은 비교적 단순하기 때문에상기 라이브테스트는 하지 않아도 된다. 그러나경우에 따라서는 상기 설명한 바와 같은 요령으로 테이터의 흐름을 추적하면 앱완성에 결정적인 도움을 준다.

4. 지금까지의 설명한 블록을 종합하여 나타내면 다음의 스크린샷과 같다.





5. 요약

기초부터 시작하지 않고 실생활에 유용하다고 생각되는 자기소개용 어플을 소개하였다. 전화를 거는 기능블록 및 블로그 또는 페이스북 등의 인터넷에 액세스하는 스타트액티비티의 주용기능을 배웠다.

참고사항 1: 초보자에게는 설명이 어려울 수 있다. 하고 싶은 의욕만 있다면 설명을 전부 무시하고 디자이너창에서 구성요소를 따라하고, 블록에디터창에서 블록을 끌어다 놓으면 된다. 성취감을 느낄수 있다.

참고사항 2: 그래도 어려우면, 제 3 장 자기소개서 앱 만들기 1 (준비단계 및 학습소개)에 첨부된 압축파일을 풀지말고 제 2 장 앱인터의 레이아웃 1 (사용자 프로젝트창)의 4-3에서 설명한 업로드 소스버튼난을 참조하여 업로드하면 디자이너창 및 블록에디터창에 지금 까지 복잡하게 설명한 블록의 조합을 볼수 있다. 이를 참고하면 쉽게 해결될 수 있다.