2013年11月30日

DialogInterfaceとは

DialogInterface

AlertDialogで設定した"はい"、"いいえ"などをクリックイベントに使用する。

主にはDialogInterface.onClickListenerが主に使用されます。

DialogInterface

MainAcitivity.java
public class MainActivity extends Activity {

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  
  AlertDialog.Builder alert = new AlertDialog.Builder(this);   
        alert.setTitle("表示されるタイトル");   
        alert.setMessage("表示されるメッセージ");
        alert.setPositiveButton("はい", new DialogInterface.OnClickListener(){
            public void onClick(DialogInterface dialog, int which) {   
                //はいボタンが押された時の処理
                 Toast.makeText(MainActivity.this, "はいを押しました", Toast.LENGTH_SHORT).show();

            }});
        
        alert.setNegativeButton("いいえ", new DialogInterface.OnClickListener(){   
            public void onClick(DialogInterface dialog, int which) {   
                //いいえボタンが押された時の処理
             Toast.makeText(MainActivity.this, "いいえを押しました", Toast.LENGTH_SHORT).show();
            }});   
        alert.show();//表示
 }
}


Contextとは

Context

ApplicationやActivityが持つ状態や情報?すいません説明できません。

ただ言えることは、Contextを要素として指定する頻度は高くthis等で略されることが多い。

例:Toast.makeText(this, "テスト", Toast.LENGTH_SHORT).show();   

thisで慣れると、たまにハマるのでここでは筆者が体験した例をソースとして記載します。


~FragmentやDialogを使用した場合~

Contextthisを指定していた箇所はgetActivity()で解決するケースが多いです。

《エラー》
TextView textkazu = (TextView)findViewById(R.id.editText1);

《修正後》
TextView textkazu = (TextView)getActivity().findViewById(R.id.editText1);


《エラー》
Toast.makeText(this, "テスト", Toast.LENGTH_SHORT).show();

《修正後》
Toast.makeText(getActivity(), "テスト", Toast.LENGTH_SHORT).show();


《エラー》
SharedPreferences sp = getSharedPreferences("prif", MODE_PRIVATE);

《修正後》
SharedPreferences sp = getActivity().getSharedPreferences("settingprif", Context.MODE_PRIVATE);

2013年11月27日

ContentValuesとは

ContentValues

データベース【SQLiteDatabase】にデータを追加するためのもの。

データベースとはデータを記録、削除、検索を行えるもの。

エクセルの行列がある表みたいなものです。


①データベースの作成【SQLiteOpenHelper
②データベースを開く
ContentValuseを生成
④データを格納する【ContentValuse.put
⑤データベースに追加する【SQLiteDatabase.insert

以下ソース例ではSQLiteDatabaseに追加したデータをListViewに表示しています。

SQLlite Database
①データベースの作成
DatabaseOpenHelper.java
public class DatabaseOpenHelper extends SQLiteOpenHelper {
 private static final String DB_NAME = "DataBese.db";// データベース名
 // バージョンを変更するとonUpgrade()が呼ばれる
 private final static int DB_VER = 1;//データベースバージョン
 public static final String TABLE_NAME = "DataBaseTable";// テーブル名
 
    // 列名(column)
 public static final String COLUMN_ID = "_id";//id
 public static final String COLUMN_DATE = "_date";//日付
 public static final String COLUMN_WEIGHT = "_weight";//体重

public DatabaseOpenHelper(Context context) {
    // 指定したデータベース名が存在しない場合、onCreate()が呼ばれる
 super(context, DB_NAME, null, DB_VER);
 }
 @Override
 public void onCreate(SQLiteDatabase db) {
  db.beginTransaction();
  try{
   // テーブルの生成
      StringBuilder createSql = new StringBuilder();
      createSql.append("create table " + TABLE_NAME + " (");
      createSql.append(COLUMN_ID + " integer primary key autoincrement,");//id、自動ナンバリング
      createSql.append(COLUMN_DATE + " text,");//日付、string型
      createSql.append(COLUMN_WEIGHT + " text");//体重、string型
      createSql.append(")");
      db.execSQL( createSql.toString());
      db.setTransactionSuccessful();
      } finally {
      db.endTransaction();
      }
    }
 
 
 //データベースの更新
 @Override
 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
  // データベースのバージョン変更で呼び出される。
  //例:データ引継ぎ等はここに記載
 }
}


MainActivity.java
public class MainActivity extends Activity implements OnClickListener{

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  
  Button button = (Button)findViewById(R.id.button_00);
  button.setOnClickListener(this);
  
  listload();//データベース内容をlistviewに表示
 }

 @Override
 public void onClick(View view) {
  // TODO 自動生成されたメソッド・スタブ
        //②データベースを開く 
  SQLiteDatabase db = (new DatabaseOpenHelper(this)).getWritableDatabase();
  ContentValues values = new ContentValues();//③オブジェクトの作成
  values.put("_date", "12月1日");//④データ格納("カラム名","登録したい値"
  values.put("_weight", "84kg");//("カラム名","登録したい値"
  
  long ret;   
        try {
      //⑤データを追加する("データベーステーブル名",null,"putで設定した値")   
            ret = db.insert("DataBaseTable", null, values);
        } finally {   
            db.close();
        }   
        if (ret == -1) {   
            Toast.makeText(this, "データベース登録に失敗しました", Toast.LENGTH_SHORT).show();   
        } else {    
            Toast.makeText(this, "データベースに登録しました", Toast.LENGTH_SHORT).show();     
        }
        db.close();//データベースを閉じる
        listload();
 }
 
 private void listload() {
  // TODO 自動生成されたメソッド・スタブ
  SQLiteDatabase db = (new DatabaseOpenHelper(this)).getWritableDatabase();
  ListView list = (ListView)findViewById(R.id.datalist);
  Cursor cursor = db.query("DataBaseTable", null, null, null, null, null, null); 
  list.setAdapter(new SimpleCursorAdapter(this,
                                 R.layout.list_item,cursor,
                                 new String[] {"_id","_date","_weight"},//, "position", "number"
                                 new int[] {R.id.id,R.id.date,R.id.weight},CursorAdapter.FLAG_REGISTER_CONTENT_OBSERVER));
        db.close();
 }
}

res/layout/activity_main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:text="ボタンを押してね" />


    <Button
        android:id="@+id/button_00"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_below="@+id/textView1"
        android:layout_centerHorizontal="true"
        android:text="データベース登録" />

     <ListView
         android:id="@+id/datalist"
         android:layout_width="fill_parent"
         android:layout_height="fill_parent"
         android:layout_alignParentLeft="true"
         android:layout_below="@+id/button_00" >

     </ListView>

</RelativeLayout>


res/layout/list_item.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:padding="8dp">

    <TextView
        android:id="@+id/weight"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBaseline="@+id/weight_name"
        android:layout_alignBottom="@+id/weight_name"
        android:layout_alignParentRight="true"
        android:text="0kg" />

    <TextView
        android:id="@+id/weight_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBaseline="@+id/id_name"
        android:layout_alignBottom="@+id/id_name"
        android:layout_toLeftOf="@+id/weight"
        android:text="体重:" />



    <TextView
        android:id="@+id/date_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBaseline="@+id/weight_name"
        android:layout_alignBottom="@+id/weight_name"
        android:layout_centerHorizontal="true"
        android:text="日付:" />

    <TextView
        android:id="@+id/date"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBaseline="@+id/date_name"
        android:layout_alignBottom="@+id/date_name"
        android:layout_toRightOf="@+id/date_name"
        android:text="日" />

    <TextView
        android:id="@+id/id_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:text="id番号:" />

    <TextView
        android:id="@+id/id"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignBaseline="@+id/id_name"
        android:layout_alignBottom="@+id/id_name"
        android:layout_toRightOf="@+id/id_name"
        android:text="id" />
   
</RelativeLayout>

2013年11月26日

BroadcastReceiverとは

BroadcastReceiver

日付指定、システムの起動等のイベントを受信するものです。

例えばデバイスの日時を受信してNotifictionを起動させたり。

以下ソースではAlarmManagerNotificationを使用して通知タップすると

Activityが起動するようにしています。

BroadCastReceiver

①onReceiveに受信したときのイベントを記入

②AndroidManifest.xmlに追記













MainActivity.java
public class MainActivity extends Activity {

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  
  Intent intent = new Intent(this, AlarmReceiver.class);

  //ブロードキャストを設定
  PendingIntent _sender = PendingIntent.getBroadcast(this, 0, intent, 0);
        
  Calendar calendar = Calendar.getInstance();
        calendar.setTimeInMillis(System.currentTimeMillis());
        calendar.set(Calendar.HOUR_OF_DAY, 9);//9時にセット
        calendar.set(Calendar.MINUTE, 0);//0分
        calendar.set(Calendar.SECOND, 0);//0秒
        calendar.set(Calendar.MILLISECOND, 0);//カンマ0秒
        if(calendar.getTimeInMillis() < System.currentTimeMillis()){
         calendar.add(Calendar.DAY_OF_YEAR, 1);}//もし時間が過去の場合は1年先でセット
        
        AlarmManager alarm = (AlarmManager)getSystemService(ALARM_SERVICE);
        alarm.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), _sender);
 }
}


AlarmReceiver.java
public class AlarmReceiver extends BroadcastReceiver{//BroadcastReceiverをextends

 @Override
 public void onReceive(Context context, Intent intent) {
  //①ここに行いたいイベントを記載する
  Intent _intent = new Intent(context,MainActivity.class);

  
  PendingIntent contentIntent = PendingIntent.getActivity(context, 0, _intent,PendingIntent.FLAG_UPDATE_CURRENT);

  //NotificationBuilderをセット
  NotificationCompat.Builder builder = new NotificationCompat.Builder(context);
  builder.setContentIntent(contentIntent);
  builder.setTicker("ステータスバーに表示されるテキスト");
  builder.setSmallIcon(R.drawable.ic_launcher);//アイコン
  builder.setContentTitle("表示されるタイトル");
  builder.setContentText("サブタイトル");

  //通知するタイミング
  builder.setWhen(System.currentTimeMillis());
  //タップするとキャンセルされるか
     builder.setAutoCancel(true);

  // NotificationManagerをセット
  NotificationManager manager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
  //通知
  manager.notify(1, builder.build());
 }
}


res/AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="sample.helloworld"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="sample.helloworld.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        //②↓この行を追加↓
        <receiver android:name=".AlarmReceiver" android:process=":remote" />
        
    </application>

</manifest>

2013年11月24日

PendingIntentとは

PendingIntent

intentを予約して指定したタイミングで発行する。

難しいことは抜きにしてAlarmManagerNotification等で何かイベントを起こしたいときに

指定するということです。

BroadCastに発行【getBroadCast】
Activityに発行【getActivity】

以下ソース例では2つのPendingIntentが存在しています。

AlarmManagerの指定した時間にNotificationを起動させる為。

Notificationの通知をタップしたら"Hello World"のActivityを起動させる為。


MainActivity.java
public class MainActivity extends Activity {

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  
  Intent intent = new Intent(this, AlarmReceiver.class);

  //①Notificationを起動させる為。
  PendingIntent _sender = PendingIntent.getBroadcast(this, 0, intent, 0);
        
  Calendar calendar = Calendar.getInstance();
        calendar.setTimeInMillis(System.currentTimeMillis());
        calendar.set(Calendar.HOUR_OF_DAY, 9);//9時にセット
        calendar.set(Calendar.MINUTE, 0);//0分
        calendar.set(Calendar.SECOND, 0);//0秒
        calendar.set(Calendar.MILLISECOND, 0);//カンマ0秒
        if(calendar.getTimeInMillis() < System.currentTimeMillis()){
         calendar.add(Calendar.DAY_OF_YEAR, 1);}//もし時間が過去の場合は1年先でセット
        
        AlarmManager alarm = (AlarmManager)getSystemService(ALARM_SERVICE);
        alarm.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), _sender);
 }
}


AlarmReceiver.java
public class AlarmReceiver extends BroadcastReceiver{

 @Override
 public void onReceive(Context context, Intent intent) {
  //ここに行いたいイベントを記載する
  Intent _intent = new Intent(context,MainActivity.class);

  //②Activityを起動させる為。
  PendingIntent contentIntent = PendingIntent.getActivity(context, 0, _intent,PendingIntent.FLAG_UPDATE_CURRENT);

  //NotificationBuilderをセット
  NotificationCompat.Builder builder = new NotificationCompat.Builder(context);
  builder.setContentIntent(contentIntent);
  builder.setTicker("ステータスバーに表示されるテキスト");
  builder.setSmallIcon(R.drawable.ic_launcher);//アイコン
  builder.setContentTitle("表示されるタイトル");
  builder.setContentText("サブタイトル");

  //通知するタイミング
  builder.setWhen(System.currentTimeMillis());
  //タップするとキャンセルされるか
     builder.setAutoCancel(true);

  // NotificationManagerをセット
  NotificationManager manager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
  //通知
  manager.notify(1, builder.build());
 }
}


res/AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="sample.helloworld"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="sample.helloworld.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        //↓この行を追加↓
        <receiver android:name=".AlarmReceiver" android:process=":remote" />
        
    </application>

</manifest>

2013年11月23日

AlertDialogとは

AlertDialog

ダイアログを表示させてテキスト表示させたりボタンでユーザーに選択してもらったりする。

よく使うのが2択でYESorNOでユーザーの確認を得る為に使用する。

AlartDialog
サンプルソース例では、2択形式ですがダイアログには
さまざまな種類があります。
  • Text表示
  • ListView表示
  • RadioButton表示
  • 指定のLayout.xmlで表示   等










MainAcitivity.java
public class MainActivity extends Activity {

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  
  AlertDialog.Builder alert = new AlertDialog.Builder(this);   
        alert.setTitle("表示されるタイトル");//タイトル   
        alert.setMessage("表示されるメッセージ");//文中
        alert.setPositiveButton("はい", new DialogInterface.OnClickListener(){
            public void onClick(DialogInterface dialog, int which) {   
                //はいボタンが押された時の処理   
                 Toast.makeText(MainActivity.this, "はいを押しました", Toast.LENGTH_SHORT).show();

            }});
        
        alert.setNegativeButton("いいえ", new DialogInterface.OnClickListener(){   
            public void onClick(DialogInterface dialog, int which) {   
                //いいえボタンが押された時の処理
             Toast.makeText(MainActivity.this, "いいえを押しました", Toast.LENGTH_SHORT).show();
            }});   
        alert.show();//表示
 }
}

2013年11月22日

NotificationManagerとは

NotificationManager

ステータスバーに通知させる。

Notification.builderで設定したものを実際に通知またはキャンセルさせます。


図1 Notification通知画面

以下ソース例はステータスバーに通知をしてユーザーがクリックすると通知が消えるようにしてます。
















MainActivity.java
public class MainActivity extends Activity {

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  
  Intent intent = new Intent(this, AlarmReceiver.class);
  
        PendingIntent _sender = PendingIntent.getBroadcast(this, 0, intent, 0);
        
  Calendar calendar = Calendar.getInstance();
        calendar.setTimeInMillis(System.currentTimeMillis());
        calendar.set(Calendar.HOUR_OF_DAY, 9);//9時にセット
        calendar.set(Calendar.MINUTE, 0);//0分
        calendar.set(Calendar.SECOND, 0);//0秒
        calendar.set(Calendar.MILLISECOND, 0);//カンマ0秒
        if(calendar.getTimeInMillis() < System.currentTimeMillis()){
         calendar.add(Calendar.DAY_OF_YEAR, 1);}//もし時間が過去の場合は1年先でセット
        
        AlarmManager alarm = (AlarmManager)getSystemService(ALARM_SERVICE);
        alarm.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), _sender);
 }
}


AlarmReceiver.java
public class AlarmReceiver extends BroadcastReceiver{

 @Override
 public void onReceive(Context context, Intent intent) {
  Intent _intent = new Intent(context,MainActivity.class);
  PendingIntent contentIntent = PendingIntent.getActivity(context, 0, _intent,PendingIntent.FLAG_UPDATE_CURRENT);

  NotificationCompat.Builder builder = new NotificationCompat.Builder(context);
  builder.setContentIntent(contentIntent);
  builder.setTicker("ステータスバーに表示されるテキスト");
  builder.setSmallIcon(R.drawable.ic_launcher);
  builder.setContentTitle("表示されるタイトル");
  builder.setContentText("サブタイトル");
 builder.setDefaults(Notification.DEFAULT_SOUND);
  builder.setDefaults(Notification.DEFAULT_VIBRATE);
 builder.setDefaults(Notification.DEFAULT_LIGHT);
  builder.setDefaults(Notification.DEFAULT_ALL);

 
  builder.setWhen(System.currentTimeMillis());//通知するタイミング
  
  builder.setAutoCancel(true);//タップするとキャンセルされるか


  // NotificationManagerをセット
  NotificationManager manager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
  
  manager.notify(1, builder.build());//通知
 }
}


res/AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="sample.helloworld"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="sample.helloworld.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        //↓この行を追加↓
        <receiver android:name=".AlarmReceiver" android:process=":remote" />
        
    </application>

</manifest>

Notificationとは

Notification

NotificationCompat

ステータスバーに通知を表示させる。

ステータスバーへの通知なのでアプリ起動中に単独で使うことはあまりない。

アプリを起動してない時に通知させる為、AlarmManagerと併用されることが多い。

図1 Notification通知画面

NotificationCompat.Builderの使用を推奨※
 ※support.v4が必要(Android1.6から使用可にするサポート)
















MainActivity.java
public class MainActivity extends Activity {

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  
  Intent intent = new Intent(this, AlarmReceiver.class);
  
        PendingIntent _sender = PendingIntent.getBroadcast(this, 0, intent, 0);
        
  Calendar calendar = Calendar.getInstance();
        calendar.setTimeInMillis(System.currentTimeMillis());
        calendar.set(Calendar.HOUR_OF_DAY, 9);//9時にセット
        calendar.set(Calendar.MINUTE, 0);//0分
        calendar.set(Calendar.SECOND, 0);//0秒
        calendar.set(Calendar.MILLISECOND, 0);//カンマ0秒
        if(calendar.getTimeInMillis() < System.currentTimeMillis()){
         calendar.add(Calendar.DAY_OF_YEAR, 1);}//もし時間が過去の場合は1年先でセット
        
        AlarmManager alarm = (AlarmManager)getSystemService(ALARM_SERVICE);
        alarm.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), _sender);
 }
}


AlarmReceiver.java
public class AlarmReceiver extends BroadcastReceiver{

 @Override
 public void onReceive(Context context, Intent intent) {
  Intent _intent = new Intent(context,MainActivity.class);
  PendingIntent contentIntent = PendingIntent.getActivity(context, 0, _intent,PendingIntent.FLAG_UPDATE_CURRENT);

  NotificationCompat.Builder builder = new NotificationCompat.Builder(context);
  builder.setContentIntent(contentIntent);
  builder.setTicker("ステータスバーに表示されるテキスト");//通知に表示される文章
  builder.setSmallIcon(R.drawable.ic_launcher);//通知アイコン
  builder.setContentTitle("表示されるタイトル");//表示されるタイトル
  builder.setContentText("サブタイトル");//タイトルの下に表示されるサブタイトル
 builder.setDefaults(Notification.DEFAULT_SOUND);//通知音
  builder.setDefaults(Notification.DEFAULT_VIBRATE);//通知時バイブレーション
 builder.setDefaults(Notification.DEFAULT_LIGHT);//通知時ライト
  builder.setDefaults(Notification.DEFAULT_ALL);//通知音、バイブレーション、ライト

 //通知するタイミング
  builder.setWhen(System.currentTimeMillis());
  //タップするとキャンセルされるか
  builder.setAutoCancel(true);

  // NotificationManagerをセット
  NotificationManager manager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
  //通知
  manager.notify(1, builder.build());
 }
}


res/AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="sample.helloworld"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="sample.helloworld.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        //↓この行を追加↓
        <receiver android:name=".AlarmReceiver" android:process=":remote" />
        
    </application>

</manifest>

2013年11月21日

AlarmManagerとは

AlarmManeger

指定された時間やタイミングでイベントを走らせるもの。

よくステータスバーに通知を出す【Notification】と併用されます。

以下ソースはNotificationの適用例。

図1 Notification
Intent,PendingIntentをセット
Calendarをセット
AlarmManegerをセット
BroadcastReceiverNotificationをセットする
⑤AndroidManifest.xmlにReceiverを登録する













MainActivity.java
public class MainActivity extends Activity {

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  
  Intent intent = new Intent(this, AlarmReceiver.class);//1.Intent,PendingIntentをセット
  
        PendingIntent _sender = PendingIntent.getBroadcast(this, 0, intent, 0);//1.Intent,PendingIntentをセット
        
  Calendar calendar = Calendar.getInstance();//2.Calendarをセット
        calendar.setTimeInMillis(System.currentTimeMillis());
        calendar.set(Calendar.HOUR_OF_DAY, 9);//9時にセット
        calendar.set(Calendar.MINUTE, 0);//0分
        calendar.set(Calendar.SECOND, 0);//0秒
        calendar.set(Calendar.MILLISECOND, 0);//カンマ0秒
        if(calendar.getTimeInMillis() < System.currentTimeMillis()){
         calendar.add(Calendar.DAY_OF_YEAR, 1);}//もし時間が過去の場合は1年先でセット
        
        AlarmManager alarm = (AlarmManager)getSystemService(ALARM_SERVICE);//3.AlarmMangerをセット
        alarm.set(AlarmManager.RTC_WAKEUP, calendar.getTimeInMillis(), _sender);
 }
}


AlarmReceiver.java
public class AlarmReceiver extends BroadcastReceiver{

 @Override
 public void onReceive(Context context, Intent intent) {
  //ここに行いたいイベントを記載する
  Intent _intent = new Intent(context,MainActivity.class);
  PendingIntent contentIntent = PendingIntent.getActivity(context, 0, _intent,PendingIntent.FLAG_UPDATE_CURRENT);

  //NotificationBuilderをセット
  NotificationCompat.Builder builder = new NotificationCompat.Builder(context);
  builder.setContentIntent(contentIntent);
  builder.setTicker("ステータスバーに表示されるテキスト");
  builder.setSmallIcon(R.drawable.ic_launcher);//アイコン
  builder.setContentTitle("表示されるタイトル");
  builder.setContentText("サブタイトル");

  //通知するタイミング
  builder.setWhen(System.currentTimeMillis());
  //タップするとキャンセルされるか
     builder.setAutoCancel(true);

  // NotificationManagerをセット
  NotificationManager manager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
  //通知
  manager.notify(1, builder.build());
 }
}


res/AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="sample.helloworld"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="17" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name="sample.helloworld.MainActivity"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        //↓この行を追加↓
        <receiver android:name=".AlarmReceiver" android:process=":remote" />
        
    </application>

</manifest>

2013年11月20日

Activityとは

Activity

簡単に言うと目に見えるアプリ画面です。

Activity

下記ソース実行例
画面にHello World!と記載されてます。
(文字ちっさ!)

①res/layout/activity_main.xmlに書かれた内容が表示される
②res/valuse/strings.xmlに記載している"Hello World!"とアプリ画面にテキストが表示される。










MainActivity.java
public class MainActivity extends Activity {
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);//①activity_main.xmlをセット
 }
}

res/layout/activity_main.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:text="@string/hello_world" />//②
</RelativeLayout>

res/values/strings.xml
<?xml version="1.0" encoding="utf-8"?>
<resources>

    <string name="app_name">HelloWorld</string>
    <string name="hello_world">Hello world!</string>
    <string name="menu_settings">Settings</string>

</resources>


2013年11月19日

Androidアプリ開発環境【Eclipse編】

androidアプリ開発に必要な開発環境は以下になります。
  1. JDK6のインストール
  2. AndroidSDK ADT Bundle版インストール

1)JDK6のインストール手順

http://www.oracle.com/technetwork/java/javase/downloads/index.html

~JDK SE 6をダウンロードします~

※最新版はJDK7です。今回はJDK6のインストール方法です。

図1 JDK6 画面
図2 JDK6を選択
図3 JDK6u45を選択
図4 JDK6ダウンロード画面

~ダウンロード後、インストールを実行します~

特にこだわりがなければデフォルトのままでok

~インストールが完了したら、環境変数を加えます。(windows7の場合)~

マイコンピュータ>右クリック>プロパティ>システムの詳細設定

詳細設定タブの環境変数をクリック。

図5 環境変数システムプロパティ画面

《変数Pathに付け加える》

変数一覧からPathをクリック>編集をクリック

変数値の一番最後にセミコロン ; をつけて

インストールしたJDKのbinフォルダのアドレスを加える
※デフォルトかつJDK6u45の場合、C:\Program Files\Java\jdk1.6.0_45\bin

例:   ;C:\Program Files\Java\jdk1.6.0_45\bin


《変数JAVA_HOMEを新規追加》

 新規をクリックして下記のように入力
 ※変数値はデフォルト例です。セミコロン不要、\binは含まない

 変数名:JAVA_HOME

変数値:C:\Program Files\Java\jdk1.6.0_45

図6 環境変数画面
JDKインストールは以上です。




2)AndroidSDK ADT Bundle版インストール

http://developer.android.com/sdk/

※EclipseやSDK等個別にDLする方法もありますが
ここでは楽なBundle版を紹介します。

Bundleの中身

  • Eclipse【このソフトでプログラミング作成します】
  • AndroidSDK
  • Androidプラットホフォーム
  • エミュレータ

~ADT Bundle版をダウンロードする~

図1 ADT Bundle ダウンロード画面

規約画面が出てくるので同意チェックと32bitか64bitを選択してダウンロード開始します。

~ダウンロード後、インストールを実行します~

特にこだわりがなければデフォルトのままでok

インストール作業は以上です。


~Eclipseを起動する~

先ほどのインストールで展開した下位フォルダのeclipse.exeを起動します。
(\adt-bundle-windows-x86\eclipse\eclipse.exe)

WorkSpaceを選択しましょう。ワークスペースとはアプリプロジェクトを保存しておく場所です。

日本語化は下記サイトを参照して下さい。
http://mergedoc.sourceforge.jp/

図2 Eclipse起動画面

インストール作業は以上です。

《起動エラー、失敗の場合》

以下確認
  1. JDK6?
  2. JDKは正常インストールされてる?32bit?64bit?
  3. 環境変数は修正した?Path、JAVA_HOME
だいたい3の環境変数に失敗してるケースが多いです。



2013年11月12日

Androidアプリ開発環境【AndroidStudio編】

androidアプリ開発に必要な開発環境は以下。
  1. JDK7のインストール
  2. AndroidStudioのインストール

1)JDK7のインストール手順

http://www.oracle.com/technetwork/java/javase/downloads/index.html

~JDK SE 7をダウンロードします~

画像はJDK7u45です。※u以降の数字はUpdate番号
図1 JDKホームページ画面
図2 JDK7ダウンロード画面

~ダウンロード後、インストールを実行します~

特にこだわりがなければデフォルトのままでok

~インストールが完了したら、環境変数を加えます。(windows7の場合)~

マイコンピュータ>右クリック>プロパティ>システムの詳細設定

 詳細設定タブの環境変数をクリック。

図3 環境変数システムプロパティ画面

《変数Pathに付け加える》

変数一覧からPathをクリック>編集をクリック
 
 変数値の一番最後にセミコロン ; をつけて

 インストールしたJDKのbinフォルダのアドレスを加える
 ※デフォルトかつJDK7u45の場合、C:\Program Files\Java\jdk1.7.0_45\bin

例:   ;C:\Program Files\Java\jdk1.7.0_45\bin


《変数JDK_HOMEを新規追加》

 新規をクリックして下記のように入力
 ※変数値はデフォルト例です。セミコロン不要、\binは含まない

 変数名:JDK_HOME

 変数値:C:\Program Files\Java\jdk1.7.0_45
 
図5 環境変数画面

JDKインストールは以上です。

環境変数を加えないとandroidStudio起動できません。



2)androidSDKのインストール手順


~androidStudioをダウンロードする~

図6 AndroidStudioホームページ画面

~ダウンロード後、インストールを実行します~

特にこだわりがなければデフォルトのままでok


AndroidStudioインストールは以上です。

なにも問題がなければ以下画面が出てくるはずです。

図7 AndroidStudio起動時画面
図8 起動後画面

《起動エラー、失敗の場合》

以下確認

  1. JDK7?
  2. JDKは正常インストールされてる?32bit?64bit?
  3. 環境変数は修正した?Path、JDK_HOME
だいたい3の環境変数に失敗してるケースが多いです。

筆者は不覚にも1と3を間違っていました。

筆者は、こんなエラーが出ました。
"No JVM installation dound.Please install a 64-bit JDK.
if you already have a JDK installed define a JAVA_HOME variable in Computer >
System Properties > System Settings > Environment Variables"

図9 AndroidStudio起動失敗例

2013年11月11日

Androidアプリ開発~ご挨拶~

Androidアプリ開発ブログの主旨

  • androidアプリ開発メモ
  • JAVAプログミングエラー対策
  • JAVAプログラミングソース例
  • アプリ開発入門講座
  • android仲間集め
  • 情報共有
画像とプログラミングソースを公開しながら分かりやすく書いていきます。

開発環境

  • eclipse     [開発環境]
  • JDK6               [JAVA開発環境]
  • AndroidStudio [開発環境]
  • JDK7               [JAVA開発環境]                
  • gimp               [アイコン、画像作成]
2013年5月よりandroidstudioが公開されてますが
とりあえず今はeclipseで開発中


2013年11月10日

体重計アラーム

体重計アラーム
体重計アラーム

《アプリ説明》
決まった時間に体重計を測るよう通知する。
体重を記録する。
https://play.google.com/store/apps/details?id=bodony.pack.diet&hl=ja



《取り込んでいる機能》

貯めマスっち

貯めマスっち
貯金ゆるキャラ”貯めマスっち”アプリ


https://play.google.com/store/apps/details?id=bodony.pack.tamemasucchi&hl=ja

かんたん血圧記録

かんたん血圧記録
2013年11月6日 かんたん血圧記録アプリを公開!