月別アーカイブ: 2013年12月

Google MapsV2

AndroidでGoogle MapsV2を利用するサンプル
Google Play services のバージョン13で利用方法(AndroidManifestへの設定)が変更になりました。

以下に基本マップのコードを掲載しておきます。

device-2013-12-09-100318

MainActivity.java

import java.io.IOException;
import java.util.List;
import java.util.Locale;

import android.location.Address;
import android.location.Geocoder;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;

import com.google.android.gms.maps.CameraUpdateFactory;
import com.google.android.gms.maps.GoogleMap;
import com.google.android.gms.maps.SupportMapFragment;
import com.google.android.gms.maps.model.LatLng;

public class MainActivity extends FragmentActivity {

// GoogleMap変数宣言
private GoogleMap mMap;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

// Mapの初期化
if (mMap == null) {
mMap = ((SupportMapFragment) getSupportFragmentManager()
.findFragmentById(R.id.map)).getMap();

// Mapが有効なら表示位置とズームレベルを指定
if (mMap != null) {
LatLng posision = new LatLng(37.904137, 139.047429);
mMap.moveCamera(CameraUpdateFactory.newLatLngZoom(posision, 15));
}
}

// ボタンの初期化とオンクリックリスナーの実装
Button btn = (Button) findViewById(R.id.button1);
btn.setOnClickListener(new OnClickListener() {

@Override
public void onClick(View v) {
// テキストビューの初期化
TextView tv = (TextView) findViewById(R.id.textView1);
// LatLng型変数にマップの中心座標を代入
LatLng po = mMap.getCameraPosition().target;
// テキストに住所を表示
tv.setText(getAddress(po));
}
});
}

// 緯度、経度情報から住所を取得するメソッド
private String getAddress(LatLng po) {

// 情報出力用文字列バッファの初期化
StringBuffer buff = new StringBuffer();

try {
Geocoder geocoder = new Geocoder(this, Locale.getDefault());
// 取得する情報数を最初の1つに指定(推奨 1 – 5)してListに格納
List<Address> address = geocoder.getFromLocation(po.latitude,
po.longitude, 1);
for (Address addr : address) {
int index = addr.getMaxAddressLineIndex();
// 0はたいがい国名
for (int i = 1; i <= index; i++) {
// 文字バッファに追加
buff.append(addr.getAddressLine(i));
}
}
} catch (IOException e) {
e.printStackTrace();
}

return buff.toString();
}

}

activity_main.xml

<LinearLayout xmlns:android=”http://schemas.android.com/apk/res/android”
xmlns:tools=”http://schemas.android.com/tools”
android:id=”@+id/LinearLayout1″
android:layout_width=”match_parent”
android:layout_height=”match_parent”
android:orientation=”vertical”
tools:context=”.MainActivity” >

<LinearLayout
android:layout_width=”match_parent”
android:layout_height=”match_parent”
android:layout_weight=”1″
android:orientation=”vertical” >

<fragment
android:id=”@+id/map”
android:name=”com.google.android.gms.maps.SupportMapFragment”
android:layout_width=”match_parent”
android:layout_height=”match_parent” />
</LinearLayout>

<LinearLayout
android:layout_width=”match_parent”
android:layout_height=”wrap_content” >

<Button
android:id=”@+id/button1″
android:layout_width=”wrap_content”
android:layout_height=”wrap_content”
android:text=”中心の住所” />

<TextView
android:id=”@+id/textView1″
android:layout_width=”wrap_content”
android:layout_height=”wrap_content”
android:text=”TextView” />
</LinearLayout>

</LinearLayout>

AndroidMaifest.xml

<?xml version=”1.0″ encoding=”utf-8″?>
<manifest xmlns:android=”http://schemas.android.com/apk/res/android”
package=”com.example.mapbase2″
android:versionCode=”1″
android:versionName=”1.0″ >

<uses-sdk
android:minSdkVersion=”10″
android:targetSdkVersion=”18″ />
<uses-feature android:required=”true”
android:glEsVersion=”0x00020000″/>
<uses-permission
android:name=”com.google.android.providers.gsf.permission.READ_GSERVICES”/>
<uses-permission android:name=”android.permission.WRITE_EXTERNAL_STORAGE”/>
<uses-permission android:name=”android.permission.INTERNET”/>
<uses-permission android:name=”android.permission.ACCESS_COARSE_LOCATION”/>
<uses-permission android:name=”android.permission.ACCESS_FINE_LOCATION”/>
<uses-permission android:name=”android.permission.ACCESS_NETWORK_STATE”/>

<application
android:allowBackup=”true”
android:icon=”@drawable/ic_launcher”
android:label=”@string/app_name”
android:theme=”@style/AppTheme” >
<activity
android:name=”com.example.mapbase2.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>
<meta-data android:value=”ここは自分で取得したコード”
android:name=”com.google.android.maps.v2.API_KEY”/>
<meta-data android:value=”@integer/google_play_services_version”
android:name=”com.google.android.gms.version”/>
</application>

</manifest>

AndroidManifest.xmlは、Google Play servicesに同梱されているMapサンプルを見るとわかりやすいです。

Android 4.4対応のADTのXMLエディター

Android SDKを最新の4.4対応(API 19)にアップデートすると、ADTも対応のパーションにアップデートしないといけません。

ところがその最新版ADTのXMLエディターが、便利になったのか不便になったのか・・・

オブジェクトのプロパティを設定する時、すでに設定されているプロパティ値を変更する場合は直接プロパティウィンドウの該当するプロパティを編集できますが、新規にプロパティを設定する場合には慣れないと少々不便な入力方法に変わってしまいました。

新規に設定する場合は、アウトラインウィンドウ上の該当するパーツの上でマウスボタンを右クリックして追加する形になってしまいました。

まあ、良くなったのか悪くなったのかは個人の主観によると思いますが・・・

ご注意あれ。

ActivityForResultのサンプル

Activityを呼び出してデータを受渡し、戻り値をもらうサンプル。

device-2013-12-03-182032  device-2013-12-03-182407

MainActivity.java

package com.example.activityresulttest;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;

public class MainActivity extends Activity {

// リクエストコードの定数
private static final int SUB_ACTIVITY = 1;
// 共通変数定義
private EditText inputText;

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// エディットテキスト初期化
inputText = (EditText) findViewById(R.id.editText1);

// ボタン初期化とクリックリスナーの実装
Button btn = (Button) findViewById(R.id.button1);
btn.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// TODO 自動生成されたメソッド・スタブ
// サブアクティビティ起動インテント生成
Intent intent = new Intent(getApplicationContext(),
SubActivity.class);
// インテントにパラメーターをセット
intent.putExtra(“MAIN_INPUT_TEXT”, inputText.getText()
.toString());
// 戻り結果を受け取るアクティビティの呼出し
startActivityForResult(intent, SUB_ACTIVITY);
}
});
}

// アクティビティの戻り値を受け取るメソッド
@Override
protected void onActivityResult(int requestCode, int resultCode,
Intent intent) {
super.onActivityResult(requestCode, resultCode, intent);
// リクエストコードを照合して処理するメソッド
if (requestCode == SUB_ACTIVITY) {
// リザルトコードを照合して処理するメソッド
if (resultCode == RESULT_OK) {
// 戻り値にセットされたインテントのパラメータを受け取る
Bundle extras = intent.getExtras();
// パラメータを受け取っていたらテキストエディットに表示、無かったら空白を表示
if (extras != null) {
inputText.setText(extras.getString(“SUB_TEXT”));
} else {
inputText.setText(“”);
}
}
}
}
}

SubActivity.java

package com.example.activityresulttest;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.EditText;

public class SubActivity extends Activity {

// 共通変数定義
private EditText editText;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_sub);

// エディットテキスト初期化
editText = (EditText) findViewById(R.id.sub_editText1);

// 受け渡されたインテントのパラメータを取得
Intent intent = getIntent();
Bundle extras = intent.getExtras();

// パラメータがある場合にはエディットテキストに表示、無かったら空白を表示
if (extras != null) {
editText.setText(extras.getString(“MAIN_INPUT_TEXT”));
} else {
editText.setText(“”);
}

// キャンセルボタンの初期化とクリックリスナーの実装
Button btn_cancel = (Button) findViewById(R.id.btn_cancel);
btn_cancel.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// リザルトコードにキャンセルをセットしてアクティビティを終了
setResult(RESULT_CANCELED);
finish();
}
});

// リターンボタンの初期化とクリックリスナーの実装
Button btn_return = (Button) findViewById(R.id.btn_return);
btn_return.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
// インテントを生成し、パラメーターにエディットテキストの内容をセット
Intent intent = new Intent();
intent.putExtra(“SUB_TEXT”, editText.getText().toString());
// リザルトコードにOK をセットして戻り値をセットしてアクティビティを終了
setResult(RESULT_OK, intent);
finish();
}
});
}
}