2012年9月17日月曜日

SQLite

データベースの勉強

テーブル名productsで、名前と値段だけです。



********************  MainActivity.java  ********************
package jp.lesson.studyandroid;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;

import android.content.Context;
import android.widget.TextView;

public class MainActivity extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
       
        // データベース接続
        MyDBHelper helper = new MyDBHelper(this);
        SQLiteDatabase db = helper.getReadableDatabase();
        Cursor c = db.query("products",
                new String[] { "name", "price" },
                null, null, null, null, null);
        /*    query()
             table:テーブル名
            columns:取得する列名(カラム名、フィールド名)の配列
            selection:取得するレコードの条件を指定
            group:
            having:
            order:
            limit:取得するレコードの上限数を指定。使わない場合は、null。
         */
       
        boolean isEof = c.moveToFirst();
        TextView textView1 = (TextView) findViewById(R.id.textView1);
        String text="";
       
        while (isEof) {
            text += String.format("%s : %d円\r\n", c.getString(0), c.getInt(1));
            isEof = c.moveToNext();
        }
        textView1.setText(text);
        c.close();
        db.close();
    }
    @Override
    protected void onDestroy() {
        super.onDestroy();
    }
    public class MyDBHelper extends SQLiteOpenHelper {
        public MyDBHelper(Context context) {
            super(context, null, null, 1);
                /*    コンテキストオブジェクト
                    fileName・・・データベース名
                    factory・・・通常nullを指定
                    version・・・データベースのバージョン
                */
        }
        @Override
        public void onCreate(SQLiteDatabase db) {
            db.execSQL(
                    "create table products("+
                    "   name text not null,"+
                    "   price text"+
                    ");"
                );
            // table row insert
            db.execSQL("insert into products(name,price) values ('クッキー', 120);");
            db.execSQL("insert into products(name,price) values ('ビスケット', 85);");
            db.execSQL("insert into products(name,price) values ('ケーキ', 285);");
        }
        @Override
        public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
            // TODO 自動生成されたメソッド・スタブ
           
        }
    }
}

********************  activity_main.xml  ********************
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" >
        <TextView
            android:id="@+id/textView1"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:text="@string/hello" />
    </LinearLayout>

********************  strings.xml  ********************
<resources>
    <string name="app_name">StudyAndroid</string>
    <string name="hello">Hello world!</string>
    <string name="menu_settings">Settings</string>
    <string name="title_activity_main">MainActivity</string>
</resources>

2012年9月14日金曜日

画面遷移 データの受け渡し

ボタンをクリックをしたとき、サブの画面に遷移する。
そのときEditTextに入力されたデータも受け渡す。


********************  MainActivity.java  ********************
package jp.lesson.studyandroid;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.content.Intent;
import android.widget.EditText;
public class MainActivity extends Activity {
   
    private Button btn1;
    private EditText edit1;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        edit1 = (EditText) findViewById(R.id.editText1);
        btn1 = (Button) findViewById(R.id.button1);
       
        btn1.setOnClickListener(new View.OnClickListener() {
           
            public void onClick(View v) {
                String strdata = edit1.getText().toString();
               
                Intent intent = new Intent(MainActivity.this, SubActivity.class);
                intent.putExtra("data", strdata);  // インテントに値をセット
                startActivity(intent);
            }
        });
    }
   
}

********************  activity_main.xml  ********************
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" >
        <TextView
            android:id="@+id/textView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/maintv" />
        <EditText
            android:id="@+id/editText1"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:ems="10" >
            <requestFocus />
        </EditText>
        <Button
            android:id="@+id/button1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/btn" />
    </LinearLayout>

********************  SubActivity.java  ********************
package jp.lesson.studyandroid;
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
public class SubActivity extends Activity {
   
    private Button subbtn;
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_sub);
       
        EditText edtxt = (EditText) findViewById(R.id.editText2);
        Intent intent = getIntent();
        String sdata = intent.getStringExtra("data");
        edtxt.setText(sdata);
        subbtn = (Button) findViewById(R.id.button2);
        subbtn.setOnClickListener(new View.OnClickListener() {
           
            public void onClick(View v) {
                // TODO 自動生成されたメソッド・スタブ
                finish();  // 次画面のアクティビティ終了
            }
        });
    }
}

********************  activity_sub.xml  ********************
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/subtv" />
    <EditText
        android:id="@+id/editText2"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:ems="10" >
        <requestFocus />
    </EditText>
    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/btn2" />
</LinearLayout>

********************  AndroidManifest.xml  ********************
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="jp.lesson.studyandroid"
    android:versionCode="1"
    android:versionName="1.0" >
    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />
    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/title_activity_main" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".SubActivity"
            android:label="@string/title_activity_sub" >
        </activity>
        </application>
</manifest>

********************  strings.xml  ********************
<resources>
    <string name="app_name">StudyAndroid</string>
    <string name="menu_settings">Settings</string>
    <string name="maintv">main画面</string>
    <string name="subtv">sub画面</string>
    <string name="title_activity_main">MainActivity</string>
    <string name="title_activity_sub">SubActivity</string>
    <string name="btn">サブ画面へ</string>
    <string name="btn2">元に戻る</string>
</resources>

2012年9月12日水曜日

画面遷移

ボタンをクリックをしたとき、サブの画面に遷移する。


遷移先のアクティビティを「AndroidManifest.xml」に登録する必要がある。
AndroidManifest.xml は res の下にある。


********************  MainActivity.java  ********************
package jp.lesson.studyandroid;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.widget.Button;
import android.content.Intent;
public class MainActivity extends Activity {
   
    private Button btn1;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        btn1 = (Button) findViewById(R.id.button1);
        btn1.setOnClickListener(new View.OnClickListener() {
           
            public void onClick(View v) {
               
                Intent intent = new Intent(MainActivity.this, SubActivity.class);
                startActivity(intent);

            }
        });
    }
   
}

********************  activity_main.xml  ********************
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" >
        <TextView
            android:id="@+id/textView1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/maintv" />
        <Button
            android:id="@+id/button1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/btn" />
    </LinearLayout>

********************  SubActivity.java  ********************
package jp.lesson.studyandroid;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
public class SubActivity extends Activity {
   
    private Button subbtn;
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_sub);
       
        subbtn = (Button) findViewById(R.id.button2);
        subbtn.setOnClickListener(new View.OnClickListener() {
           
            public void onClick(View v) {
                // TODO 自動生成されたメソッド・スタブ
                finish();  // 次画面のアクティビティ終了
            }
        });
    }
}

********************  activity_sub.xml  ********************
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >
    <TextView
        android:id="@+id/textView2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/subtv" />
    <Button
        android:id="@+id/button2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/btn2" />
</LinearLayout>

********************  AndroidManifest.xml  ********************
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="jp.lesson.studyandroid"
    android:versionCode="1"
    android:versionName="1.0" >
    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="15" />
    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".MainActivity"
            android:label="@string/title_activity_main" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".SubActivity"
            android:label="@string/title_activity_sub" >

        </activity>
        </application>
</manifest>

********************  strings.xml  ********************
<resources>
    <string name="app_name">StudyAndroid</string>
    <string name="menu_settings">Settings</string>
    <string name="maintv">main画面</string>
    <string name="subtv">sub画面</string>
    <string name="title_activity_main">MainActivity</string>
    <string name="title_activity_sub">SubActivity</string>
    <string name="btn">サブ画面へ</string>
    <string name="btn2">元に戻る</string>
</resources>