ia32-libs が入っているか確認する。
dpkg -l | grep ia32
Android SDK を下記サイトからダウンロードしてくる。
http://developer.android.com/sdk/index.html
android-sdk_r20.0.1-linux.tgz を解凍する。
解凍して出来たフォルダ android-sdk-linux をホームに移動する。
~/android-sdk-linux/tools/android をダブルクリックすると
Android SDK Manager が起動する。
必要なものをインストールしておく。
Toolsの
Android SDK Tools
Android SDK Platform-tools
と
Android 2.2の SDK Platform をインストールした。
toolとか使いやすいようにPATHを通しておく。
.bashrcに追加
export ANDROID_SDK_HOME=[AndroidSDKを配置したパス]
PATH=$PATH:$ANDROID_SDK_HOME/tools:$ANDROID_SDK_HOME/platform-tools
変更を有効にする。
$source .bashrc
eclipse のインストール
ubuntu ソフトウェアセンターからインストールする。
eclipse.intの末尾に追記
-Djava.library.path=/usr/lib/jni
日本語化
pleiades_1.3.4 で日本語化する。
sudo cp -R features/* /usr/lib/eclipse/features/
sudo cp -R plugins/* /usr/lib/eclipse/plugins/
eclipse.intの修正
追記する
-javaagent:/usr/lib/eclipse/plugins/jp.sourceforge.mergedoc.pleiades/pleiades.jar
コメントアウトする
#-showsplash
#org.eclipse.platform
eclipse に Android Plugin をインストール
ヘルプ→新規ソフトウェアのインストールを開く
https://dl-ssl.google.com/android/eclipse/ を入力してインストール
2012年7月31日火曜日
ubuntu12.04 64bitにeclipseをインストールする。
普通にインストールしても起動しないので、設定ファイルを修正する。
設定ファイルを管理者権限で開く
sudo gedit /etc/eclipse.ini
開いたファイルの末尾に次の一行を書き込む
-Djava.library.path=/usr/lib/jni
設定ファイルを管理者権限で開く
sudo gedit /etc/eclipse.ini
開いたファイルの末尾に次の一行を書き込む
-Djava.library.path=/usr/lib/jni
ソースコードの取得・ビルド
ソースコードの取得
androidのソースコード取得に必要なツールを取得する。
sudo apt-get install git-core
sudo apt-get install curl
ホームにbinディレクトリを作りrepoをコマンドをインストールして、実行権限を与える。
mkdir ~/bin
curl https://dl-ssl.google.com/dl/googlesource/git-repo/repo > ~/bin/repo
PATH=~/bin:$PATH
chmod a+x ~/bin/repo
ソースコードのダウンロード用ディレクトリandroidCoreを作ってそこに移動して、repoコマンドを打つ(masterの場合)
mkdir androidMaster
cd androidMaster/
repo init -u https://android.googlesource.com/platform/manifest
ソースコード取得開始
ビルド準備
JDKのインストールオラクルのページからjdk-6u33-linux-x64.binをダウンロードしてくる。
$ chmod a+x jdk-6u33-linux-x64.bin
$ ./jdk-6u33-linux-x64.bin
$ sudo mv jdk1.6.0_33 /usr/lib/jvm/
javaの環境設定をしてくれるツールをインストールする
$ wget http://webupd8.googlecode.com/files/update-java-0.5b
$ chmod a+x update-java-0.5b
$ sudo ./update-java-0.5b
jdk1.6.0_33 を選択する。
必要なツールのインストールとシンボリックリンクの作成
$ sudo apt-get install git-core gnupg flex bison gperf build-essential \ zip curl libc6-dev libncurses5-dev:i386 x11proto-core-dev \ libx11-dev:i386 libreadline6-dev:i386 libgl1-mesa-glx:i386 \ libgl1-mesa-dev g++-multilib mingw32 openjdk-6-jdk tofrodos \ python-markdown libxml2-utils xsltproc zlib1g-dev:i386
$ sudo ln -s /usr/lib/i386-linux-gnu/mesa/libGL.so.1 /usr/lib/i386-linux-gnu/libGL.so
ビルド
source build/envsetup.sh
lunch full-eng
make -j8
備考
バージョン(ブランチ名)を指定して取得する場合
repo init -u https://android.googlesource.com/platform/manifest -b android-4.0.4_r1.2
ブランチ名を調べる方法
repo init ....を打った後
$ ls -1 .repo/manifests.git/logs/refs/remotes/origin/
開発環境
ubuntu 12.04 LTS 64bit
メモリ:8G
プロセッサ:intel Core i3
ディスク容量:135G
androidのソースコード取得に必要なツールを取得する。
sudo apt-get install git-core
sudo apt-get install curl
ホームにbinディレクトリを作りrepoをコマンドをインストールして、実行権限を与える。
mkdir ~/bin
curl https://dl-ssl.google.com/dl/googlesource/git-repo/repo > ~/bin/repo
PATH=~/bin:$PATH
chmod a+x ~/bin/repo
ソースコードのダウンロード用ディレクトリandroidCoreを作ってそこに移動して、repoコマンドを打つ(masterの場合)
mkdir androidMaster
cd androidMaster/
repo init -u https://android.googlesource.com/platform/manifest
ソースコード取得開始
repo sync -j8ビルド準備
JDKのインストールオラクルのページからjdk-6u33-linux-x64.binをダウンロードしてくる。
$ chmod a+x jdk-6u33-linux-x64.bin
$ ./jdk-6u33-linux-x64.bin
$ sudo mv jdk1.6.0_33 /usr/lib/jvm/
javaの環境設定をしてくれるツールをインストールする
$ wget http://webupd8.googlecode.com/files/update-java-0.5b
$ chmod a+x update-java-0.5b
$ sudo ./update-java-0.5b
jdk1.6.0_33 を選択する。
必要なツールのインストールとシンボリックリンクの作成
$ sudo apt-get install git-core gnupg flex bison gperf build-essential \ zip curl libc6-dev libncurses5-dev:i386 x11proto-core-dev \ libx11-dev:i386 libreadline6-dev:i386 libgl1-mesa-glx:i386 \ libgl1-mesa-dev g++-multilib mingw32 openjdk-6-jdk tofrodos \ python-markdown libxml2-utils xsltproc zlib1g-dev:i386
$ sudo ln -s /usr/lib/i386-linux-gnu/mesa/libGL.so.1 /usr/lib/i386-linux-gnu/libGL.so
ビルド
source build/envsetup.sh
lunch full-eng
make -j8
備考
バージョン(ブランチ名)を指定して取得する場合
repo init -u https://android.googlesource.com/platform/manifest -b android-4.0.4_r1.2
ブランチ名を調べる方法
repo init ....を打った後
$ ls -1 .repo/manifests.git/logs/refs/remotes/origin/
開発環境
ubuntu 12.04 LTS 64bit
メモリ:8G
プロセッサ:intel Core i3
ディスク容量:135G
2012年7月30日月曜日
ソースコード・ビルドメモ
ubuntuをViertualBoxで利用 ソースコードの取得時に止まるので諦める。
ubuntu-11.04-desktop-amd64.iso を利用
必要なソフトのインストール
$ sudo apt-get install git-core gnupg flex bison gperf build-essential \
zip curl zlib1g-dev libc6-dev lib32ncurses5-dev ia32-libs \
x11proto-core-dev libx11-dev lib32readline5-dev lib32z-dev \
libgl1-mesa-dev g++-multilib mingw32 tofrodos python-markdown \
libxml2-utils xsltproc
シンボリックリンクの作成
$ sudo ln -s /usr/lib32/mesa/libGL.so.1 /usr/lib32/mesa/libGL.so
ubuntu-11.04-desktop-amd64.iso を利用
必要なソフトのインストール
$ sudo apt-get install git-core gnupg flex bison gperf build-essential \
zip curl zlib1g-dev libc6-dev lib32ncurses5-dev ia32-libs \
x11proto-core-dev libx11-dev lib32readline5-dev lib32z-dev \
libgl1-mesa-dev g++-multilib mingw32 tofrodos python-markdown \
libxml2-utils xsltproc
シンボリックリンクの作成
$ sudo ln -s /usr/lib32/mesa/libGL.so.1 /usr/lib32/mesa/libGL.so
JDKのインストール
http://source.android.com/source/initializing.html
上記のページに書いてある方法ではインストール出来なくなっていたので、
オラクルのページからダウンロードしてくる。
jdk-6u33-linux-x64.bin
$ chmod a+x jdk-6u33-linux-x64.bin
$ ./jdk-6u33-linux-x64.bin
$ sudo mkdir /usr/lib/jvm
$ sudo mv jdk1.6.0_33 /usr/lib/jvm/
$ cd /usr/lib/jvm
$ sudo ln -s jdk1.6.0_33 java-6-oracle
javaの環境設定をしてくれるツールをインストールする
$ wget http://webupd8.googlecode.com/files/update-java-0.5b
$ chmod a+x update-java-0.5b
$ sudo ./update-java-0.5b
java-6-oracle
repoのインストール
$ mkdir ~/bin
$ PATH=~/bin:$PATH
$ curl https://dl-ssl.google.com/dl/googlesource/git-repo/repo > ~/bin/repo
$ chmod a+x ~/bin/repo
Androidのソースツリーダウンロード
Windows installerを使って30Gの容量でインストールした、ソースのダウンロードは出来たがビルドは容量不足で出来なかった。
結局ハードディスクにインストールしてビルドした。
http://source.android.com/source/initializing.html を確認する。
JDKのインストール
Android 4.0の場合はJava 6をインストールする。
64ビットの場合は、http://developer.android.com/sdk/installing/index.html#troubleshooting
を確認すると,
sudo apt-get install ia32-libs
が必要なようだ。これで sudo apt-get install sun-java6-jdk
インストールで出来なかった。
今回はOAB-Javaでローカルリポジトリを追加して、
Oracle(Sun) Java 6をインストールする。
cd ~/
wget https://github.com/flexiondotorg/oab-java6/raw/0.2.4/oab-java.sh -O oab-java.sh
chmod +x oab-java.sh
sudo ./oab-java.sh
sudo apt-get install sun-java6-jdk これで、java 6 JDK がインストール出来た。
必要なソフトのインストール
$ sudo apt-get install git-core gnupg flex bison gperf build-essential \
zip curl libc6-dev libncurses5-dev:i386 x11proto-core-dev \
libx11-dev:i386 libreadline6-dev:i386 libgl1-mesa-glx:i386 \
libgl1-mesa-dev g++-multilib mingw32 openjdk-6-jdk tofrodos \
python-markdown libxml2-utils xsltproc zlib1g-dev:i386
シンボリックリンクの作成
$ sudo ln -s /usr/lib/i386-linux-gnu/mesa/libGL.so.1 /usr/lib/i386-linux-gnu/libGL.so
repoコマンドのインストール
mkdir ~/bin
PATH=~/bin:$PATH
curl https://dl-ssl.google.com/dl/googlesource/git-repo/repo > ~/bin/repo
chmod a+x ~/bin/repo
gitの設定
git config --global user.email "androckjp@gmail.com"
git config --global user.name "AndRock"
ソースの取得
mkdir WORKING_DIRECTORY
cd WORKING_DIRECTORY
repo init -u https://android.googlesource.com/platform/manifest -b android-4.0.1_r1
repo sync -j4
j4オプションはビルドするマシンのCPU×2倍位にするといいそうです。
envsetup.sh の実行と lunch の設定
source build/envsetup.sh
lunch generic-eng
make の実効
make -j4
http://source.android.com/source/initializing.html
上記のページに書いてある方法ではインストール出来なくなっていたので、
オラクルのページからダウンロードしてくる。
jdk-6u33-linux-x64.bin
$ chmod a+x jdk-6u33-linux-x64.bin
$ ./jdk-6u33-linux-x64.bin
$ sudo mkdir /usr/lib/jvm
$ sudo mv jdk1.6.0_33 /usr/lib/jvm/
$ cd /usr/lib/jvm
$ sudo ln -s jdk1.6.0_33 java-6-oracle
javaの環境設定をしてくれるツールをインストールする
$ wget http://webupd8.googlecode.com/files/update-java-0.5b
$ chmod a+x update-java-0.5b
$ sudo ./update-java-0.5b
java-6-oracle
repoのインストール
$ mkdir ~/bin
$ PATH=~/bin:$PATH
$ curl https://dl-ssl.google.com/dl/googlesource/git-repo/repo > ~/bin/repo
$ chmod a+x ~/bin/repo
Androidのソースツリーダウンロード
ubuntu 12.04 LTS 64ビット
Windows installerを使って30Gの容量でインストールした、ソースのダウンロードは出来たがビルドは容量不足で出来なかった。
結局ハードディスクにインストールしてビルドした。
http://source.android.com/source/initializing.html を確認する。
JDKのインストール
Android 4.0の場合はJava 6をインストールする。
64ビットの場合は、http://developer.android.com/sdk/installing/index.html#troubleshooting
を確認すると,
sudo apt-get install ia32-libs
が必要なようだ。これで sudo apt-get install sun-java6-jdk
インストールで出来なかった。
今回はOAB-Javaでローカルリポジトリを追加して、
Oracle(Sun) Java 6をインストールする。
cd ~/
wget https://github.com/flexiondotorg/oab-java6/raw/0.2.4/oab-java.sh -O oab-java.sh
chmod +x oab-java.sh
sudo ./oab-java.sh
sudo apt-get install sun-java6-jdk これで、java 6 JDK がインストール出来た。
必要なソフトのインストール
$ sudo apt-get install git-core gnupg flex bison gperf build-essential \
zip curl libc6-dev libncurses5-dev:i386 x11proto-core-dev \
libx11-dev:i386 libreadline6-dev:i386 libgl1-mesa-glx:i386 \
libgl1-mesa-dev g++-multilib mingw32 openjdk-6-jdk tofrodos \
python-markdown libxml2-utils xsltproc zlib1g-dev:i386
シンボリックリンクの作成
$ sudo ln -s /usr/lib/i386-linux-gnu/mesa/libGL.so.1 /usr/lib/i386-linux-gnu/libGL.so
repoコマンドのインストール
mkdir ~/bin
PATH=~/bin:$PATH
curl https://dl-ssl.google.com/dl/googlesource/git-repo/repo > ~/bin/repo
chmod a+x ~/bin/repo
gitの設定
git config --global user.email "androckjp@gmail.com"
git config --global user.name "AndRock"
ソースの取得
mkdir WORKING_DIRECTORY
cd WORKING_DIRECTORY
repo init -u https://android.googlesource.com/platform/manifest -b android-4.0.1_r1
repo sync -j4
j4オプションはビルドするマシンのCPU×2倍位にするといいそうです。
envsetup.sh の実行と lunch の設定
source build/envsetup.sh
lunch generic-eng
make の実効
make -j4
2012年7月25日水曜日
ListVewのタッチイベント:ListActivity,onListItemClick
ListActivityにはonListItemClickメソッドが用意されている。
import java.util.ArrayList;
import android.app.ListActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.ArrayAdapter;
import android.widget.ListView;
public class ListVewTouchEventActivity extends ListActivity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
// Listの作成
ArrayList<String> list = new ArrayList<String>();
// Listにデータを入れる
list.add("ゼウス");
list.add("アテナ");
list.add("アポロン");
list.add("ポセイドン");
//ListView に表示する項目設定
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
android.R.layout.simple_list_item_1, list);
setListAdapter(adapter);
}
protected void onListItemClick(ListView listView, View v, int position,long id) {
super.onListItemClick(listView, v, position, id);
String str = (String) listView.getItemAtPosition(position);
Log.v("TAG", position + " 行目の " + str + " がクリックされた");
}
}
07-25 13:05:35.737: V/TAG(4478): 0 行目の ゼウス がクリックされた 07-25 13:05:36.507: V/TAG(4478): 1 行目の アテナ がクリックされた 07-25 13:05:37.307: V/TAG(4478): 2 行目の アポロン がクリックされた 07-25 13:05:42.077: V/TAG(4478): 3 行目の ポセイドン がクリックされた
2012年7月24日火曜日
Threadの利用方法:AsyncTask、ProgressDialog
import android.app.Activity;
import android.app.ProgressDialog;
import android.content.Context;
import android.content.DialogInterface;
import android.content.DialogInterface.OnCancelListener;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
public class AndroidAsyncTaskActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
public void buttonClick(View v) {
Log.d("タグ", "ボタンがクリックした。!");
new MyAsyncTask(this).execute("Param1");
}
public class MyAsyncTask extends AsyncTask<String, Integer, Long> implements OnCancelListener {
private Context context;
private ProgressDialog dialog;
public MyAsyncTask(Context context) {
// TODO 自動生成されたコンストラクター・スタブ
this.context = context;
}
@Override
protected void onPreExecute() {
// タスク開始前処理:UIスレッドで実行される
//進捗ダイアログの表示
Log.d("TAG", "onPreExecute");
dialog = new ProgressDialog(context);
dialog.setTitle("しばらくお待ちください");
dialog.setMessage("データ読み込み中...");
dialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
dialog.setCancelable(true);// ProgressDialog のキャンセルが可能かどうか
dialog.setOnCancelListener(this);
dialog.setMax(100);
dialog.setProgress(0);
// ProgressDialog の Cancel ボタン
dialog.setButton(DialogInterface.BUTTON_NEGATIVE, "キャンセル", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
// ProgressDialog をキャンセル
dialog.cancel();
}
});
dialog.show();
}
@Override
protected Long doInBackground(String... params) {
// 別スレッドで実行する処理
Log.d("", "doInBackground ::" + params[0]);//doInBackground ::Param1
try {
for (int i = 0; i < 10; i++) {
if (isCancelled()) {
Log.d("", "Cancelled!");
break;
}
Thread.sleep(1000);
publishProgress((i + 1) * 10);
}
} catch (InterruptedException e) {
Log.d("", "InterruptedException in doInBackground");
}
return 999L;
}
// プログレスバー更新処理: UIスレッドで実行される
@Override
protected void onProgressUpdate(Integer... values) {
Log.d("", "onProgressUpdate ::" + values[0]);
dialog.setProgress(values[0]);
}
@Override
protected void onCancelled() {
Log.d("", "onCancelled");
dialog.dismiss();
}
@Override
protected void onPostExecute(Long result) {
// タスク終了後処理:UIスレッドで実行される
Log.d("", "onPostExecute :: " + result);//doInBackground のリターン
// 進捗ダイアログをクローズ
dialog.dismiss();
}
public void onCancel(DialogInterface dialog) {
Log.d("", "Dialog onCancell... calling cancel(true)");
this.cancel(true);
}
}
}
07-23 20:52:59.493: D/(12475): onProgressUpdate ::50 07-23 20:53:00.509: D/(12475): onProgressUpdate ::60 07-23 20:53:01.163: D/(12475): Dialog onCancell... calling cancel(true) 07-23 20:53:01.163: D/(12475): InterruptedException in doInBackground 07-23 20:53:01.173: D/(12475): onCancelled
ListView追加読み込み:003 SimpleAdapter
import android.app.Activity;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.ArrayAdapter;
import android.widget.ListView;
public class AndroidAsyncTaskActivity extends Activity implements OnScrollListener {
private ArrayAdapter<String> adapter;
private AsyncTask<String, Integer, Long> mTask;
private ListView listView;
private View mFooter;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
listView = (ListView) findViewById(R.id.listView1);
adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1);
// アイテムを追加します
for (int i = 1; i < 10; i++) {
adapter.add("Item" + i);
}
mFooter = getLayoutInflater().inflate(R.layout.listview_footer, null);
listView.addFooterView(mFooter);
// アダプターを設定します
listView.setAdapter(adapter);
listView.setOnScrollListener(this);
}
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
// TODO 自動生成されたメソッド・スタブ
if (totalItemCount == firstVisibleItem + visibleItemCount) {
Log.d("TAG", "末尾");//
additionalReading();
}
}
private void additionalReading() {
// TODO 自動生成されたメソッド・スタブ
// 既に読み込み中ならスキップ
if (mTask != null && mTask.getStatus() == AsyncTask.Status.RUNNING) {
Log.d("", "読み込み中");
return;
}
mTask = new MyAsyncTask(this).execute("text");
}
public class MyAsyncTask extends AsyncTask<String, Integer, Long> {
public MyAsyncTask(AndroidAsyncTaskActivity androidAsyncTaskActivity) {
}
protected Long doInBackground(String... params) {
Log.d("", "doInBackground ::" + params[0]);// doInBackground
try {
Thread.sleep(2000);//確認のために2秒止める
} catch (InterruptedException e) {
// TODO 自動生成された catch ブロック
e.printStackTrace();
}
return 999L;
}
@Override
protected void onPostExecute(Long result) {
Log.d("", "onPostExecute :: " + result);// doInBackground のリターン
//データ追加
for (int n = 0; n < 10; n++) {
adapter.add("追加" + n);
}
}
}
public void onScrollStateChanged(AbsListView view, int scrollState) {
// TODO 自動生成されたメソッド・スタブ
}
}
ListView:SimpleAdapter View再利用 getView
使い方があってるか良く分からない。
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import android.app.Activity;
import android.os.Bundle;
import android.widget.ListView;
import android.widget.SimpleAdapter;
public class AndroidListviewTest01Activity extends Activity {
private ArrayList<Map<String, String>> retDataList;
private SimpleAdapter adapter;
private HashMap<String, String> data;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
new ArrayList<Map<String, Object>>();
retDataList = new ArrayList<Map<String, String>>();
for (int n = 0; n < 11; n++) {
data = new HashMap<String, String>();
data.put("title", n + "行目");
data.put("comment", "テキスト" + n);
retDataList.add(data);
}
// adapter = new SimpleAdapter(this, retDataList,R.layout.raw, new
// String[] { "title", "comment" }, new int[] {android.R.id.text1,
// android.R.id.text2 });
adapter = new MySimpleAdapter(this, retDataList, R.layout.raw, new String[] { "title", "comment" }, new int[] { android.R.id.text1, android.R.id.text2 });
// MyAdapter adapter = new MyAdapter(this, list);
ListView listView = (ListView) findViewById(R.id.listView1);
listView.setAdapter(adapter);//
}
}
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.SimpleAdapter;
import android.widget.TextView;
public class MySimpleAdapter extends SimpleAdapter {
// private Context context;
private LayoutInflater inflater;
private List<? extends Map<String, ?>> listData;
public class ViewHolder {
TextView line1;
TextView line2;
}
public MySimpleAdapter(Context context, List<? extends Map<String, ?>> data, int resource, String[] from, int[] to) {
super(context, data, resource, from, to);
// TODO 自動生成されたコンストラクター・スタブ
// this.context = context;
this.inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
this.listData = data;
}
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
// ビューを受け取る
View view = convertView;
if (view == null) {
view = inflater.inflate(R.layout.raw, parent, false);
// LayoutInflater inflater = (LayoutInflater)
// context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
// view = inflater.inflate(R.layout.raw, null);
holder = new ViewHolder();
holder.line1 = (TextView) view.findViewById(android.R.id.text1);
holder.line2 = (TextView) view.findViewById(android.R.id.text2);
view.setTag(holder);
} else {
holder = (ViewHolder) view.getTag();
}
String text1 = ((HashMap<?, ?>) listData.get(position)).get("title").toString();
String text2 = ((HashMap<?, ?>) listData.get(position)).get("comment").toString();
holder.line1.setText(text1);
holder.line2.setText(text2);
return view;
}
}
2012年7月23日月曜日
ListView追加読み込み:未002 SimpleAdapter
末尾に追加
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.widget.AbsListView;
import android.widget.ListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.SimpleAdapter;
public class AndroidListviewTest01Activity extends Activity implements OnScrollListener {
Map<String, Object> map0;
Map<String, Object> map1;
private ArrayList<Map<String, String>> retDataList;
private SimpleAdapter adapter2;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
new ArrayList<Map<String, Object>>();
retDataList = new ArrayList<Map<String, String>>();
for (int n = 0; n < 11; n++) {
Map<String, String> data = new HashMap<String, String>();
data.put("title", n + "行目");
data.put("comment", "111");
retDataList.add(data);
}
adapter2 = new SimpleAdapter(this, retDataList,
R.layout.raw, new String[] { "title", "comment" },
new int[] {android.R.id.text1, android.R.id.text2 });
ListView listView = (ListView) findViewById(R.id.listView1);
listView.setAdapter(adapter2);//
listView.setOnScrollListener(this);
}
public void onScroll( AbsListView view, int firstVisibleItem,int visibleItemCount, int totalItemCount ) {
// TODO 自動生成されたメソッド・スタブ
Log.d("TAG", "スクロールが発生した。2");
Log.d("TAG", "firstVisibleItem::" + firstVisibleItem );
Log.d("TAG", "visibleItemCount::" + visibleItemCount );
Log.d("TAG", "totalItemCount::" + totalItemCount );
if (totalItemCount == firstVisibleItem + visibleItemCount) {
Log.d("TAG", "end");//
// mData.add( );
//List<Map<String, String>> retDataList = new ArrayList<Map<String, String>>();
Map<String, String> data = new HashMap<String, String>();
data.put("title", "追加");
data.put("comment", "111");
retDataList.add(data);
adapter2.notifyDataSetChanged();
}
}
public void onScrollStateChanged(AbsListView arg0, int arg1) {
// TODO 自動生成されたメソッド・スタブ
}
}
2012年7月22日日曜日
ListView追加読み込み:未001ArrayAdapter
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.widget.AbsListView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.AbsListView.OnScrollListener;
public class AndroidListviewTest01Activity extends Activity implements OnScrollListener{
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ListView listView = (ListView) findViewById(R.id.listView1);
//ListView に表示する項目設定
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1);
// アイテムを追加します
for (int n = 0; n < 10; n++) {
adapter.add("Item" + n );
}
// アダプタを設定します。
listView.setAdapter(adapter);
listView.setOnScrollListener(this);
}
public void onScroll(AbsListView view, int firstVisibleItem,int visibleItemCount, int totalItemCount) {
// TODO 自動生成されたメソッド・スタブ
Log.d("TAG", "スクロールが発生した。2");
Log.d("TAG", "firstVisibleItem::" + firstVisibleItem );
Log.d("TAG", "visibleItemCount::" + visibleItemCount );
Log.d("TAG", "totalItemCount::" + totalItemCount );
if (totalItemCount == firstVisibleItem + visibleItemCount) {
Log.d("TAG", "end");//
addListView();
}
}
private void addListView() {
// TODO 自動生成されたメソッド・スタブ
Log.d("TAG", "end2");//
ListView listView = (ListView) findViewById(R.id.listView1);
@SuppressWarnings("unchecked")
ArrayAdapter<String> tempAdapter = (ArrayAdapter<String>)listView.getAdapter();
tempAdapter.add("001");
}
public void onScrollStateChanged(AbsListView arg0, int arg1) {
// TODO 自動生成されたメソッド・スタブ
}
}
ListViewで複雑なタッチイベントを取得する:GestureDetector
ListViewの要素変更:ArrayAdapter viewの再利用の記事のソースを複雑なタップイベントが取得出来るようにする。
とりあえずダブルタップを取得してみる。
とりあえずダブルタップを取得してみる。
import java.util.ArrayList;
import java.util.List;
import android.app.ListActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.GestureDetector;
import android.view.View;
import android.view.GestureDetector.SimpleOnGestureListener;
import android.view.MotionEvent;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
public class AndroidListViewTestActivity extends ListActivity implements OnItemClickListener
{
private GestureDetector gestureDetector;
private View.OnTouchListener gestureListener;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
gestureDetector = new GestureDetector(new MyGestureDetector());
gestureListener = new View.OnTouchListener() {
public boolean onTouch(View v, MotionEvent event) {
return gestureDetector.onTouchEvent(event);
}
};
getListView().setOnItemClickListener(this);
getListView().setOnTouchListener(gestureListener);
List<BindData> list = new ArrayList<BindData>();
// ここにlistに項目を追加する処理が入る
list.add(new BindData("タイトル0", null, null));
list.add(new BindData(null, "line1-1", "line1-2"));
for (int i = 1; i < 10; i++) {
list.add(new BindData("タイトル" + i, null, null));
list.add(new BindData(null, "line2-1", "line2-2"));
list.add(new BindData(null, "line2-12", "line2-22"));
}
MyAdapter adapter = new MyAdapter(this, list);
setListAdapter(adapter);
}
public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
// TODO 自動生成されたメソッド・スタブ
Log.i("TAG", "::" + "リストがタッチされた2" );
}
class MyGestureDetector extends SimpleOnGestureListener {
@Override
public boolean onDoubleTap(MotionEvent event) {
Log.d("TAG", "ダブルタップが発生した。");
return super.onDoubleTap(event);
}
}
}
07-22 05:06:34.806: D/TAG(13681): ダブルタップが発生した。 07-22 05:06:34.937: I/TAG(13681): ::リストがタッチされた2
2012年7月21日土曜日
Activityのライフサイクルを確認
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
public class ActivityTest extends Activity {
//アクティビティが最初に起動するときに呼び出される。
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
Log.i("タグ", "onCreate()");
}
//アクティビティが表示される直前に呼ばれます。
public void onStart() {
super.onStart();
Log.i("タグ", "onStart()");
}
//アクティビティがユーザとのやり取りを始められるようになる直前に呼ばれます。
public void onResume() {
super.onResume();
Log.i("タグ", "onResume()");
}
//アクティビティがバックグラウンドに隠れるときに呼ばれます。
public void onPause() {
super.onPause();
Log.i("タグ", "onPause()");
}
//アクティビティがユーザーから見えなくなったとき
public void onStop() {
super.onStop();
Log.i("タグ", "onStop()");
}
//終了状態になったアクティビティが再び実行される直前呼ばれる。
public void onRestart() {
super.onRestart();
Log.i("タグ", "onRestart()");
}
//アクティビティが破棄される直前に呼ばれます。
public void onDestroy() {
super.onDestroy();
Log.i("タグ", "onDestroy()");
}
//Activityのインスタンスを保存 Bundleにデータ保存する
public void onSaveInstanceState(Bundle savedInstanceState){
super.onSaveInstanceState(savedInstanceState);
Log.i("タグ", "onSaveInstanceState()");
}
//Activityのインスタンスを復帰
public void onRestoreInstanceState(Bundle savedInstanceState){
super.onRestoreInstanceState(savedInstanceState);
Log.i("タグ", "onRestoreInstanceState()");
}
// ボタンイベント
public void SetButtonOnClick(View v) {
switch (v.getId()) {
case R.id.button1:
Log.i("タグ", "ボタン1が押された");
break;
case R.id.button2:
Log.i("タグ", "ボタン2が押された");
Intent subactivity = new Intent(this,com.yamato.test.SecondScreenActivity.class);
startActivity(subactivity);
break;
case R.id.button3:
Log.i("タグ", "ボタン3が押された");
finish();
break;
}
}
}
最初に起動させた時
07-21 05:57:31.581: I/タグ(3992): onCreate() 07-21 05:57:31.581: I/タグ(3992): onStart() 07-21 05:57:31.592: I/タグ(3992): onResume()
ホームボタンを押した時
07-21 06:00:18.332: I/タグ(3992): onSaveInstanceState() 07-21 06:00:18.332: I/タグ(3992): onPause() 07-21 06:00:19.042: I/タグ(3992): onStop()
ホームボタンを押した後アプリケーション画面から起動させた時
07-21 06:03:46.612: I/タグ(3992): onRestart() 07-21 06:03:46.612: I/タグ(3992): onStart() 07-21 06:03:46.612: I/タグ(3992): onResume()
finish()が呼びさされた時
07-21 06:06:09.833: I/タグ(3992): onPause() 07-21 06:06:10.451: I/タグ(3992): onStop() 07-21 06:06:10.451: I/タグ(3992): onDestroy()
finish()で終了した後、アプリケーション画面から起動させた時
07-21 06:08:34.592: I/タグ(3992): onCreate() 07-21 06:08:34.592: I/タグ(3992): onStart() 07-21 06:08:34.592: I/タグ(3992): onResume()
別アクティビティーが呼ばれた時
07-21 06:32:38.362: I/タグ(4904): onSaveInstanceState() 07-21 06:32:38.362: I/タグ(4904): onPause() 07-21 06:32:38.842: I/タグ(4904): onStop()
別アクティビティーが呼ばれた後戻るボタンを押した時
07-21 06:34:51.502: I/タグ(4904): onRestart() 07-21 06:34:51.502: I/タグ(4904): onStart() 07-21 06:34:51.502: I/タグ(4904): onResume()
複数ボタンの処理:view button
import android.app.Activity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
public class ButtonActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
// ボタンイベント
public void SetButtonOnClick(View v) {
switch (v.getId()) {
case R.id.button1:
Log.i("buttonTest", "ボタン1が押された");
break;
case R.id.button2:
Log.i("buttonTest", "ボタン2が押された");
break;
case R.id.button3:
Log.i("buttonTest", "ボタン3が押された");
break;
}
}
}
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<Button
android:id="@+id/button1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="SetButtonOnClick"
android:text="Button1" />
<Button
android:id="@+id/button2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="SetButtonOnClick"
android:text="Button2" />
<Button
android:id="@+id/button3"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="SetButtonOnClick"
android:text="Button3" />
</LinearLayout>
2012年7月15日日曜日
assetsフォルダのフォントファイルの利用:Typeface
フォントサイズが大きすぎてassets フォルダで未圧縮の状態では使えない場合。
assets フォルダに圧縮したフォントファイルをおいて、アプリケーション領域にコピーして使う。
アプリの容量は、4GB にまで拡大されたが、APK ファイル自体のサイズは50MBまで、
拡張ファイル1つあたりの制限は2GB までなので2GBを超えるフォントサイズでは使えないので、WEBからダウンロードする方法を採らないといけないかも。
assetsフォルダの圧縮ファイルを解凍してアプリケーション領域のfilesフォルダにコピーする。
一つのファイルが圧縮されている場合。
try {
AssetManager am = getResources().getAssets();
InputStream is = am.open("ipaexm.zip", AssetManager.ACCESS_STREAMING);
ZipInputStream zis = new ZipInputStream(is);
ZipEntry ze = zis.getNextEntry();
if (ze != null) {
path = getFilesDir().toString() + "/" + ze.getName();
FileOutputStream fos = new FileOutputStream(path, false);
byte[] buf = new byte[1024];
int size = 0;
while ((size = zis.read(buf, 0, buf.length)) > -1) {
fos.write(buf, 0, size);
}
fos.close();
zis.closeEntry();
}
zis.close();
} catch (Exception e) {
e.printStackTrace();
}
圧縮ファイルに複数のファイルが含まれているとき
try {
AssetManager am = getResources().getAssets();
InputStream is = am.open("ipaexm.zip", AssetManager.ACCESS_STREAMING);
ZipInputStream zis = new ZipInputStream(is);
ZipEntry ze = zis.getNextEntry();
while (ze != null) {
path = getFilesDir().toString() + "/" + ze.getName();
FileOutputStream fos = new FileOutputStream(path, false);
byte[] buf = new byte[1024];
int size = 0;
while ((size = zis.read(buf, 0, buf.length)) > -1) {
fos.write(buf, 0, size);
}
fos.close();
zis.closeEntry();
ze = zis.getNextEntry();
}
zis.close();
} catch (Exception e) {
e.printStackTrace();
}
フォントファイルがアプリケーションデータ領域のfilesフォルダに保存されている場合
TextView tv2 = (TextView)findViewById(R.id.textView2);
TextView tv3 = (TextView)findViewById(R.id.textView3);
Typeface typeface = Typeface.createFromFile("/data/data/com.ymato.font/files/ipaexg.ttf");
Typeface typeface2 = Typeface.createFromFile("/data/data/com.ymato.font/files/ipaexm.ttf");
tv2.setTypeface(typeface);//
tv3.setTypeface(typeface2);//
フォントファイルがSDカードに入っている場合
Typeface typeface = Typeface.createFromFile( new File(Environment.getExternalStorageDirectory(), "ipaexm.ttf"));
assetsフォルダには1MB以上の非圧縮ファイルを設置できないので、
大きいサイズのフォントファイルを置いたらエラーが出た
Data exceeds UNCOMPRESS_DATA_MAX (6022748 vs 1048576)
FileOutputStream fos = new FileOutputStream(path, false); ではパーミッションが
-rw------- になるので変更する場合
FileOutputStream fos = openFileOutput( ze.getName() , MODE_WORLD_READABLE);
ファイルの指定方法が違う、上は/data/data/[app name]/files/fileName,
下は、ファイル名のみ、
MODE_PRIVATE このアプリからのみ使用
MODE_APPEND 現在のファイルに追記
MODE_WORLD_READABLE 他のアプリからも読み込み可能
MODE_WORLD_WRITEABLE 他のアプリからも書き込み可能
2012年7月9日月曜日
ListViewの要素変更:ArrayAdapter viewの再利用
AndroidListViewTestActivity.java
import java.util.ArrayList;
import java.util.List;
import android.app.ListActivity;
import android.os.Bundle;
public class AndroidListViewTestActivity extends ListActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
List<BindData> list = new ArrayList<BindData>();
// ここにlistに項目を追加する処理が入る
list.add(new BindData("タイトル1", null , null));
list.add(new BindData(null, "line1-1" ,"line1-2"));
list.add(new BindData("タイトル2", null , null));
list.add(new BindData(null, "line2-1" ,"line2-2"));
list.add(new BindData(null, "line2-12" ,"line2-22"));
MyAdapter adapter = new MyAdapter(this, list);
setListAdapter(adapter);
}
}
MyAdapter.java
import java.util.List;
import android.content.Context;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.TextView;
class BindData {
String title;
String line1;
String line2;
public BindData(String string0, String string1, String string2) {
this.title = string0;
this.line1 = string1;
this.line2 = string2;
}
}
class ViewHolder {
TextView title;
TextView line1;
TextView line2;
}
public class MyAdapter extends ArrayAdapter<BindData> {
private LayoutInflater inflater;
public MyAdapter(Context context, List<BindData> objects) {
super(context, 0, objects);
this.inflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
}
@Override
public boolean isEnabled(int position) {
// 選択不可にする
return true;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = inflater.inflate(R.layout.raw, parent, false);
holder = new ViewHolder();
holder.title = (TextView) convertView.findViewById(R.id.title);
holder.line1 = (TextView) convertView.findViewById(R.id.line1);
holder.line2 = (TextView) convertView.findViewById(R.id.line2);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
BindData data = getItem(position);
//Log.d("タグ", ":" + position);
//Log.d("タグ", "::" + data.title);
//Log.d("タグ", ":::" + isEnabled(position));
// タイトル
if ( getItem(position).title != null ) {
holder.title.setVisibility(View.VISIBLE);
holder.title.setText(data.title);
holder.line1.setVisibility(View.GONE);
holder.line2.setVisibility(View.GONE);
// line1,2
} else {
holder.title.setVisibility(View.GONE);
holder.line1.setVisibility(View.VISIBLE);
holder.line1.setText(data.line1);
holder.line2.setVisibility(View.VISIBLE);
holder.line2.setText(data.line2);
}
return convertView;
}
}
main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<ListView
android:id="@id/android:list"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
raw.xml
<?xml version="1.0" encoding="utf-8"?>
<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/title"
android:layout_width="fill_parent"
android:layout_height="wrap_content" android:background="#808080" android:textColor="#FFFFFF" android:text="title" android:gravity="center"/>
<!-- アルバム名 -->
<TextView
android:id="@+id/line1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="line1"/>
<!-- アーティスト名 -->
<TextView
android:id="@+id/line2"
android:layout_width="fill_parent"
android:layout_height="wrap_content" android:text="line2"/>
</LinearLayout>
[ソースコード公開中]
Google Code
2012年7月6日金曜日
ListViewの要素変更:SimpleAdapter
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.app.ListActivity;
import android.content.Context;
import android.graphics.Color;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.SimpleAdapter;
import android.widget.TwoLineListItem;
public class AndroidListView004Activity extends ListActivity {
public class MySimpleAdapter extends SimpleAdapter {
public MySimpleAdapter(Context context, List<Map<String, String>> items, int resource, String[] from, int[] to) {
super(context, items, resource, from, to);
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = super.getView(position, convertView, parent);
TwoLineListItem v = (TwoLineListItem)view;
v.getText1().setTextSize(30);
if (position % 2 == 0) {
view.setBackgroundColor(Color.BLACK);
} else {
view.setBackgroundColor(Color.DKGRAY);
}
return view;
}
}
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
List<Map<String, String>> dataList = new ArrayList<Map<String,String>>();
Map<String, String> data = new HashMap<String, String>();
data.put("title", "タイトル欄");
data.put("comment", "COMMENT欄");
dataList.add(data);
data = new HashMap<String, String>();
data.put("title", "タイトル欄2");
data.put("comment", "COMMENT欄");
dataList.add(data);
MySimpleAdapter adapter = new MySimpleAdapter(
this,
dataList,
android.R.layout.simple_list_item_2,
new String[] { "title", "comment" },
new int[] { android.R.id.text1, android.R.id.text2 }
);
setListAdapter(adapter);
}
}
main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<ListView
android:id="@id/android:list"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</LinearLayout>
ListViewフォントサイズの変更
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import android.widget.TextView;
public class AndroidListViewActivity extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
String[] data = {"太陽", "水星", "金星"};
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this
, android.R.layout.simple_list_item_1, data ) {
@Override
public View getView(int position, View convertView, ViewGroup parent) {
TextView view = (TextView)super.getView(position, convertView, parent);
view.setTextSize( 30 );
return view;
}
};
ListView listView = (ListView) findViewById(R.id.listView1);
// アダプターを設定します
listView.setAdapter(adapter);
}
}
3行表示:ListView
一行に3つのTextView を表示出来るかやってみた。
res/raw フォルダに raw.xml ファイルを作成する。
res/raw フォルダに raw.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/textView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TextView" />
<TextView
android:id="@+id/textView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TextView" />
<TextView
android:id="@+id/textView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="TextView" />
</LinearLayout>
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.app.Activity;
import android.os.Bundle;
import android.widget.ListView;
import android.widget.SimpleAdapter;
public class AndroidListViewActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
// ListView を取得
ListView listView = (ListView) findViewById(R.id.listView1);
List<Map<String, String>> retDataList = new ArrayList<Map<String, String>>();
//for (int n = 0; n < 3; n++) {
Map<String, String> data = new HashMap<String, String>();
data.put("title", "一行目");
data.put("comment", "111");
data.put("note", "aaa");
retDataList.add(data);
data = new HashMap<String, String>();
data.put("title", "二行目");
data.put("comment", "222");
data.put("note", "bbb");
retDataList.add(data);
// リストビューに渡すアダプタを生成します。
SimpleAdapter adapter2 = new SimpleAdapter(this, retDataList,
R.layout.raw, new String[] { "title", "comment" ,"note"},
new int[] {R.id.textView1, R.id.textView2 , R.id.textView3});
// アダプタを設定します。
listView.setAdapter(adapter2);
}
}
android.R.layout.simple_list_item_2を変更:ListView
res/raw フォルダに raw.xml ファイルを作成する。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" xmlns:android="http://schemas.android.com/apk/res/android">
<TextView
android:id="@android:id/text1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="TextView"
android:textSize="18dp" >
</TextView>
<TextView
android:id="@android:id/text2"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="TextView" >
</TextView>
</LinearLayout>
main.xml<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<ListView
android:id="@+id/listView1"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
</ListView>
</LinearLayout>
アダプターの生成部分
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import android.app.Activity;
import android.os.Bundle;
import android.widget.ListView;
import android.widget.SimpleAdapter;
public class AndroidListView003Activity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
ListView listView = (ListView) findViewById(R.id.listView1);
List<Map<String, String>> retDataList = new ArrayList<Map<String, String>>();
//for (int n = 0; n < 3; n++) {
Map<String, String> data = new HashMap<String, String>();
data.put("title", "一行目");
data.put("comment", "111");
retDataList.add(data);
data = new HashMap<String, String>();
data.put("title", "二行目");
data.put("comment", "222");
retDataList.add(data);
// リストビューに渡すアダプタを生成します。
SimpleAdapter adapter2 = new SimpleAdapter(this, retDataList,
R.layout.raw, new String[] { "title", "comment" },
new int[] {android.R.id.text1, android.R.id.text2 });
// アダプタを設定します。
listView.setAdapter(adapter2);
}
}
2012年7月5日木曜日
処理時間の測定
long start = System.currentTimeMillis();
//測定したい処理
long end = System.currentTimeMillis();
Log.d("タグ", "measure: " + (end - start) +" ms");
登録:
コメント (Atom)










