昨天,有提到有關新增及點選ListView時,會觸發的事件及說明,如下述程式碼,特別加了注解的部份。主要是要切換到新增、編輯的Activity時,要用Intent物件來帶參數過去。
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
    //取得按下ListView的那個Item的值。
    String strbookname = adapterView.getItemAtPosition(i).toString();
    //按下Item時,要呼叫編輯的Activity,利用Intent物件帶參數過去。
    Intent it = new Intent();
    it= new Intent(this,frm_book_edit.class);
    it.putExtra("pname",strbookname);
    startActivity(it);
    //關閉本身的Activity。
    this.finish();
}
public void prc_btnadd(View v)
{
    //按下新增時,要呼叫新增的Activity,利用Intent物件。
    Intent it = new Intent();
    it= new Intent(this,frm_book_add.class);
    startActivity(it);
    //關閉本身的Activity。
    this.finish();
}
接下來,我們先來看看要如何新增書籍資料。在原來的專案,再增加一個Empty Activity,Activity名稱,取名為「frm_book_add」。再拉出三個TextView、二個EditVIew、一個Spinner及二個Button,來當做書籍名稱、簡介的輸入欄位及分類的下拉式選項。按下存檔的Button,再呼叫api來存入資料庫,再回到列表的Activity。順序來排列出來。如下圖所示:



呼叫的API,有二段。一個是將分類的資料,跟Spinner元件結合起來,才可以下拉式的方式來選取此書籍的分類。另一段,就是要輸入的書籍名稱、簡介、所屬分類,以Http POST的方式回存在伺服器的資料庫。
_api_gettags.php
<?php
	//引用資料庫連接檔案
    include("conn/_db_Config.php");
	//查詢分類資料的SQL語法
	//查詢分類資料的SQL語法
	//執行SQL語法,並且將資料轉成array
    $res = $db->query("select ctag_id, ctag_name from ttaginfo");
    
    $arytags = array();
    while ($row = $res->fetch_assoc()) {
    	$arytags[] = $row;
    }   
    
	//輸出成JSON字串,要加JSON_UNESCAPED_UNICODE,中文字才不會變成亂碼	
    echo json_encode($arytags, JSON_UNESCAPED_UNICODE);
?>
在網頁執行看看,沒有沒問題。
執行成功,回到Android,看看要如何呼叫此api,也是用之前文章用的方式,透過Volley物件,用GET的方式,回傳JSON字串。再解析成陣列後,再跟Spinner元件結合。完整的程式碼,如下:
//宣告物件名稱。
private RequestQueue objqueue;
private final static String strurl = "http://220.134.63.231:8088/book/_api_gettags.php";
private Spinner lst_tag;
private EditText txt_name;
private EditText txt_content;
ArrayList<String> arytags;
private StringRequest getRequest;
//宣告物件 (POST物件)
private RequestQueue objpostqueue;
private StringRequest postRequest;
private final static String strposturl = "http://220.134.63.231:8088/book/_api_addbookinfo.php";
@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_frm_book_add);
    StrictMode.ThreadPolicy policy = new StrictMode.ThreadPolicy.Builder().permitAll().build();
    StrictMode.setThreadPolicy(policy);
    //物件名稱跟Layout上的物件,產生連結。
    lst_tag = (Spinner)findViewById(R.id.lsttag);
    txt_name = (EditText)findViewById(R.id.txtname);
    txt_content = (EditText)findViewById(R.id.txtcontent);
    arytags=new ArrayList<>();
    //設定Volley物件。
    objqueue = Volley.newRequestQueue(this);
    //實做Volley物件,在StringRequest的函式,預設值就是Request.Method.GET,可以省略。
    //而strurl,就是要GET的API網址。
    //最後,還要Override二個監聽的事件。
    getRequest = new StringRequest(strurl, new Response.Listener<String>() {
        @Override
        public void onResponse(String response) {
            //response,表示是回傳值,就是API要回傳的字串,也可以是JSON字串。
            //宣告JSONArray時,要用try...catch包起來,不然會出現錯誤。
            try{
                //將JSON字串,放到JSONArray中。
                JSONArray array = new JSONArray(response);
                //解出JSON的資料,將所要的資料,再寫入陣列中。
                for (int i = 0; i < array.length(); i++) {
                    JSONObject jsonObject = array.getJSONObject(i);
                    String strtagname = jsonObject.getString("ctag_name");
                    arytags.add(strtagname);
                }
            }
            catch(JSONException e) {
                e.printStackTrace();
            }
            //將陣列跟Spinner物件連結在一起。
            lst_tag.setAdapter(new ArrayAdapter<String>(frm_book_add.this, android.R.layout.simple_spinner_dropdown_item, arytags));
        }
    }, new Response.ErrorListener() {
        @Override
        public void onErrorResponse(VolleyError error) {
            //如果發生錯誤,就是回傳VolleyError,可以顯示是什麼錯誤。
        }
    });
    //將getRequest物件加入Volley物件的queue中,執行跟API的溝通。
    objqueue.add(getRequest);
}
執行出來的新增畫面,如下圖所示:
輸入好書籍名稱、內容後,再按「存檔」,將資料存回資料庫。後續,再說明如何將資料,存入資料庫。