eclipse で Javaのコードを書いてAndroid アプリ開発の勉強をやっています。
昨日は、画面を縦方向にスクロールできるようにレイアウトを定義する方法や、インテントを使って画面を切り替える方法などを学習しました。
インテントを使って画面を切り替える場合には、画面のレイアウトを追加し、AndroidManifest.xml に定義を追加し、コードの中でインテントの記述をします。画面を切り替える際に文字列を引き渡すことができます。
なお、現在、作成しているのは、Android 上でAccess のデータベースファイル(mdbファイルやaccdbファイルなど)のテーブルの内容を表示するアプリです。Accessのデータベースにアクセスするために jackcess や ucanaccess などのライブラリを使用しています。
ucanaccess を使ったサンプルプログラムを以下でも紹介させていただいております。
http://chaos-fractal.blogspot.jp/2014/10/android-accessmdb.html
(2014.11.1)
テキストビューを横スクロールできるようにする方法を学習しました。layout ファイルを書き換えてやる必要があります。
アプリを公開する方法についても調べています。
(2014.11.21)
開発したAndroid アプリをはじめて公開 してみました。
2014年10月31日金曜日
2014年10月30日木曜日
SSL 3.0 の脆弱性への対応について
SSL 3.0 の脆弱性の対応を行うため、以下のサイトを参照して、FireFox にアドオンをいれました。
http://www.mozilla.jp/blog/entry/10433/
SSL3.0の脆弱性対策についての情報処理推進機構のサイト
http://www.ipa.go.jp/security/announce/20141017-ssl.html
http://www.mozilla.jp/blog/entry/10433/
SSL3.0の脆弱性対策についての情報処理推進機構のサイト
http://www.ipa.go.jp/security/announce/20141017-ssl.html
2014年10月29日水曜日
Androidアプリ開発 Excelに書かれた株のリストのそれぞれの株価を取得して表示する
まずExcelファイルには、いくつかの株のコードが書かれています。以下のサンプルでは、Excelのファイルから株のコードを読み取り、それぞれの株について、インターネットのYahooのサイトから株価を取得して表示します。Excelから株コードを読み取るためにjexcelapi というライブラリを使用して、インターネットから株価を取得するためには、jsoup というライブラリを使用しています。
source code
source code
Android アプリ開発 Excelシートのデータを表示する
Android アプリで、Excel ファイルを読み込んでシートの内容を表示するサンプルです。Jexcel というライブラリを使用しています。私の環境ではなぜか新しいタイプのxlsxファイルは読み込めず、古いタイプのxlsファイルは読み込めました。
source code
source code
Android アプリ開発でプログラム内でビューを定義する
Android アプリ開発では、プログラムの中でビューを作ることもできます。以下のサンプルでは、7つのボタンを配置して、その後さらに、OKとCancelのボタンを作成しています。
import android.app.Activity;
import android.os.Bundle;
import android.widget.Button;
import android.widget.LinearLayout;
public class MainActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LinearLayout linearLayout = new LinearLayout(this);
linearLayout.setOrientation(LinearLayout.VERTICAL);
setContentView(linearLayout);
Button[] buttons ;
int num_arr;
num_arr=7;
buttons = new Button[num_arr];
int i =0;
while ( i < num_arr){
buttons[i] = new Button(this);
buttons[i].setText("number" + i );
buttons[i].setLayoutParams(new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.WRAP_CONTENT,
LinearLayout.LayoutParams.WRAP_CONTENT));
linearLayout.addView(buttons[i]);
i=i+1;
}
Button button1 = new Button(this);
button1.setText("OK");
button1.setLayoutParams(new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.MATCH_PARENT,
LinearLayout.LayoutParams.WRAP_CONTENT));
linearLayout.addView(button1);
Button button2 = new Button(this);
button2.setText("Cancel");
button2.setLayoutParams(new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.WRAP_CONTENT,
LinearLayout.LayoutParams.WRAP_CONTENT));
linearLayout.addView(button2);
}
}
import android.app.Activity;
import android.os.Bundle;
import android.widget.Button;
import android.widget.LinearLayout;
public class MainActivity extends Activity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
LinearLayout linearLayout = new LinearLayout(this);
linearLayout.setOrientation(LinearLayout.VERTICAL);
setContentView(linearLayout);
Button[] buttons ;
int num_arr;
num_arr=7;
buttons = new Button[num_arr];
int i =0;
while ( i < num_arr){
buttons[i] = new Button(this);
buttons[i].setText("number" + i );
buttons[i].setLayoutParams(new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.WRAP_CONTENT,
LinearLayout.LayoutParams.WRAP_CONTENT));
linearLayout.addView(buttons[i]);
i=i+1;
}
Button button1 = new Button(this);
button1.setText("OK");
button1.setLayoutParams(new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.MATCH_PARENT,
LinearLayout.LayoutParams.WRAP_CONTENT));
linearLayout.addView(button1);
Button button2 = new Button(this);
button2.setText("Cancel");
button2.setLayoutParams(new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.WRAP_CONTENT,
LinearLayout.LayoutParams.WRAP_CONTENT));
linearLayout.addView(button2);
}
}
Java で Jackcess ライブラリを使用し Accessデータベースのテーブルのフィールド名を取得する
Jackcess というライブラリを使用するとAccessデータベースのファイルにアクセスできることがわかりました。
使用したのは、以下のjarファイルです。
jackcess-2.0.6.jar
commons-lang-2.6.jar
commons-logging-1.1.1.jar
以下のサンプルでは、Java で Jackcess ライブラリを使用し Accessデータベースのテーブルのフィールド名を取得して表示しています。
Contacts.accdb というデータベースのContacts というテーブルのフィールド名をリストアップして表示しています。
また、そのテーブル内のレコードのLast Name と Address というフィールドの内容を表示しています。
import java.io.File;
import java.sql.Types;
import java.util.List;
import java.util.Set;
import com.healthmarketscience.jackcess.*;
public class jackcess_sample1{
public static void main(String[] args) {
try {
Database db = DatabaseBuilder.open(new File("/home/user/Contacts.accdb"));
Table table =db.getTable("Contacts");
List<? extends Column> Columns=table.getColumns();
for(Column column : Columns){
System.out.println("column_name =" + column.getName());
}
for(Row row : table) {
System.out.println("row = " + row.get("Last Name") + " " + row.get("Address"));
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
(2014.11.22)
Jackcess を使って Access データベースのテーブルを更新する場合には制限があります。データベースによっては更新できないのです。
使用したのは、以下のjarファイルです。
jackcess-2.0.6.jar
commons-lang-2.6.jar
commons-logging-1.1.1.jar
以下のサンプルでは、Java で Jackcess ライブラリを使用し Accessデータベースのテーブルのフィールド名を取得して表示しています。
Contacts.accdb というデータベースのContacts というテーブルのフィールド名をリストアップして表示しています。
また、そのテーブル内のレコードのLast Name と Address というフィールドの内容を表示しています。
import java.io.File;
import java.sql.Types;
import java.util.List;
import java.util.Set;
import com.healthmarketscience.jackcess.*;
public class jackcess_sample1{
public static void main(String[] args) {
try {
Database db = DatabaseBuilder.open(new File("/home/user/Contacts.accdb"));
Table table =db.getTable("Contacts");
List<? extends Column> Columns=table.getColumns();
for(Column column : Columns){
System.out.println("column_name =" + column.getName());
}
for(Row row : table) {
System.out.println("row = " + row.get("Last Name") + " " + row.get("Address"));
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
(2014.11.22)
Jackcess を使って Access データベースのテーブルを更新する場合には制限があります。データベースによっては更新できないのです。
2014年10月26日日曜日
Excel やAccess のファイルをAndroid から操作するアプリを開発する
個人がデータベースを構築して使用する際に、サーバー形式のOracle 、MySQL、SQLserver などを使うという方法もあるのかもしれませんが、それほど大きくないデータベースの場合には、ExcelやAccess を使用するということも多いのではないでしょうか?
そうして作成した Excel や Access のファイルを、Dropbox などのクラウド上に配置して、PCからもスマホやタブレットからも使用したいというニーズはあると思います。
そのため、最近は、Android から、ExcelやAccessのファイル(xls、xlsx、mdb、accdbなど)を操作するアプリを作ってみようという気になっています。
Androidアプリは、Ubuntu上でEclipseを使ってJava で作成しています。また、Excelのxls,xlsx ファイルを操作するには、POIやjexcelapiというAPIを使えばできるらしいということがわかっています。 また、Accessのmdb,accdb ファイルを操作するには、ucanaccess というAPIを使用すればできることがわかっています。
POIやucanaccess はダウンロードして、解凍して、jar ファイルを取り出し、所定の位置に配置すれば使用できます。
なお、自分で開発しなくても Android で Accessデータベースを閲覧するアプリ は存在します。
そうして作成した Excel や Access のファイルを、Dropbox などのクラウド上に配置して、PCからもスマホやタブレットからも使用したいというニーズはあると思います。
そのため、最近は、Android から、ExcelやAccessのファイル(xls、xlsx、mdb、accdbなど)を操作するアプリを作ってみようという気になっています。
Androidアプリは、Ubuntu上でEclipseを使ってJava で作成しています。また、Excelのxls,xlsx ファイルを操作するには、POIやjexcelapiというAPIを使えばできるらしいということがわかっています。 また、Accessのmdb,accdb ファイルを操作するには、ucanaccess というAPIを使用すればできることがわかっています。
POIやucanaccess はダウンロードして、解凍して、jar ファイルを取り出し、所定の位置に配置すれば使用できます。
なお、自分で開発しなくても Android で Accessデータベースを閲覧するアプリ は存在します。
Ubuntu 14.10 にアップグレードしました。
Ubuntu 14.10 にアップグレードしました。ただしアップグレードの途中で以下のようなメッセージが表示されてしまいました。
クラッシュレポート
アプリケーション Ubuntu Software Center が突然終了しました。
Syslinux-themes-debian パッケージが動かない状態にある可能性があります。
クリーンアップ中に問題が発生しました。
installArchives() failed
クラッシュレポート
アプリケーション Ubuntu Software Center が突然終了しました。
Syslinux-themes-debian パッケージが動かない状態にある可能性があります。
クリーンアップ中に問題が発生しました。
installArchives() failed
2014年10月23日木曜日
2014年10月20日月曜日
Android アプリ開発サンプル Accessのmdb
以下のAndroidのサンプルアプリでは、ucanaccessを使ってAccessのmdbファイルにアクセスして、テーブルにレコードを追加しています。
Android sample code which add a record of Access database file (mdb file). It needs three edittext fields and two buttons on layout.
source code
Android sample code which add a record of Access database file (mdb file). It needs three edittext fields and two buttons on layout.
source code
Androidアプリ開発 Accessデータベースであるmdbファイルにアクセス
先日、紹介させていただいたODBCブリッジを使用しないでJAVAからAccessデータベースのファイルにアクセスする方法を使って、Androidの簡単なアプリを作成してみました。ODBCブリッジを使用しないでAccessにアクセスするというのは、ucanaccess というしくみを使用するものです。Accessデータベースの場合にはファイルの拡張子は、mdbかまたはaccdbです。(mdbのほうが古いです。)以下のソースコードではdropbox/mdb/foma0.mdbというAccessデータベースの中のfoma1というテーブルの内容を表示しています。
Android appli development sample code which acccess to the Access database mdb file.
source code
Android appli development sample code which acccess to the Access database mdb file.
source code