SL4A - Android API erkunden

SL4A basiert auf dem Facade Design Pattern für die Kommunikation mit der zugrunde liegenden Android-API. In diesem Kapitel wird die Funktionsweise des Fassadenentwurfsmusters und der verschiedenen SL4A-API-Fassaden erläutert.

Was ist ein Fassadenmuster?

Eine Fassade ist ein Objekt, das eine Schnittstelle bereitstellt, die den Zugriff auf die zugehörigen Schnittstellen in der Anwendung vereinfacht. Mit anderen Worten, eine Fassade isoliert die Arbeitsweise der Bibliotheken vom Client und fungiert als Einstiegspunkt für jede Subsystemebene. Somit kommunizieren die Kunden nur über ihre Fassaden. Die folgende Abbildung erklärt dasselbe.

SL4A- und Android-API-Fassaden

SL4A hostet Dolmetscher für jede unterstützte Sprache. Die Interpreter greifen über eine als Fassade bezeichnete Schnittstelle auf die zugrunde liegenden Android-APIs zu.

In der folgenden Tabelle sind die Fassaden der obersten Ebene und die von ihnen bereitgestellten Funktionen aufgeführt:

S.No. Android API Fassade & Beschreibung
1

ActivityResultFacade

Hiermit wird festgelegt, wie Ihr Skript Informationen als Aktivität zurückgibt. Diese Methode impliziert, dass Ihr Skript ein Ergebnis zurückgibt. Der Ergebnistyp kann entweder auf RESULT_CANCELED (0) oder RESULT_OK (-1) gesetzt werden.

2

AndroidFacade

Es bietet Zugriff auf gängige Android-Funktionen wie Lesen von Eingaben, Benachrichtigungen, Starten von Anwendungskomponenten usw.

3

ApplicationManagerFacade

Listen Sie alle verfügbaren und ausgeführten Pakete auf, starten Sie eine Aktivität, erstellen Sie Ihren Task-Manager oder beenden Sie einen bestimmten Satz von Paketen.

4

BatteryManagerFacade

Zeigt den Batteriemanager an und ermöglicht die Verfolgung des Batteriestatus, des Zustands, des Typniveaus, der Spannung usw.

5

BluetoothFacade

Bietet Zugriff auf Bluetooth-Funktionen von den grundlegenden Verbindungsfunktionen bis zum Senden und Empfangen von ASCII- und Binärdaten. Diese Fassade erfordert mindestens API Level 5.

6

CameraFacade

Diese Methode bietet Zugriff auf alle kamerabezogenen Funktionen. Ermöglicht das Aufnehmen eines Bildes mit der Kamera des Geräts und das Speichern unter einem bestimmten Pfad. Es bietet zwei Funktionen, nämlich cameraCapturePicture und cameraInteractiveCapturePicture. Diese Funktionen sind ausschließlich für die Verwendung des Objektivs auf der Rückseite des Geräts vorgesehen.

7

CommonIntentsFacade

Bietet Zugriff auf allgemeine Android-Absichten wie das Öffnen einer Kontaktliste, das Durchführen einer Kartensuche, das Starten einer Aktivität durch Aktion usw.

8

ContactsFacade

Ermöglicht den Zugriff auf Kontakte, z. B. das Bereitstellen der Kontaktliste zum Auswählen eines Kontakts, das Abfragen der Kontaktliste nach Attributen und das Abrufen einer Liste aller Kontakte mit ihren IDs und Attributen. Einige von der Fassade bereitgestellte Methoden umfassen ContactsGet, PickContact, ContactsGetById usw.

9

EventFacade

Das Android-Betriebssystem unterhält eine Ereigniswarteschlange zum asynchronen Übertragen von Informationen zwischen Anwendungen. Diese Fassade bietet Funktionen zum Verwalten der Ereigniswarteschlange, z. B. Löschen vorhandener Ereignisse, Veröffentlichen neuer Ereignisse, Auflisten, Registrieren und Aufheben der Registrierung von Broadcast-Signalen usw. Beispiele für Methoden sind eventPost, eventClearBuffer usw.

10

EyesFreeFacade

Verfügbar auf Geräten unter API-Stufe 4. Es ermöglicht Skripten das Sprechen mithilfe der Text-to-Speech-Technologie. Diese Fassade wird jetzt durch TextToSpeechFacade ersetzt. Die einzige verfügbare Funktion ist ttsSpeak.

11

LocationFacade

Bietet Funktionen, mit denen Sie den aktuellen Standort entweder per GPS oder mithilfe von Informationen zum aktuell verwendeten Mobilfunkmast verfolgen können. Diese Funktion erfordert eine aktive Internetverbindung, um die eigentliche Suche durchzuführen. Die Fassade bietet Methoden wie getLastKnownLocation, startLocating, stopLocating, readLocation usw.

12

MediaPlayerFacade

Ermöglicht das Abspielen von Mediendateien, das Steuern des Media Players, das Abfragen des aktuellen Status des Media Players und das Abrufen von Informationen zu den Mediendateien. mediaIsPlaying, mediaPlayInfo und mediaPlayList geben den aktuellen Status des Media Players zurück. Ein Aufruf der Funktion startActivity startet den Media Player. Funktionen wie mediaPlay, mediaPlayPause, mediaPlayClose, mediaPlaySeek, mediaPlayStart und mediaPlaySetLooping werden zur Steuerung des Media Players verwendet.

13

MediaRecorderFacade

Diese Fassade bietet Audio- und Videoaufzeichnungsfunktionen. Die Funktionen startInteractiveVideoRecording, recorderStartMicrophone und recorderCaptureVideo werden zum Starten bzw. Starten der Audio- / Videoaufzeichnung verwendet. Um eine zuvor gestartete Aufnahme zu beenden, rufen Sie die Funktion recorderStop auf.

14

PhoneFacade

Stellt grundlegende Telefonvorgänge wie das Verfolgen des Telefonstatus, des Roaming-Status, das Einleiten von Anrufen, SIM-Informationen usw. programmgesteuert zur Verfügung. Beispiele für Methoden sind phoneCallNumber, phoneDialNumber, getCellLocation usw.

15

PreferencesFacade

Ermöglicht den Zugriff auf freigegebene Einstellungen wie das Abrufen der Liste vorhandener Einstellungen und das Lesen, Ändern und Hinzufügen neuer Einstellungen. Es gibt drei Funktionen, die von SL4A r4 Release unterstützt werden: prefGetAll, prefGetValue und prefPutValue.

16

SensorManagerFacade

Ermöglicht die Verfolgung von Sensordaten wie Licht, Beschleunigung, Magnetfeld und Ausrichtung. Verwenden Sie zum Starten / Stoppen der Erkennung die Funktionsaufrufe startSensing (veraltet und ersetzt durch startSensingThreshold und startSensingTimed von SL4r4) und stopSensing. readSensoren, SensorenGetLight, SensorenReadAccelerometer, SensorenReadMagnetometer und SensorenReadOrientation sind die Funktionen dieser Fassade.

17

SettingsFacade

Ermöglicht den Zugriff auf verschiedene Telefoneinstellungen wie Ruftonlautstärke, Bildschirmhelligkeit, Flugzeugmodus, Vibration, Medienlautstärke usw. Die von dieser Fassade bereitgestellten Funktionen sind checkAirplaneMode, checkRingersilentMode und checkScreenOn (mindestens API-Stufe 7), getVibrateMode, setScreenTimeout, toggleVibrateMode setRingerVolume usw.

18

SignalStrengthFacade

Ermöglicht die Überwachung der Telefonsignalstärke. Rufen Sie die Funktion startTrackingSignalStrengths auf, um mit dem Sammeln von Daten zu beginnen. Rufen Sie die Funktion readSignalStrengths auf, um mit dem Sammeln von Daten zu beginnen. Um den Prozess herunterzufahren, rufen Sie die Funktion stoptrackingSignalStrengths auf. Es erfordert mindestens API-Level 7.

19

SmsFacade

Es verfügt über Funktionen zum Löschen, Lesen, Markieren und Senden von SMS-Nachrichten. Beispiele für Funktionen dieser Fassade sind smsMarkMessageRead, smsDeleteMessage, smsSend usw.

20

SpeechRecognitionFacade

Ermöglicht das Hinzufügen von Spracherkennungsfunktionen zum Skript. Es hat nur eine Funktion namens RecognSpeech.

21

TextToSpeechFacade

Bietet TTS-Dienste für API4 und höher. Verwenden Sie die Funktion ttsSpeak, um ein Gerät sprechen zu lassen. Verwenden Sie die Funktion ttsIsSpeaking, um festzustellen, ob die Sprechfunktion abgeschlossen ist.

22

ToneGeneratorFacade

Erzeugt DTMF-Töne für bestimmte Ziffern. Um es zu verwenden, müssen Sie die Funktion generateDtmfTones aufrufen.

23

UiFacade

Bietet Funktionen zum Erstellen von Elementen der Benutzeroberfläche wie Textfeldern, Kontrollkästchen, Datumsauswahl usw. Außerdem ermöglicht es die interaktive Verwendung von HTML-Seiten.

24

WakeLockFacade

Bietet Funktionen zum Erstellen einer Wecksperre, einschließlich wakeLockAcquireBright, wakeLockAcquireDim, wakeLockAcquireFull und wakelockAcquirePartial.

25

WebCamFacade

Für diese Fassade ist mindestens API-Stufe 8 erforderlich. Sie ermöglicht das Streaming von MJPEG-Streams von der nach vorne gerichteten Gerätekamera zum Netzwerk. Verwenden Sie zum Starten / Stoppen der Webcam die Funktionen webcamStart und webcamStop. Verwenden Sie die Funktion webcamAdjustQuality, um die Qualität des Videos während des Streamings anzupassen.

26

WifiFacade

Hilft Ihnen bei der Steuerung des WLAN-Radios auf Ihrem Gerät. Es ermöglicht Skripten, den Status der Wi-Fi-Konnektivität abzufragen, nach Zugangspunkten zu suchen, eine Verbindung zu WiFi-Netzwerken herzustellen und diese zu trennen und während der Skriptausführung eine Wi-Fi-Sperre zu halten.

Verweisen https://code.google.comEine vollständige Liste der von diesen Fassaden bereitgestellten Methoden finden Sie hier. In den folgenden Kapiteln wird erläutert, wie Sie Dienstprogramme mithilfe der API-Funktionen von Android Façade erstellen.