반응형
P2SK의 라이프
블로그 이미지
P2SKLife
앱개발에 대한 정보와 취미인 음악감상에 대한 정보를 공유합니다.

calendar

1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31

Notice

250x250
반응형
728x90
반응형

앱인벤터도 최근 복사기능이 추가되었다.

코듈러도 복사[이동]기능이 가능하다.

 

Kodular에서는 [Copy Screen]을 하면 현재 Screen을 복사하여 새로운 Screen을 만들어 준다.

App Inventor에서는 화면을 추가하고 컴포넌트를 복사하기[Ctrl+C] 또는 잘라내기[Ctrl+X] 후

원하는 위치 바로 위의 컴포넌트를 선택한 후 붙여넣기[Ctrl+V]하면 된다.

해당 컴포넌트의 블럭까지도 복사가 된다.

이제 컴포넌트를 복사하기와 붙여넣기로 손쉽게 작업할 수 있게 되었다.

 

728x90
반응형
posted by P2SKLife
2020. 10. 31. 12:08 앱개발/코듈러,앱인벤터
728x90
반응형

앱인벤터는 광고를 직접 등록할 수가 없지만 간접적으로 할 수 있습니다.

앱인벤터로 제작한 앱을 파일(aia확장자)로 다운로드 받습니다.

메뉴의 [프로젝트]에서 [선택된 프로젝트(aia)를 내 컴퓨터로 보내기]를 선택하시면 됩니다.

kodular를 실행하시고 메뉴 중 [Project]에서 [Import project (.aia) from my computer]를 선택하고 방금 다운로드 받은 파일을 선택하면 됩니다.

 

이제 AdMob광고를 디자인하고 블럭코딩을한 후 광고ID를 복사해 넣으면 됩니다.

이때 주의사항은 제작자는 광고를 클릭하시면 안됩니다.

그러면 광고승인이 안될 수 있습니다. 일종의 부정클릭인 셈이라고 할까요.. 이점 주의하세요..

 

먼저 컴포넌트를 추가해야합니다.

컴포넌트 메뉴 중 맨 밑에서 세번째 [$ Monetization]-[Advertising]를 클릭하면

AdMob광고 컴포넌트가 있습니다.

AdMob Banner는 화면 상단 또는 하단 등 일부 공간을 차지하여 계속 보여주는 배너광고입니다.

AdMob Interstitial은 화면이 바뀔때 화면전체에 광고를 보여주는 전면광고입니다.

[Designer]에서 이것을 원하는 스크린에 추가하세요.

[Blocks]에서 위와 같이 코딩하세요. [Battle]은 스크린이름입니다. [Menu]는 화면이동을 위한 버튼이름입니다.

이제 AdMob에서 광고를 등록하고 ID를 복사해서 붙여넣기 해야합니다.

혹시 AdMob에 아직 등록이 안되었다면 구글계정으로 간편하게 할 수 있습니다.

 

AdMob에 로그인 한 후

메뉴 중 [앱]을 클릭하고 [앱 추가]를 클릭하세요.

앱을 앱마켓에 아직 등록안 했기 때문에 [아니요]를 클릭합니다.

[앱 정보 입력]에서 [앱이름]을 입력하고, 플랫폼[Android, ios] 중 선택하고 [추가]를 클릭하세요.

[다음단계:광고단위만들기]를 클릭하세요.

[배너]를 선택하세요.

[광고 단위 이름](예:상단,하단,전면 등)을 입력하고 [광고단위만들기]를 클릭하세요.

[완료]를 클릭하세요.

화살표를 클릭하면 광고ID가 복사됩니다.

이제 kodular [designer]로 돌아와서

AdMobBanner를 클릭한 후

속성을 그림처럼 처리합니다.

방금 복사한 ID를 Ad Unit Id에 붙여넣기합니다.

Test Mode는 클릭해제합니다.

[전면]과고도 배너와 같은 방법으로 하시면 됩니다.

 

이제 앱을 실행하면 광고가 보이게 됩니다.

 

 

 

728x90
반응형
posted by P2SKLife
2020. 10. 29. 17:43 앱개발/코듈러,앱인벤터
728x90
반응형

인터넷에서 아이콘을 다운 받습니다. 이때 그림 파일의 확장자를 png(배경 투명 처리)인 것을 고르시면 됩니다.

일반 jpg확장자 아이콘은 배경색이 투명이 아니라 회전시키면 CD회전하는 모양이 제대로 구현되지 않습니다.

Image 콤포넌트를 핸드폰 화면 원하는 위치에 추가한 후 다운 받은 아이콘을 속성의 picture에 추가합니다.

이때 Height와 Width를 핸드폰에 화면에 맞게 크기를 [숫자, %, auto, parent] 을 사용하여 적절하게 조절합니다.

그리고 디자인에서 콤포넌트 중 [clock]을 추가합니다.

이 클락의 [interval]을 기본 1000으로 하지 말고 대략 50 내외의 숫자로 조정합니다.

그래야 영화의 프레임과 같이 적절한 회전 모양이 구현됩니다. 숫자가 크면 뚝 뚝 끊기는 현상이 발생하니 숫자를 적당히 보기 좋은 모양이 구현되는 것으로 조절하세요.

그리고 위와 같이 블럭을 처리하시면 됩니다. 이때 더하는 숫자도 적절하게 본인의 취향에 맞춰 조절하시면 됩니다.

숫자가 너무 크면 역시 부드럽지 않은 회전이 구현됨으로 적절하게 조절하시면 됩니다.

728x90
반응형
posted by P2SKLife
2020. 10. 29. 17:30 앱개발/코듈러,앱인벤터
728x90
반응형

Before     Next       Play        Pause      Stop

디자인에서 그림과 같이 버튼을 배치합니다.

물론 이미지는 따로 아이콘을 다운받아서 버튼 속성에서 Image에 추가하면 됩니다.

 

 

[Total Time]은 유튜브 음원의 총 재생시간을 처리하는 루틴입니다. 생략해도 됩니다.

[Before]버튼에서는 유튜브를 일시정지시키고 시작 포지션을 0로 세팅해줍니다. 그리고 유튜브 목록의 인덱스를 하나 감소시켜주고 유튜브를 play합니다.

[Next]버튼에서는 유튜브를 일시정지시키고 시작 포지션을 0로 세팅해줍니다. 그리고 유튜브 목록의 인덱스를 하나 증가시켜주고 유튜브를 play합니다.

 

728x90
반응형
posted by P2SKLife
2020. 10. 29. 17:07 앱개발/코듈러,앱인벤터
728x90
반응형

디자인에서 버튼[Quit]을 만들어 놓습니다.

이 버튼을 클릭하면 앱을 종료할지 여부를 묻고 그 대답에 따라 처리하는 예제입니다.

버튼의 순서가 참 그렇더라구요.. 위 그림처럼 하시면 왼쪽에 [예], 오른쪽에 [아니오], 취소버튼은 생략됩니다.

728x90
반응형
posted by P2SKLife
2020. 10. 18. 20:11 앱개발/코듈러,앱인벤터
728x90
반응형

Firebase Realtime Database를 등록 유효날자가 경과하니 Permission Denied 에러 메시지가 허걱!

데이타베이스에 저장이 안된다.. 헐!

그래서 여기저기 검색해보다가 규칙설정의 읽고 쓰기를 true로 변경하면 된다하여 다음 그림과 같이 했더니

다행히 다시 저장이 되기 시작했다.

Firebase에 로그인 해서

1. Realtime Database을 클릭한다.

2. [규칙]을 클릭한다.

3. [규칙수정]에서 그림과 같이 true루 수정을 한다.

그러면 화면에 위와 같은 팝업창이 나타나는데 이때 [게시]를 과감히 클릭한다. 끝...

 

728x90
반응형
posted by P2SKLife
2020. 10. 18. 18:03 앱개발/코듈러,앱인벤터
728x90
반응형

DB중 실시간 자료 갱신여부를 체크해주는 Firebase의 Realtime Database 등록 및 설정 방법을 알려드리겠습니다.

 

 

 

Firebase

Firebase는 고품질 앱을 빠르게 개발하고 비즈니스를 성장시키는 데 도움이 되는 Google의 모바일 플랫폼입니다.

firebase.google.com

1. 먼저 firebase에 가입을 해야합니다. 위 링크를 클릭하여 회원가입을 합니다.

대부분 구글계정이 있으시기 때문에 별도 절차없이 구글 계정으로 로그인 하시면 바로 이용할 수 있습니다.

2. 로그인 후 [시작하기]를 클릭합니다.

3. [프로젝트 추가]를 클릭합니다.

4. 프로젝트 이름을 영문4자 이상으로 하여 원하는 문자를 입력한 후 [계속]을 클릭합니다.

5. [계속]을 클릭합니다.

6. 계정을 선택한 후 [프로젝트 만들기]를 클릭합니다.

7. 프로젝트가 생성중입니다. 잠시만 기다리면 완성됩니다.

8. 이제 [sample]이라는 프로젝트가 준비되었습니다. [계속]을 클릭하시면 됩니다.

9.  좌측 메뉴 중 [Realtime Database]를 클릭합니다.

10. [데이타베이스 만들기]를 클릭합니다.

11. [테스트 모드에서 시작]을 선택하고 [사용 설정]을 클릭합니다.

12. 이제 나만의 실시간 데이타베이스 공간이 확보되었습니다. 일단, 빨간 화살표의 클립아이콘을 클릭하여 빨간 네모안의 url주소를 복사합니다.

13. 코둘라(앱인벤터)에서 Firebase RetimeDatabse 컴포넌트 항목을 디자인에서 추가 한후 속성 화면을 보시면 위와 같이 3개의 항목을 이제 채워 넣어야 통신이 가능해집니다. 이 중 1,2번은 firebase에서 값을 복사해와야 하며, 3번은 임의의 문자열을 원하는 대로 입력하면 됩니다. 일종의  폴더명이라고 생각하시면 쉽습니다.

자, 12번에서 복사한 값을 위의 2번 URL칸에 붙여넣기합니다. 

14. 이번엔 1번 토큰값을 복사하는 방법입니다. 다시 Firebase 화면으로 갑니다.

     빨간 원의  톱니 아이콘을 클릭하고 [프로젝트 설정]을 클릭합니다.

15. 웹API키 검은선 부분을 복사합니다. 그리고 12번의 1번 네모칸[Token]에 붙여넣기합니다.

자, 이제 대망의 실시간 데이타베이스 사용 준비가 완료되었습니다.

활용 예제는 다음에 올려드리도록 하겠습니다. 

 

16. 그리고 끝으로 읽고 쓰기 권한 규칙을 수정해 주지 않으면 나중에 permission denied로 읽고 쓰기가 불가능해질 시기(한달 뒤)가 옵니다. 바로 규칙을 다음과 같이 수정해줍니다.

16. 위 그림과 같이 규칙을 수정해 주고 

17. [게시]를 클릭해 줍니다... 이제 읽고 쓰기 권한이 부여되었으니 거부당할 일이 없습니다...

728x90
반응형
posted by P2SKLife
2020. 10. 17. 14:53 앱개발/코듈러,앱인벤터
728x90
반응형

리스트를 행을 나누어 변수에 저장하는 방법입니다.

먼저 디자인에서 [HTML Format]을 활성화 시켜줍니다.

 

블럭코딩에서 위 그림과 같이 리스트와 변수를 설정합니다.

for each 블럭으로 해당 리스트[Title]의 길이를 구해서[length of list] 1까지 역순[-1]로 반복하게 합니다.

1부터 하면 맨 마지막 행이 맨 위로 합쳐지기 때문에 첫 행을 맨 나중에 합쳐지게 하려면 역순으로 처리해야합니다.

그리고 변수[Title2]에 줄바꿈 명령어<br>을 삽입하여 이전 상태에 다시 ㅊ행을 추가하면 행이 나위어져 문자열이 합쳐집니다.

단순히 리스트를 거꾸로 정렬하는 reverse도 있으니 잘 조합하면 뭔가 멋진 그림이 그려질 것입니다.

 

728x90
반응형
posted by P2SKLife
2020. 10. 17. 13:56 앱개발/코듈러,앱인벤터
728x90
반응형

교과서를 선택 한 후 그 교과서에 수록된 곡목을 선택하기 위한 디자인입니다.

1단계 : 첫번째 리스트피커인 [교과서]의 목록을 선택하기 위한 리스트[ListTextBook]를 [Before Picking] 컴포넌트에 입력합니다.

2단계 : 선택한 교과서명을 화면의 ListPicker에 표시하기 위해 [After Picking]컴포넌트에 지정합니다.

         여기서는 선택한 교과서명에 해당하는 파일을 읽는 과정을 [After Picking] 단계에서 시작하는 예제입니다.

         2단계에서 교과서를 선택하면 해당 교과서 파일을 읽어 들입니다.

         여기서 파일명은 관리하기 편하도록 인덱스번호를 쉽게 활용하기 위하여 교과서명이 아닌 일련번호로 파일명을 정하였습니다.

         파일읽기의 [Get Text]컴포넌트에서 파일의 내용을 리스트로 변환합니다.

         파일에는 [곡목(Title), 유튜브 주소(Youtube), 총재생시간(TotalTime)]으로 저장했습니다.

3단계 :  2단계 처리 과정 중에 두번째 리스트피커[ListTitle]의 [Elements], [Text]를 지정해줍니다.

4단계 : [After Picking] 컴포넌트에 선택 후 처리할 내용을 지정합니다. 여기서는 선택한 곡목의 인덱스번호[Selection Index]를 다른 컴포넌트(유튜브 재생)에 활용하기 위하여 변수[index]에 저장합니다. 

728x90
반응형
posted by P2SKLife
728x90
반응형

총 시간이 초로 되어 있는 것을 분과 초로 나누어 변환하는 예제입니다.

변수 [TempTime]에 들어 있는 숫자(초)를 60으로 나눈 몫(quotient of]으로 분의 값을 구하고

60으로 나눈 나머지(remainder of)로 초의 값으로 구하면 됩니다.

 

728x90
반응형
posted by P2SKLife
prev 1 2 3 4 5 6 next

728x90
반응형