: Beginning Android

Readin n Writin

Readin n Writin

Reading and writing your own, application-specific data files is nearly identical to what you might do in a desktop Java application. The key is to use openFileInput() and openFileOutput() on your Activity or other Context to get an InputStream and OutputStream, respectively. From that point forward, the process is not much different from using regular Java I/O logic:

Wrap those streams as needed, such as using an InputStreamReader or OutputStreamWriter for text-based I/O.

Read or write the data.

Use close() to release the stream when done.

If two applications both try reading a notes.txt file via openFileInput(), they will each access their own edition of the file. If you need to have one file accessible from many places, you probably want to create a content provider, as will be described in Chapter 28.

Note that openFileInput() and openFileOutput() do not accept file paths (e.g., path/to/file.txt), just simple filenames.

The following code shows the layout for the worlds most trivial text editor, pulled from the Files/ReadWrite sample application available on the Apress Web site:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
<Button android:id="@+id/close"
android:text="Close" />

All we have here is a large text-editing widget with a Close button above it. The Java is only slightly more complicated:

package com.commonsware.android.files;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import java.io.BufferedReader;
import java.io.File;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.OutputStream;
import java.io.OutputStreamWriter;
publicclass ReadWriteFileDemoextends Activity {
privatefinalstatic String NOTES = "notes.txt";
private EditText editor;
public voidonCreate(Bundle icicle) {
editor = (EditText)findViewById(R.id.editor);
Button btn = (Button)findViewById(R.id.close);
btn.setOnClickListener(new Button.OnClickListener() {
public voidonClick(View v) {
public voidonResume() {
try {
InputStream in =openFileInput(NOTES);
if (in !=null) {
InputStreamReader tmp =newInputStreamReader(in);
BufferedReader reader =newBufferedReader(tmp);
String str;
StringBuffer buf =newStringBuffer();
while ((str = reader.readLine()) !=null) {
}catch (java.io.FileNotFoundException e) {
// that's OK, we probably haven't created it yet
}catch (Throwable t) {
Toast.makeText(this, "Exception: " + t.toString(), 2000).show();
public voidonPause() {
try {
OutputStreamWriter out =
newOutputStreamWriter(openFileOutput(NOTES, 0));
}catch (Throwable t) {
Toast.makeText(this, "Exception: " + t.toString(), 2000).show();

First we wire up the button to close out our activity when its clicked, by using setOnClickListener() to invoke finish() on the activity.

Next we hook into onResume() so we get control when our editor is coming to life, from a fresh launch or after having been frozen. We use openFileInput() to read in notes.txt and pour the contents into the text editor. If the file is not found, we assume this is the first time the activity was run (or that the file was deleted by other means), and we just leave the editor empty.

Finally we hook into onPause() so we get control as our activity gets hidden by another activity or is closed, such as via our Close button. Here we use openFileOutput() to open notes.txt, into which we pour the contents of the text editor.

The net result is that we have a persistent notepad: whatever is typed in will remain until deleted, surviving our activity being closed, the phone being turned off, and similar situations.

: 0.477. /Cache: 3 / 1