반응형
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
반응형
2020. 11. 15. 16:17 앱개발/코듈러,앱인벤터
728x90
반응형

레이블이나 버튼 등 컴포넌트에 들어가는 문자열의 줄바꾸기를 하는 방법입니다.

코둘라의 경우 컴포넌트의 속성 중 [Advanced Properties]를 활성화 한 후 [HTML]을 체크하여 활성화 합니다.

앱인벤터는 속성 중 [HTML 형식]을 체크하여 활성화하면 됩니다.

 

그리고 해당 컴포넌트의 문자열 중 줄 바꾸기를 희망하는 위치에 <br>을 삽입하시면 됩니다.

 

일반 문자열 예> 여기를 터치하여 교과서를 선택하세요.

줄바꾸기 예> 여기를 터치하여 <br> 교과서를 선택하세요.

 

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

[앱인벤터 도움말 참고] ai2.appinventor.mit.edu/reference/other/any-component-blocks.html

 

Any Component Blocks

A common concept when writing apps is “Don’t Repeat Yourself” (or DRY). Rather than making lots of repetitive code, by copy and paste for example, you can instead use special blocks called “Any Component” blocks. What exactly is an “any compone

ai2.appinventor.mit.edu

 

처리할 동일한 모양의 버튼이 다수일 때 일일이 버튼별로 블럭을 만드는 것이 정말 고역입니다.

이때 이것을 쉽게 처리할 수 있는 방법입니다.

어떤 버튼이 눌러지든 그 버튼을 원하는 처리를 하는 방식입니다.

Any Component Blocks 활용하는 예제입니다.

꼭 버튼 뿐만 아니라 동일한 모양의 컴포넌트가 다수일 때 동일하게 적용할 수 있는 방법입니다.

 

예를 들어서 아래 그림과 같이 디자인을 한 경우

가,갸,거,겨~ 라벨을 클릭가능하게 하고 해당 라벨을 클릭하면 TTS컴포넌트로 자모의 발음을 처리하려고 합니다.

만약 이것을 각 라벨을 클릭하면 해당 라벨의 Text를 읽어서 TTS처리하고, 텍스트색상을 적색으로 변경하려한다면

다음과 같이 코딩을 해야할 것입니다. 라벨이 한 두개면 몰라도 수십 수백개일 경우 각 라벨마다 하나씩 블럭코딩을 해야할 것입니다.

그런데 이것을 하나의 블럭코딩으로 처리하는 방법이 바로 일괄버튼(Any component)을 사용하는 것입니다.

일괄버튼은 블록의 맨 맽에 있습니다. +를 클릭하면 사용할 수 있는 컴포넌트 목록이 펼쳐집니다.

Any Label을 클릭하면 다음과 같은 블럭들이 목록에 뜨게 되고 그 중 선택을 합니다.

노란색은 아무 레이블이나 클릭했을 때 처리하기 위한 블럭이며

연한 색은 해당 컴포넌트의 값을 가져오는 것이고

진한 색은 해당 컴포넌트의 값을 변경하는 것입니다.

 

이제 다음과 같이 블럭을 구성하시면 됩니다.

1(component)을 클릭하고 2에서 get.component를 클릭하여 3에 결합하면 됩니다.

이제 어떤 레이블을 클릭하면 해당 레이블의 text를 가져와서 TestToSpeech처리를 하고

해당 레이블의 텍스트 색상을 적색으로 변경하는 처리를 하게 됩니다.

수십개의 블럭을 하나로 처리할 수 있게 되었습니다.

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

Firebase의 Realtime Database를 활용하면서 알게된 몇가지를 공유하려 합니다.

혹시 실시간 데이타베이스 사용에 관한 더 많은 정보를 알고 계시면 알려주시면 감사하겠습니다.

 

일단 실시간데이타베이스는

1. 온라인상에서 바로 바로 데이타베이스를 공유하면 변경내용을 참조할 필요가 있을 때 사용합니다.

  예를 들자면 둘 이상이 사용자가 게임을 할 때 실시간으로 데이타를 공유할 필요가 필요할 때일 것입니다.

2. 파이에베이스 실시간 데이타베이스를 제가 여러가지 방법으로 실시간 데이타 변경내용을 참조하다보니 체득하게 된 사항입니다. 버킷내에 태그가 여러 개 있을 경우에 실시간 데이타 변경이 짧은 시간에 여러 개가 발생할 경우 시간상 제일 나중에 변경된 것을 참조하는 것 같았습니다. 무슨 말인가하면 앱에서 순ㄴ차적으로 발생시켰다고 실시간 데이타베이스도 그 순서대로 변경되지 않을 수도 있기 때문에 참조하는 데 있어서 혼란이 발생하기도 한다는 것입니다.

3. 그래서 이런 혼란을 방지하고자 생각해낸 방법이 변수 하나에 버킷 하나만 만드는 것입니다.

당연히 RealtimeDatabase의 컴포넌트도 각 변수대로 추가하여야 할 것입니다. 버킷에 태그도 1개만 만드세요. 그래야 혼란이 발생하지 않더라구요.

4. 그래서, 각 변수에 한 개의 컴포넌트를 추가하고 각 컴포넌트 별로 한 개의 버킷,태그만을 지정하면 서로 헛갈리지 않고 잘 인식합니다. |^.^|

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

ProgressBarExample.aia
0.00MB

프로그레스바를 구현한 예제(aia)를 파일로 첨부했습니다.

프로젝트 메뉴 중 [Import project(.aia) from my computer]를 선택하고 다운로드 한 첨부 파일을 선택하면 확인하실 수 있습니다.

그림처럼 ㅇ에서 100까지 막대가 초록색으로 채워지는 스크린입니다.

 

블럭의 코딩입니다.

 

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

그림을 1초간만 보여주고 사라지게 하는 예제입니다.

먼저 다른 블록에 원하는 [ image / picture / 그림 파일명]을 지정합니다.

clock의 Time Interval을 원하는 시간[1000은 1초에 해당]의 숫자를 연결합니다.

clock의 Time Enavled를 true로 해줍니다.

 

그리고 clock.Timer에다가 

Time Enabled를 [False]로 해주고

Image Picture의 파일명을 공백처리해줍니다.

 

그러면 해당하는 그림을 1초간 보여주고 그림이 사라집니다.

이 기능을 구현하기 위해서 참 오랜 시간과 노력이 필요했었습니다.

이 기능을 구현하게 되어 참 기쁩니다. |^.^|

 

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

코둘라에서 폰트를 내가 원하는 것으로 변경이 가능합니다. 

먼저, 인터넷에서 원하는 폰트를 파일로 다운로드합니다.

아래 링크로 가시면 이쁜 무료 폰트가 다양하게 있습니다.

 

 

상업적 이용 가능한 무료 한글 폰트 모음 사이트 눈누

상업적으로 이용할 수 있는 무료 한글 폰트를 모아 놓은 사이트 눈누

noonnu.cc

 

다운로드 한 폰트파일을 [Assets]에 업로드합니다.

 

해당 레이블이나 버튼 등 텍스트가 있는 컴포넌트의 속성 중 [Advanced properties]를 클릭하고

Font TypeFace Import를 클릭하여 방금 업로드한 파일을 선택하면 디자인의 폰트가 변경됩니다.

기본 폰트
MapleStory 폰트 적용

야호! 이제 원하는 폰트로 이쁘게 바로 디자인 해보세요!

728x90
반응형
posted by P2SKLife
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
prev 1 ··· 4 5 6 7 8 9 next

728x90
반응형