2015年1月12日 星期一

補考

今天早上去看了一下補考同學的狀況,本人也是修這門課的學生

看完了也花了幾分鐘的時間作過一遍

個人覺得還蠻簡單的

程式寫法有很多種

沒有一定的寫法,只要執行出來是正確就沒有什麼!!


在使用不同的開發工具
在介面上都需要調整到自己最佳的畫面(最佳寫程式的畫面,會依照不同的螢幕大小調整,以及撰寫區塊的文字大小)

以下是我在寫 android app 成是習慣的介面


當然在不同的動作時會有一些小小的視窗跑出來
這時把它縮小就可以了(以免要用的的時候找不到)


再來就是補考的程式補考內容囉!!

跳到MainActivity.java
圖a是我寫的程式

圖a. MainActivity.java程式碼
圖b為activity_main.xml介面的程式碼
這也可以用拖曳的方式產生所以我就不show畫面囉!!
只是我在裡面有一點小細節要注意一下喔~~(自行尋找囉!!)
我比較習慣看程式碼
因為這樣在不同平台沒有圖形介面也是可以Debug
這在對於很多工程師當中需要的人員吧!!(自己覺得啦!!這也不是一定)

圖b. activity_main.xml程式碼
痾~~~這樣就可以了!!
是的就這麼簡單!!
應該是不用到幾分鐘就寫完了!!

所以程式不是這麼難
最主要就是要常用以及參考他人的寫作
網路上都有很多資源
當然也要找對關鍵字(關鍵字如果可以盡量可以用英文)
這樣也會快速找到想要的資訊

個人是看 Android App 寫作推薦的書籍


老師說這本好像會有點厚
自己慢慢看重點囉!!
這本不見得終生適用喔!!
因為程式會改版,所以要去看官網的使用手冊喔!!

最重要就是要花時間囉!!
話就說到這裡囉!!

2014年12月17日 星期三

android 2.2 ↑↓ 版使用 HtppClient

***********************************
test3.php
***********************************
<?php

?>


**********************************************************************
GetPhpServerMessageDemoActivity.java
**********************************************************************



public class GetPhpServerMessageDemoActivity extends Activity {
    /** Called when the activity is first created. */
    private TextView textView;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        textView = (TextView)findViewById(R.id.text_view);

        String msg = stringQuery("http://localhost/androidapp/android_connect/test3.php");
        textView.setText("Server message is "+msg);
    }
    
    public String stringQuery(String url){
        try
        {
            HttpClient httpclient = new DefaultHttpClient();
            HttpPost method = new HttpPost(url);
            
            HttpResponse response = httpclient.execute(method);
            /*HttpEntity entity = response.getEntity();*/
            if(response != null){
                return response.getStatusLine().toString();
            }
            else{
                return "No string.";
            }
            
         }
         catch(Exception e){
             return "Network problem";
         }
    }
    
    
}




因為我們只要測試是否連線正常   回傳 200 為正常
只要有產生 php 的檔案就可以了!!







Android 4.0 ↑請看 :
Recognizer + Android 4.0↑ HttpClient 實作

Recognizer + Android 4.0↑ HttpClient 實作

***********************************
test3.php
***********************************


<?php

header ("Content-Type:text/html; charset=utf-8");

$response = $_POST['data'];


echo $response;




?>

***********************************
Main.java
***********************************

public class Main extends Activity implements OnClickListener

{
private String txtMessage;
private Button sendBtn;
private TextView tv;

private String uriAPI = "http://localhost/androidapp/test3.php";
protected static final int REFRESH_DATA = 0x00000001;

@Override
public void onCreate(Bundle savedInstanceState)
{

super.onCreate(savedInstanceState);
setContentView(R.layout.main);


sendBtn = (Button) findViewById(R.id.send_btn);
tv = (TextView)findViewById(R.id.textView1);

if (sendBtn != null)
sendBtn.setOnClickListener(this);
}

Handler mHandler = new Handler()
{
@Override
public void handleMessage(Message msg)
{
switch (msg.what)
{

case REFRESH_DATA:
String result = null;
if (msg.obj instanceof String)
result = (String) msg.obj;
if (result != null)

tv.setText(result);
break;
}
}
};

@Override
public void onClick(View v)

{
if (v == sendBtn)
{
Intent it = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
       it.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,
               RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
       it.putExtra(RecognizerIntent.EXTRA_PROMPT, "請說...");
       this.startActivityForResult(it, 1);

}
}

@Override
    public void onActivityResult(int requestCode, int resultCode, Intent it) {
        if (requestCode != 1) {
         
            return;
        }
        if (resultCode != RESULT_OK) {
         
            return;
        }
        List<String> list = it.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);
        txtMessage = list.get(0);
     
        this.onclick2(txtMessage);
     
    }

public void onclick2 (String txtMessage) {
if (txtMessage != null)
{

final String msg = txtMessage.toString();

Thread t = new Thread(new sendPostRunnable(msg));
t.start();
}
}

class sendPostRunnable implements Runnable
{
String strTxt = null;

public sendPostRunnable(String strTxt)
{
this.strTxt = strTxt;
}

@Override
public void run()
{
String result = sendPostDataToInternet(strTxt);
mHandler.obtainMessage(REFRESH_DATA, result).sendToTarget();
}

}

private String sendPostDataToInternet(String strTxt)
{

HttpPost httpRequest = new HttpPost(uriAPI);

List<NameValuePair> params = new ArrayList<NameValuePair>();

params.add(new BasicNameValuePair("data", strTxt));

try

{
httpRequest.setEntity(new UrlEncodedFormEntity(params, HTTP.UTF_8));

HttpResponse httpResponse = new DefaultHttpClient()
.execute(httpRequest);

if (httpResponse.getStatusLine().getStatusCode() == 200)
{

String strResult = EntityUtils.toString(httpResponse
.getEntity());

return strResult;
}
} catch (Exception e)
{
e.printStackTrace();
}
return null;
}

}


***********************************
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" >

    <Button
        android:id="@+id/send_btn"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="@string/send" />

    <TextView
        android:id="@+id/textView1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

</LinearLayout>


***********************************
AndroidManifest.xml
***********************************

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

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

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name" >
        <activity
            android:name=".Main"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
    <!-- 這裡加入可以存取網路的權限 -->

    <uses-permission android:name="android.permission.INTERNET" />

</manifest>













Android 2.2 ↑↓請看:
android 2.2 ↑↓ 版使用 HtppClient

2014年12月4日 星期四

一個.java檔 完成呼叫google語音辨識系統



只要一個.java完成呼叫google語音辨識系統

這不是很方便嗎?

接下來我們就來看一下程式碼囉!!


/***********************************************
MainActivity.java
***********************************************/


public class MainActivity extends ActionBarActivity {
private ImageButton btnspeak;  //在這裡我們就宣告一個 ImageButton 型態的 btnspeak變數
private static final String TAG = "SpeechRecognizerActivity";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        llbtn();    //在這裡我們呼叫llbtn這麼function
     
    }
 
    //viewbtn    這裡就是我們所呼叫的llbtn的function,接下來看一下做了什麼事情
    public void llbtn() {
//這邊宣告ll 變數型態為LinearLayout
LinearLayout ll=(LinearLayout) findViewById(R.id.LinearLayout1);
//在這new ImageButton 出來
btnspeak =new ImageButton(this);
//設定ImageButton 的圖案為ic_btn_speak_now,如果要設定文字的話就要用Button型態宣告以及設定時使用setText()這個方法來作設定
btnspeak.setImageDrawable(getResources().getDrawable(drawable.ic_btn_speak_now));
//ll加入View出btnSpeak變數
ll.addView(btnspeak);
//設定 l 為btnspeak 呼叫的function
btnspeak.setOnClickListener(l);
    }
    //接下來就是呼叫語音辨識系統了
    private ImageButton.OnClickListener l=new ImageButton.OnClickListener(){

     @Override
     public void onClick(View v) {
     Intent it = new Intent(RecognizerIntent.ACTION_RECOGNIZE_SPEECH);
     it.putExtra(RecognizerIntent.EXTRA_LANGUAGE_MODEL,
     RecognizerIntent.LANGUAGE_MODEL_FREE_FORM);
     it.putExtra(RecognizerIntent.EXTRA_PROMPT, "請說...");
//這裡要小心  在Android Recognizer文章中這裡是 "this.startActivityForResult(it,1);"這樣無法呼叫傳 (it ,1) 給onActivityResult這個function喔!!
     startActivityForResult(it, 1);
     }
   
   
    };
 
 
    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent it) {
        if (requestCode != 1) {
            Log.d(TAG, "不是語音辨識");
            return;
        }
        if (resultCode != RESULT_OK) {
            Log.e(TAG, "語音辨識失敗");
            return;
        }
        List<String> list = it.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);
        StringBuilder text = new StringBuilder();
        for (String s : list) {
            text.append(s + "\n");
        }

    }
 
 
     

   
 
/**************************************************************/

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

    @Override
    public boolean onOptionsItemSelected(MenuItem item) {
        // Handle action bar item clicks here. The action bar will
        // automatically handle clicks on the Home/Up button, so long
        // as you specify a parent activity in AndroidManifest.xml.
        int id = item.getItemId();
        if (id == R.id.action_settings) {
            return true;
        }
        return super.onOptionsItemSelected(item);
    }
}




這樣是不是簡單多了呢!!





2014年11月30日 星期日

Android App 控制返回鍵

因為返回件為大多數Android 手機必備的按鍵

在我昨天學到的三秒跳轉頁面發現這樣一個問題

按下回上一頁@@

怎麼跳回去上一個activity的頁面了!!

今天研究出了解決這樣的問題點

@Override
public void run() {
// TODO Auto-generated method stub
try {
Thread.sleep(3000);
startActivity(new Intent().setClass(SplashActivity.this, MainActivity.class));
/*如果要在三秒後跳到主頁面後返回不要跳回此頁,可加入這行*/
     xsystarActivity.this.finish(); 
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

}).start();
}


加上一點美感的返回對話框


protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }
   
    /*返回建設定*/
    public boolean onKeyDown(int keyCode, KeyEvent event) {

        if ((keyCode == KeyEvent.KEYCODE_BACK)) {  

            ConfirmExit();

            return true;

        }

        return super.onKeyDown(keyCode, event);

}
   
    private void ConfirmExit() {
// TODO Auto-generated method stub
    AlertDialog.Builder ad=new AlertDialog.Builder(MainActivity.this); //創建訊息方塊

        ad.setTitle("離開");

        ad.setMessage("確定要離開?");

        ad.setPositiveButton("是", new DialogInterface.OnClickListener() { //按"是",則退出應用程式

            public void onClick(DialogInterface dialog, int i) {

              MainActivity.this.finish();

       }

     });

        ad.setNegativeButton("否",new DialogInterface.OnClickListener() { //按"否",則不執行任何操作

            public void onClick(DialogInterface dialog, int i) {

       }

     });

        ad.show();
}



Android App 進入程式前畫面

/************************************************************************
*                                       MainActivity.java                                                                         *
*                                                                                                                                             *
************************************************************************/



public class MainActivity extends ActionBarActivity {

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


    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }

 
}


/************************************************************************
*                                      SplashActivity.java                                                                        *
*                       在src的資料夾裡建立此 .java  檔                                                       *
************************************************************************/

public class SplashActivity extends Activity {
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
setContentView(R.layout.splash);
new Thread(new Runnable(){

@Override
public void run() {
// TODO Auto-generated method stub
try {
Thread.sleep(3000);
startActivity(new Intent().setClass(SplashActivity.this, MainActivity.class));
/*如果要在三秒後跳到主頁面後返回不要跳回此頁,可加入這行*/
     xsystarActivity.this.finish(); 
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

}).start();
}

@Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }
}


/************************************************************************
*                                     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"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context="com.example.test.MainActivity" >

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/hello_world" />

</RelativeLayout>



/************************************************************************
*                                     splash.xml                                                                                       *
*        自行在/res/layout資料夾下建立這個檔案                               *
************************************************************************/

<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"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".MainActivity"
    android:background="@drawable/darkgray" >

    <ImageView
        
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:contentDescription="@string/app_name"
        android:src="@drawable/butterfly" />

</RelativeLayout>


/************************************************************************
*                             AndroidManifest.xml                                                                             *
*                                                                                                                                             *
************************************************************************/



        <activity
//這邊要注意一下喔!!   你建立專案的名稱
            android:name="com.example.test.MainActivity"
            android:label="@string/app_name" >
         
        </activity>
        <activity android:name=".SplashActivity" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

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


點入App的第一個畫面


3秒後跳轉至的頁面




2014年11月27日 星期四

語音文字判斷(比對)

最近在用語音出來的文字如何判斷

今天終於給我是出來了


List<String> list = it.getStringArrayListExtra(RecognizerIntent.EXTRA_RESULTS);      
     
 /*這段再作判斷以及取得list取得第一個陣列文字作判斷就好了*/
       if (list.get(0).equals("賽夏")) {
        tv.setText("賽夏");
       }else {
        tv.setText("查無此意");
       }








語音請參考這裡:http://kuoapp.blogspot.tw/2014/11/android.html