顯示具有 Google 標籤的文章。 顯示所有文章
顯示具有 Google 標籤的文章。 顯示所有文章

2013年6月17日 星期一

Google Maps Android API v2 APP 開發步驟

網路上很多 Google Maps Android API v2 相關文章,但有各種不同講法,自己試了 1-2 個禮拜都沒有成功,最後結合網路找的資料跟 android sdk 內附的 maps 範例程式,總算成功試出來了,因此作下記錄。

準備工作…
一、建立 keystore 並取出 SHA1 碼。
 到 jre bin 目錄下 C:\Program Files\Java\jre6\bin\
 建立 keysor…
  keytool -genkey -v -keystore yourkeyname.keystore -alias yourkeyname -keyalg RSA -keysize 2048 -validity 10000
 取出 sha1 碼…
  keytool -list -v -keystore yourkeyname.keystore > save_sha1.txt
  打開 save_sha1.txt 找到 sha1 碼
      SHA1:xx:xx:xx…

二、到 Google apis 申請 API key
 到 https://code.google.com/apis/console/
 Create project
 Services 中 google Maps Android API v2 點一下 off 改成 on
 API Access 中「Create new Android key」
  輸入「sha1碼」+「;」+「your_package_name
  產生出 API key…
   Key for Android apps (with certificates)
   API key:AIzaSyB1yoElxxxxxxxx...

三、打開 Android SDK Manager 安裝  Google Play services,在 extra 底下。
 
四、將  google-play-services_lib import 進 Workspace。
 在 SDK 安裝目錄下 \extras\google\google_play_services\libproject\google-play-services_lib

開發專案…
一、建立新專案。

二、將 google-play-services_lib 函式庫加入專案中。
 project > properties >Android Library , Add。

三、順便將 Android Lint Preferences > Correctness:Messages 中 Missing Translation 改為 Ignore。(忽略多國語言未翻譯的錯誤)

四、修改 AndroidManifest.xml,加入權限及 API key。
 application 內加入 api key…
        <meta-data
            android:name="com.google.android.maps.v2.API_KEY"
                    android:value="AIzaSyB1yoElxxxxxxxx..."/>

 接著 application 底下加入權限設定…
    <permission
        android:name="your_package_name.permission.MAPS_RECEIVE"
        android:protectionLevel="signature"/>
    <uses-permission android:name="your_package_name.permission.MAPS_RECEIVE"/>
    <uses-permission android:name="android.permission.INTERNET"/>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <uses-permission android:name="com.google.android.providers.gsf.permission.READ_GSERVICES"/>
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION"/>
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
    <uses-feature android:glEsVersion="0x00020000" android:required="true"/>


五、修改 activIty_main.xml,內容改成底下,最簡易 layout,只用 fragment …
<?xml version="1.0" encoding="utf-8"?>
<fragment xmlns:android="http://schemas.android.com/apk/res/android"
  android:id="@+id/map"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  class="com.google.android.gms.maps.SupportMapFragment"/>


 六、MainActivity.java 範例…
public class MainActivity  extends FragmentActivity {

    private GoogleMap mMap;

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

    @Override
    protected void onResume() {
        super.onResume();
        setUpMapIfNeeded();
    }

    private void setUpMapIfNeeded() {
        // Do a null check to confirm that we have not already instantiated the map.
        if (mMap == null) {
            // Try to obtain the map from the SupportMapFragment.
            mMap = ((SupportMapFragment) getSupportFragmentManager().findFragmentById(R.id.map))
                    .getMap();
            // Check if we were successful in obtaining the map.
            if (mMap != null) {
                setUpMap();
            }
        }
    }
    private void setUpMap() {
        mMap.setMyLocationEnabled(true);
    }

} 

註:API LEVEL 8 以上 Android 2.2 以上才能支援 Google Play services。
註:keystore 可以用自己產生的(release用),也可以用 debug 的。(在 C:\Documents and Settings\USER\.android\debug.keystore)

2010年5月31日 星期一

Android 開發 Google Map API - 如何註冊 API Key

Google Map View 官方教學網站…

http://developer.android.com/resources/tutorials/views/hello-mapview.html

這有詳盡的 Android Google API 開發教學~

萬事起頭難,其中提到,必須有一組 API Key 才能註冊成為合法認證的 Google API,才能在 Android 上執行,才可以開始玩。(其實就是 java 憑證)

建立過程如下…

一、在開發的過程中,可以先建立 debug certificate…

http://code.google.com/intl/zh-TW/android/add-ons/google-apis/mapkey.html#getdebugfingerprint


二、按照上面的說明,先找到應用程式存放 debug keystore 的地方,通常放在…

C:\Documents and Settings\<user>\.android\debug.keystore

或可透過裝了 ADT 的 Eclipse 選單 Windows > Prefs > Android > Build 中找到完整路徑。

三、再下達…

keytool -list -alias androiddebugkey -keystore <path_to_debug_keystore>.keystore -storepass android -keypass android

會發生二個問題…
  • keytool.exe 的位置:在 JAVA JRE 安裝目錄中,例如…

    C:\Program Files\Java\jre6\bin

  • 路徑有可能包含空白字元,導致無法在 DOS COMMAND 視窗下達指令,你可以先把 debug.keystore 拷貝到 C:\ 再下達指令…

    keytool -list -alias androiddebugkey -keystore c:\debug.keystore -storepass android -keypass android

四、如此便會算出 MD5 碼…

androiddebugkey, 2010/5/15, keyEntry,
認證指紋 (MD5): 70:02:A3:1F:85:35:D1:A4:3C:1C:D2:12:34:56:78:90

五、有了 MD5 碼就可以到 Android Maps API Key Signup 網頁註冊新的 API Key…

http://code.google.com/intl/zh-TW/android/maps-api-signup.html

六、完成註冊,得到 API Key…

感謝您申請 Android Maps API 金鑰!
您的金鑰為:
0GNWKtyf-6M2YDIU3XIjq-Qgqh0yn1234567890
此金鑰適合所有使用以下指紋憑證所簽署的應用程式:
70:02:A3:1F:85:35:D1:A4:3C:1C:D2:12:34:56:78:90

有了金鑰就可以拿來填到 main.xml 中了。


p.s. 下達 keytool 指令時可以善用 DOS 輸出導向功能 keytool ooo xxx yyy ... zzz > md5.txt  , 把輸出導向到一個檔案方便拷貝,以免打錯 MD5 碼。

2010年5月23日 星期日

Android EventListener 建立方法

元件常常有很多「event」必預要去「listen」,這時候需要靠 EventListener。

網路上看到的範例大多長的像底下這個樣子…

btn.setOnClickListener(new OnClickListener() {
public void onClick(View v) {
/// TODO
}
});


乍看可能還很難以理解這一小段程式是在作什麼,其實整個意義如同底下這段程式…

btn.setOnClickListener( new clsOnClickListener() );
///---inline class ---///
public class clsOnClickListener implements OnClickListener {
public void onClick(View v) {
/// TODO
}
}



也就是它其實是建立了個新的 class implements 原來的 OnClickListener 來自訂 onClick 事件處理函式。

但難的是在 coding 的時候往往不曉得(或忘了)有哪些事件,有哪些 listener,更別說要寫出上面第一段那樣的程式了。

還好 Eclipse 開發環境很好用,你可以利用它自動產生程式碼的功能,幫你做到這些事。
用說的不好解釋,看段影片說明…

http://www.youtube.com/v/plW4zMxpnBA



這樣就可以減輕腦袋的負荷了~^ ^

Android 動態產生元件

Android 應用程式的開發一般都將 UI 跟 RESOURCES 的部分抽離出來,好方便管理及設計,也因此有一些 XML 檔需要撰寫,主要都是用來描述這些資源。

但若要自己土法練鋼寫動態產生時要怎麼作?


@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
///setContentView(R.layout.main); ///不使用 main.xml 資源

LinearLayout layout = new LinearLayout(this);
this.addContentView(layout, new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
layout.setOrientation(LinearLayout.VERTICAL);

Button btn = new Button(this);
btn.SetText("Button");
layout.addView(btn, new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT));

EditText txt = new EditText(this);
layout.addView(txt, new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.WRAP_CONTENT));
}


相對照若用 xml 來描述的話像這樣…

<LinearLayout
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
xmlns:android="http://schemas.android.com/apk/res/android">
<Button
android:text="Button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
</Button>
<EditText
android:layout_width="fill_parent"
android:layout_height="wrap_content">
</EditText>
</LinearLayout>

Android 練習-寶石方塊

直接將自己舊的 java 手機程式改成 Android 版本。

http://www.youtube.com/v/bYORe68RixQ

Android TabLayout 使用心得

Android 2.2 SDK 己經出了…
http://developer.android.com/sdk/index.html
最近也在學習,還好之前有 java/javaME 的基礎,還算順利。

Google 官方有提供教學網頁…
http://developer.android.com/resources/index.html 
很不錯。

不過其中一個範例 TabLayout 的使用…
 http://developer.android.com/resources/tutorials/views/hello-tabwidget.html
這個範例對初學者來講比較複雜。

底下是比較簡單易理解的版本…

HelloTabWidgetNoIcon.java

package com.study.HelloTabWidgetNoIcon;

import android.app.TabActivity;
import android.os.Bundle;
import android.widget.TabHost;

public class HelloTabWidgetNoIcon extends TabActivity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);

TabHost tabHost = getTabHost(); // The activity TabHost
TabHost.TabSpec spec; // Resusable TabSpec for each tab

// Initialize a TabSpec for each tab and add it to the TabHost
spec = tabHost.newTabSpec("artists").setIndicator("Artists").setContent(R.id.tab0);
tabHost.addTab(spec);

// Do the same for the other tabs
spec = tabHost.newTabSpec("albums").setIndicator("Albums").setContent(R.id.tab1);
tabHost.addTab(spec);

spec = tabHost.newTabSpec("songs").setIndicator("Songs").setContent(R.id.tab2);
tabHost.addTab(spec);

tabHost.setCurrentTab(0);
}
}


main.xml

<?xml version="1.0" encoding="utf-8"?>
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<LinearLayout
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:padding="5dp">
<TabWidget
android:id="@android:id/tabs"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:padding="5dp" >

<TextView
android:text="tab0"
android:id="@+id/tab0"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:text="tab1"
android:id="@+id/tab1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:text="tab2"
android:id="@+id/tab2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />

</FrameLayout>
</LinearLayout>
</TabHost>


對照一下 HelloTabWidgetNoIcon.java 及 main.xml 就可以了解程式碼跟 layout 間的對應關係了(tab0,tab1,tab2)。

跟官方的範例不同的地方在於,官方的還多加了…
一、Tab 的小圖示( ic_tab_artists.xml, ic_tab_albums.xml, ic_tab_songs.xml 及圖片 )
二、動態的 Tab View ( ArtistsActivity.java, AlbumsActivity.java, SongsActivity.java )
所以才比較複雜並且要多撰寫一些 xml 碼。

不過,若真的要用在手機上,當然還是用圖示比較吸引人嘍。

2010年5月2日 星期日

申請使用GoogleApps免費服務記錄


Google Apps 是 GOOGLE 提供的一項很好用的服務,提供免費的網頁、EMAIL服務…,一些小公司、小企業、社群團體都應該考慮使用這項免費的服務,其中EMAIL服務算是最重要的,有了這個,你再也不用自己架設、管理MAIL伺服器,可以節省一大筆開銷又能同時獲得很穩定的EMAIL服務(己使用二年的經驗來看算是非常穩定的)


你需要…
一個有效的網域名稱 ( 可以申請免費服務 )
一台DNS伺服器 ( 可以申請免費服務 )
一台網頁伺服器 ( 驗證用,透過其它驗證方式,可以省掉不用 )

換句話說,你完全不需要準備任何伺服器,就可以完成 GOOGLE APPS 服務的申請。

底下是簡單的申請步驟抓圖記錄

到申請首頁輸入你的網域名稱(透過購買或從網路上申請免費網域名稱)


輸入申請資料


輸入管理理帳戶資料


初步申請完成


進行「網域名稱驗證」,以驗證這個網域確實是你的,二種驗證方式,CNAME不需要主機,只需要DNS服務,網頁方式則需要透過上傳網頁的方式來進行,選取後GOOGLE會導引你進行驗證。


這邊是使用網頁的方式進行驗證(需要有自己的網頁伺服器)


再來是EMAIL的設定,需要設定DNS的MX記錄,指向GOOGLE的MAIL管理伺服器,才能讓GOOGL順利利用此網域收發信


這邊使用免費網域twbbs,設定MX記錄讓EMAIL生效


幾小時後,你的email服務就可以使用了!!



2009年3月3日 星期二

GMAIL建立標籤及篩選器的方法

GMAIL的標籤及篩選器搭配使用的方法…
一、點「設定」


二、點選標籤,建立一個新的標籤


三、點選篩選器,建立新的篩選器



四、在過瀘項目上填寫上條件
例如:
mary」、「peter@yahoo.com.tw」、「小明」…
亦可使用萬用字元「*」及「|」(或)來連結多個條件,例如:
mary|peter|*@mycompany.com

填好條件可以先按下「測試搜尋」來測試一下對不對,再進行下一步。




五、最後指定符合這個篩選條件的郵件要作何處理,這邊是幫它加上之前建好的標籤,記得勾選「同時套用到…」把以前的郵件也套用上這個篩選器,如此一來你的郵件就可以自動分好類了,。



六、你還可以把不同的標籤設定成不同的顏色。

GMAIL如何發信給一個群組

一、進入GMAIL通訊錄:


二、勾選你要群組在一起的聯絡人:


三、為這個群組命名,注意,開頭第一個字請不要使用中文,有些中文沒辦法達到自動群發的效果,可以使用符號,譬如「+同事」:



四、這樣以後撰寫郵件時,只要在收件人那邊打上第一個字,就會跳出群組名單讓你挑選了,非常方便:

VirtualBox 空間減肥

sdelete64 -z c: VBoxManage  modifymedium  disk  "/Users/fellow/VirtualBox VMs/Win10/Win10.vdi"  --compact *.vdi 路徑可以在 VirtualBox 儲...