Android client library to assist with using the Watson Developer Cloud services, a collection of REST APIs and SDKs that use cognitive computing to solve complex problems.
'com.ibm.watson.developer_cloud:android-sdk:0.4.2'
Download the aar here.
The minimum supported Android API level is 19. Now, you are ready to see some examples.
The examples below assume that you already have service credentials. If not, you will have to create a service in Bluemix.
You will need the username
and password
(api_key
for AlchemyAPI) credentials, as well as the url
for each service. Service credentials are different from your Bluemix account username and password.
To get your service credentials, follow these steps:
-
Log in to Bluemix at https://console.bluemix.net.
-
Create an instance of the service:
- In the Bluemix Catalog, select the service you want to use.
- Under Add Service, type a unique name for the service instance in the Service name field. For example, type
my-service-name
. Leave the default values for the other options. - Click Create.
-
Copy your credentials:
- On the left side of the page, click Service Credentials to view your service credentials.
- Copy
username
,password
(api_key
for AlchemyAPI), andurl
.
The credentials should be added to the example/res/values/credentials.xml
file shown below.
<resources>
<!-- Paste Language Translator information here -->
<string name="language_translator_username"></string>
<string name="language_translator_password"></string>
<string name="language_translator_url"></string>
<!-- Paste Speech to Text information here -->
<string name="speech_text_username"></string>
<string name="speech_text_password"></string>
<string name="speech_text_url"></string>
<!-- Paste Text to Speech information here -->
<string name="text_speech_username"></string>
<string name="text_speech_password"></string>
<string name="text_speech_url"></string>
</resources>
If you are having difficulties using the APIs or have a question about the IBM Watson Services, please ask a question on dW Answers or Stack Overflow.
You can also check out the wiki for some additional information.
This SDK is built for use with the java-sdk.
The examples below are specific for Android as they use the Microphone and Speaker; for actual services refer to the java-sdk. Be sure to use the provided example app as a model for your own Android app using Watson services.
Provides simple microphone access within an activity.
MicrophoneHelper microphoneHelper = new MicrophoneHelper(this);
The MicrophoneHelper object allows you to create new MicrophoneInputStream objects and close them. The MicrophoneInputStream class is a convenience class for creating an InputStream
from device microphone. You can record raw PCM data or data encoded using the ogg codec.
// record PCM data without encoding
MicrophoneInputStream myInputStream = microphoneHelper.getInputStream(false);
// record PCM data and encode it with the ogg codec
MicrophoneInputStream myOggStream = microphoneHelper.getInputStream(true);
An example using a Watson Developer Cloud service would look like
speechService.recognizeUsingWebSocket(new MicrophoneInputStream(),
getRecognizeOptions(), new BaseRecognizeCallback() {
@Override
public void onTranscription(SpeechResults speechResults){
String text = speechResults.getResults().get(0).getAlternatives().get(0).getTranscript();
System.out.println(text);
}
@Override
public void onError(Exception e) {
}
@Override public void onDisconnected() {
}
});
Be sure to take a look at the example app to get a working example of putting these all together.
Provides the ability to directly play an InputStream
StreamPlayer player = new StreamPlayer();
player.playStream(yourInputStream);
Provides simple camera access within an activity.
CameraHelper cameraHelper = new CameraHelper(this);
cameraHelper.dispatchTakePictureIntent();
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == CameraHelper.REQUEST_IMAGE_CAPTURE) {
System.out.println(cameraHelper.getFile(resultCode));
}
}
Like the CameraHelper, but allows for selection of images already on the device.
To open the gallery:
GalleryHelper galleryHelper = new GalleryHelper(this);
galleryHelper.dispatchGalleryIntent();
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == GalleryHelper.PICK_IMAGE_REQUEST) {
System.out.println(galleryHelper.getFile(resultCode, data));
}
}
Testing in this SDK is accomplished with Espresso.
To run the tests, in Android Studio:
Within the example package, right-click the androidTest/java folder and click Run 'All Tests'.
Use Gradle (version 1.x) to build and test the project you can use
Gradle:
$ cd android-sdk
$ gradle test # run tests
Find more open source projects on the IBM Github Page
This library is licensed under Apache 2.0. Full license text is available in LICENSE.
See CONTRIBUTING.md.