SL4A-GUI 구축
GUI (그래픽 사용자 인터페이스)는 사용자가 애플리케이션 기능을 찾아보고 액세스하고 상호 작용할 수 있도록하는 그래픽 구성 요소 집합을 나타냅니다.
SL4A와의 사용자 상호 작용에는 두 가지 기본 접근 방식이 있습니다.
다음과 같은 대화 상자 Alerts.
HTML 및 JavaScript를 사용하여 UI를 빌드 한 다음 Python을 사용하여 추가 처리를 처리합니다.
이 장에서는 두 가지 접근 방식을 모두 설명합니다.
Python 대화 상자 – 기반 GUI
SL4A에는 Android API에서 제공하는 기본 UI 요소에 액세스하기위한 UI façade가 포함되어 있습니다. 이러한 함수는 호출시 결과 객체를 명명 된 튜플로 반환합니다. 각 결과에는 추적 목적으로 고유 한 ID가 할당됩니다. 두 번째 요소는 결과입니다. 사용자의 입력을 나타냅니다. 튜플에는 발생할 수있는 오류 조건에 대해 호출자에게 피드백을 제공하는 세 번째 요소 오류도 포함됩니다. 오류가 발생하지 않은 경우이 요소는 없음으로 설정됩니다.
S. 아니. | UiFacade 기능 및 설명 |
---|---|
1 | dialogGetInput 사용자에게 텍스트 입력을 요청합니다. title (String) 입력 상자의 제목 (기본값 = 값) message (String) 입력 상자 위에 표시 할 메시지 (기본값 = 값을 입력하십시오 :) defaultText (String) 입력 상자에 삽입 할 텍스트 (선택 사항) 결과는 사용자의 입력이거나 취소가 적중 된 경우 없음 (null)입니다. |
2 | dialogShow 대화 표시 |
삼 | dialogCreateAlert 경고 대화 상자를 만듭니다. title (String)(선택 과목) message (String) (선택 과목) |
4 | dialogDismiss 대화 상자를 닫습니다. |
5 | dialogCreateDatePicker 날짜 선택기 대화 상자를 만듭니다. year (Integer) (기본값 = 1970) month (Integer) (기본값 = 1) day (Integer) (기본값 = 1) |
6 | dialogCreateTimePicker 시간 선택기 대화 상자를 만듭니다. hour (Integer) (기본값 = 0) minute (Integer) (기본값 = 0) is24hour (Boolean) 24 시간제 사용 (기본값 = false) |
7 | dialogGetPassword 사용자에게 암호를 쿼리합니다. title (String) 암호 상자의 제목 (기본값 = 암호) message (String) 입력 상자 위에 표시 할 메시지 (기본값 = 암호를 입력하십시오 :) |
8 | dialogGetResponse 대화 응답을 반환합니다. |
9 | dialogSetPositiveButtonText 경고 대화 상자 긍정적 인 단추 텍스트를 설정합니다. 텍스트 (문자열) |
10 | dialogSetNegativeButtonText 경고 대화 상자 단추 텍스트를 설정합니다. 텍스트 (문자열) |
11 | dialogSetNeutralButtonText 경고 대화 상자 단추 텍스트를 설정합니다. 텍스트 (문자열) |
12 | dialogSetSingleChoiceItems 라디오 버튼 목록이 생성됩니다. |
13 | dialogSetMultiChoiceItems 체크 박스가 생성됩니다. |
14 | dialogCreateHorizontalProgress 수평 진행 대화 상자를 만듭니다. title (String) (선택 과목) message (String) (선택 과목) maximum progress (Integer) (기본값 = 100) |
15 | dialogCreateSpinnerProgress 스피너 진행 대화 상자를 만듭니다. title (String) (선택 과목) message (String) (선택 과목) maximum progress (Integer) (기본값 = 100) |
16 | addContexMenuItem 상황에 맞는 메뉴에 새 항목을 추가합니다. label (String) 이 메뉴 항목의 레이블 event (String) 메뉴 항목 클릭시 생성되는 이벤트 eventData (Object) (선택 과목) |
17 | addOptionsMenuItem 옵션 메뉴에 새 항목을 추가합니다. label (String) 이 메뉴 항목의 레이블 event (String) 메뉴 항목 클릭시 생성되는 이벤트 eventData (Object) (선택 과목) iconName (String) |
18 | webViewShow 주어진 URL로 WebView를 표시합니다. url (String) wait (Boolean) 사용자가 WebView를 종료 할 때까지 차단 (선택 사항) |
19 | clearContextMenu 이전에 컨텍스트 메뉴에 추가 된 모든 항목을 제거합니다. |
20 | clearOptionsMenu 이전에 옵션 메뉴에 추가 된 모든 항목을 제거합니다. |
21 | makeToast 알림 생성 |
예
A simple Toast Example
import android
droid = android.Android()
uname = droid.getInput("Enter your name")
print uname
droid.makeToast("Hello %s" %uname.result)
A Horizontal Progress Bar
import android
droid = android.Android()
title = "Progress"
str = "Loading..."
droid.dialogCreateHorizontalProgress(title,str,100)
droid.showDialog()
for x in range(0,99)
time.sleep(0.1)
droid.dialogSetCurrentProgress(x)
droid.dialogDismiss()
Modal Vs Non-Modal 대화 상자
모달 대화 상자 또는 창은 다른 프로세스 또는 창의 자식입니다. 모달 대화 상자를 사용하면 사용자가 새 대화 상자와 상호 작용할 때까지 처리가 대기하거나 차단됩니다.
이 경우의 일반적인 예는 경고 대화 상자입니다. 사용자가 작업을 수행 할 때까지 경고가 닫히지 않습니다.
다음 이미지는 모달 대화 상자의 예입니다.
요약하면 실행을 계속하기 전에 사용자의 입력이 필요할 때 모달 대화 상자를 사용하십시오.
HTML을 사용한 Python GUI
SL4A는 CSS, HTML, JavaScript 및 Python을 기반으로 그래픽 사용자 인터페이스 (GUI)를 구축 할 수 있습니다. 이 접근 방식은 HTML 및 JavaScript를 사용하여 UI를 빌드하고 CSS를 사용하여 HTML 요소 및 글꼴의 모양과 일관성을 향상시키고 Python을 사용하여 추가 처리를 처리합니다.
다음 예제는 기본적인 HTML GUI 예제를 보여줍니다-
1. Speech.html
<html>
<head>
<title>Text To Speech</title>
<script>
var droid = new Android();
var speak = function(){
droid.postEvent("say",document.getElementById("say").value);
}
</script>
</head>
<body>
<form onsubmit = "speak()";return false;”>
<label for = "say">What is your message?</label>
<input type = "text" id = "say"/>
<input type = "submit" value = "Speak"/>
</form>
</body>
</html>
2. txtToSpeech.py
import android
droid = android.Android()
droid.webViewShow(‘file:///sdcard/sl4a/scripts/Speech.html’)
while True:
result = droid.waitForEvent(‘say’).result
droid.ttsSpeak(result[‘data’])
두 파일 모두- Speech.html and txtToSpeech.py,에 있어야합니다. /sdcard/sl4a/scripts장치의 디렉토리. python 스크립트를 실행하여 HTML 파일을 시작합니다.
이 파일은 webViewShowAPI 호출. 이벤트는Speak 버튼을 클릭합니다.