心情小品:
禮拜五結束了貴公司的面試,忐忑不安的心理持續到了今天,
中午 人潮人海的休息時間 看的莫名感動,因為真希望我能成為裡面其中一份子
成為秉持著熱誠、專業、來服務客戶的一份子
相信只有努力練習是不會騙人的,為自己的人生努力,也未未來的公司多一份戰力
所以 美好的假日還是持續跟APP說 Hello囉 ^^。
如何使用第三方程式庫 Retrofit 下載Json資料(進入)
Android 元件 Glide、GridView
1.作業前準備:
Step1. Android Studio→先進行環境設定 加入網路權限
詳細位置:Android Manifest
程式碼:<uses-permission android:name="android.permission.INTERNET" />
Step2. Android Studio→先進行環境設定,並加入第三方程式庫
compile 'com.google.code.gson:gson:2.2.4'
compile 'com.github.bumptech.glide:glide:3.7.0'
compile 'com.squareup.okhttp:okhttp:2.0.0'
|
詳細位置:設定→Plugins→搜尋"gsonformat"
使用介紹:能自動產生 對應到該頁面json格式 的類別
Step3. Android Studio→創造類別、Layout
詳細位置:Android Manifest
Class
|
AnimalBean (用來對應到網路上json格式用)
JsonAdapter (因為json沒有Adapter,所以我們要自己做一個Adapter)
|
Layout
|
Item.xml (用來顯示每筆資料用的item)
|
Step4. 啟用google的擴充功能,使得網頁上Json的格式更清晰
工具都準備好了 我們開始來實現這個功能吧
2.Layout的布局:
Layout:activity_main
|
<?xml version="1.0" encoding="utf-8"?> <LinearLayout 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" android:orientation="vertical" tools:context="com.example.andy.app_json.MainActivity"> <GridView android:layout_width="match_parent" android:layout_height="432dp" android:id="@+id/gridView" android:layout_gravity="center_horizontal" /> </LinearLayout> |
Layout:item
|
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="match_parent" android:layout_height="match_parent" android:weightSum="1"> <ImageView android:adjustViewBounds="true" android:src="@drawable/w1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/iv_item" /> </LinearLayout> |
3.完成對應網頁上json格式的類別:
詳細位置:Android Studio→java→Class→AnimailBean
使用介紹:利用外掛程式GsonFormat產生對應的類別,並存放在AnimalBean
簡單敘述:複製頁面上一筆資料,到android Studio中,
快捷鍵 alt+insert 開啟外掛程式,並貼入,完整包覆後,按確認
Step1. 複製網頁上其中一筆json的資料 快捷鍵 alt+insert 開啟外掛程式,並貼入,完整包覆後,按確認
Step2. 貼入外掛程式中,點選需要的選項 完成(通常我都會一次選,以防日後所需)
4.開始建立連線 Step1. 建立連線
詳細位置:Android Studio→java→Class→MainActivity
簡單敘述:利用OKHTTP所提供的程式碼 GET A URL下載
並創立一個新的執行緒在背後運作,防止在下載工程卡死在頁面
java:MainActivity
|
package com.example.andy.app_json; import android.content.Context; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.util.Log; import android.widget.GridView; import com.squareup.okhttp.OkHttpClient; import com.squareup.okhttp.Request; import com.squareup.okhttp.Response; import java.io.IOException; public class MainActivity extends AppCompatActivity { private Context context; private GridView gridView; private JsonAdapter adapter; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); Initial(); new RunWork().start(); } private void Initial() { context = this; gridView = (GridView) findViewById(R.id.gridView); //設定GridView的格式 gridView.setNumColumns(3); } //內部類別 RunWork 繼承一個執行緒 //RunWork 就是一個執行緒 public class RunWork extends Thread { // step1.這段程式碼由OKhttp所提供 // 分析 http 資料結構標準語法 // Url是再把網址放入 這時候會發送 request方法給伺服器 // 伺服器根據你要資料把資料用 response 回傳給你 String json; OkHttpClient client = new OkHttpClient(); String run(String url) throws IOException { Request request = new Request.Builder() .url(url) .build(); Response response = client.newCall(request).execute(); return response.body().string(); } //step3:創造出step2所要的工作內容 Runnable r = new Runnable() { @Override public void run() { adapter = new JsonAdapter(context,json); gridView.setAdapter(adapter); adapter.notifyDataSetChanged(); } }; //step2. // 運用OkHttp run的方法中,放入我們要讀取JSON的網址 // 放入後再另一個排程, runOnUiThread(r), // runOnUiThread 就好像為了要持續改變 環境UI的方法 // r就是工作的內容,這時候就要在new Runnable()出來。(上面) |
3.創建Adapter Step1. 建立連線
詳細位置:Android Studio→java→Class→AnimalAdapter
簡單敘述: 因為Json沒有 Adapter,所以我們要繼承一個BaseAdapter使用
java:AnimalAdapter
|
package com.example.andy.app_json; import android.content.Context; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.ImageView; import com.bumptech.glide.Glide; import com.bumptech.glide.load.engine.DiskCacheStrategy; import com.google.gson.Gson; public class JsonAdapter extends BaseAdapter{ //《依賴》把需要用的東西都先宣告起來 private Context context; private AnimalBean[] animalBeen; private ImageView m_iv_item; //建構子:記得創建方便使用 public JsonAdapter(Context context , String json) { this.context = context; animalBeen=new Gson().fromJson(json,AnimalBean[].class); } @Override //共有幾筆資料? public int getCount() { return animalBeen.length; } @Override //取得資料的位置 public Object getItem(int position) { return animalBeen[position]; } @Override //得到Item的ID public long getItemId(int position) { return position; } @Override //設定資料 public View getView(int position, View convertView, ViewGroup parent) { //因為item是一個xml,所以我們必須使用LayoutInflater(打氣筒), // 將這個item,inflate(打氣),然後膨脹展開這個頁面! View v = LayoutInflater.from(context).inflate(R.layout.item,parent,false); //膨脹以後我們就可以找到item的位置了 m_iv_item=(ImageView)v.findViewById(R.id.iv_item); //使用Log日誌,來判斷是否下載資料了 Test_Log_Data(); String url = animalBeen[position].getAlbum_file(); //第三方程式庫 Glide 由google提供 //load:網址 //placeholder :下載失敗時要顯是什麼圖 //diskCacheStrategy :是否要存取以下載的 //into :顯示在哪邊? Glide.with(context) .load(url) .placeholder(R.drawable.w1) .diskCacheStrategy(DiskCacheStrategy.RESULT) .into(m_iv_item); return v; } private void Test_Log_Data(){ for (int i=0; i<=animalBeen.length-1;i++) { Log.d("tag", "-------------" +(i+1) +"-------------"); Log.d("tag", animalBeen[i].getAlbum_name().toString()); Log.d("tag", animalBeen[i].getAnimal_colour().toString()); Log.d("tag", animalBeen[i].getAnimal_place().toString()); Log.d("tag", animalBeen[i].getAlbum_file().toString()); } } } |
Step2.透過日誌來檢查資料的內容
我們來看看成果吧
相信大家看了以後才會知道RecyclerView的好用之處 對吧?
不然每次都要再找一次View,View都不會重複再利用 ,
沒有留言:
張貼留言