使用Retrofit+Rxjava+MPAndroid來顯示氣溫曲線圖

使用Retrofit+Rxjava+MPAndroid來顯示氣溫曲線圖

這里是抓包抓來API接口:http://aider.meizu.com/app/weather/listWeather?cityIds=101020600

先看一下最終的結果:

好吧,下面就正式開始項目吧~

1.導入第三方庫

//okhttp
compile 'com.squareup.okhttp3:okhttp:3.6.0'
compile 'com.squareup.okio:okio:1.11.0'
compile 
//butterknife
compile 'com.jakewharton:butterknife:8.5.1'
annotationProcessor 'com.jakewharton:butterknife-compiler:8.5.1'
//Rxjava
compile 'io.reactivex:rxjava:1.1.3'
compile 'io.reactivex:rxandroid:1.1.0'
//Retrofit
compile 'com.squareup.retrofit2:retrofit:2.0.2'
compile 'com.squareup.retrofit2:converter-gson:2.0.2'
compile 'com.squareup.retrofit2:converter-scalars:2.0.2'
compile 'com.squareup.retrofit2:adapter-rxjava:2.0.2'
//gson
compile files('libs/gson-2.6.2.jar')
//MPAndroid
compile 'com.github.PhilJay:MPAndroidChart:v3.0.1'

2.初始化設置

  • 布局文件

    <?xml version="1.0" encoding="utf-8"?>
    <android.support.v4.widget.NestedScrollView
        xmlns:android="http://schemas.android.com/apk/res/andro    id"
        xmlns:tools="http://schemas.android.com/tools"
        android:id="@+id/activity_main"
        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.skkk.okhttp3stydy.MainActivity">
    
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
            <EditText
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:inputType="textPersonName"
                android:text="Demo"
                android:gravity="center"
                android:ems="10"
                android:id="@+id/editText"
                />
            <Button
                android:text="下載圖片"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:id="@+id/button2"
                />
            <com.github.mikephil.charting.charts.LineChart
                android:id="@+id/lc_weather_future"
                android:layout_width="match_parent"
                android:layout_height="300dp"
                ></com.github.mikephil.charting.charts.LineChar    t>
    
            <com.github.mikephil.charting.charts.LineChart
                android:id="@+id/lc_weather_detail"
               
        </LinearLayout>
    </android.support.v4.widget.NestedScrollView>
    

很簡單,一個標題,一個按鈕,一個折線圖

  • 然后我們設置一個Gson的接收類

    ...(此處省略)

  • Retrofit的接口文件

    public interface WeatherInterface {
        //http://aider.meizu.com/app/weather/listWeather?cityId    s=101010100
        @GET("app/weather/listWeather")
        Observable<WeatherGson>     getWeather(@Query("cityIds")String cityIds);
    }
    
  • 初始化網絡請求

    String baseUrl = "http://aider.meizu.com/";
        retrofit = new Retrofit.Builder()
                .addConverterFactory(GsonConverterFactory.creat    e())
                .addCallAdapterFactory(RxJavaCallAdapterFactory    .create())
                .baseUrl(baseUrl)
                .build();
    WeatherInterfaceweatherInterface=retrofit.create(WeatherInt    erface.lass)
    

3.邏輯編寫

  • 獲取被監聽者

    Observable<WeatherGson> weatherRequest     =weatherInterface.getWeather("101020600");
    
  • 網絡請求

    weatherRequest.subscribeOn(Schedulers.newThread())
    
  • 數據處理(將獲取到的Gson數據轉化為MPAndroid需求的數據)

    這個demo中我們僅僅需要數據中的未來六天日夜間氣溫變化數據就

    1.獲取目標數據

    //獲取未來天氣
    WeatherDetailsInfo weatherDetailsInfo =     weatherGson.getValue().get(0).getWeatherDetailsInfo();
    List<Weather> weathers     =weatherGson.getValue().get(0).getWeathers();
    

    2.轉化為MPAndroid需求值List<Entry>

    List<Entry> entryListD = new ArrayList<Entry>();
    List<Entry> entryListN = new ArrayList<Entry>();
    
    for (int i = 0; i < weathers.size(); i++) {
        //將天氣對象轉化為圖標中的數據元
        entryListD.add(new Entry(i, Float.valueOf(weathers.get(i).getTempDayC())));
        entryListN.add(new Entry(i, Float.valueOf(weathers.get(i).getTempNightC())));
        //將星期幾添加到數組中
        days[i] = weathers.get(i).getWeek();
    }
    

    3.這里還需要設置一下chart中的橫軸坐標格式器

    //設置X軸的格式
    xFormatter = new IAxisValueFormatter() {
    @Override
    public String getFormattedValue(float value, AxisBase axis) {
       return days[(int) value];
        }
    };
    

    4.設置折線圖數據并返回

    List<LineDataSet> lineDataSetList = new ArrayList<LineDataSet>();
    lineDataSetList.add(new LineDataSet(entryListD, getString(R.string.future_weather_day)));
    lineDataSetList.add(new LineDataSet(entryListN, getString
    //返回直線圖數據對象
    return lineDataSetList;
    

4.監聽者主線程更新UI

  • 接收數據

    Observable<WeatherGson> weatherRequest = weatherInterface.getWeather("101020600");
    weatherRequest.subscribeOn(Schedulers.newThread())
            .subscribeOn(Schedulers.io())
            .map(new Func1<WeatherGson, List<LineDataSet>>() {
                @Override
                public List<LineDataSet> call(WeatherGson weatherGson) {
                    ...
                    //返回直線圖數據對象
                    return lineDataSetList;
                }
            })
            .observeOn(AndroidSchedulers.mainThread())
            .subscribe(new Subscriber<List<LineDataSet>>() {
                @Override
                public void onCompleted() {
                    Toast.makeText(MainActivity.this, "完成網絡!", Toast.LENGTH_SHORT).show();
                }
                @Override
                public void onError(Throwable e) {
                    Toast.makeText(MainActivity.this, "網絡錯誤!", Toast.LENGTH_SHORT).show();
                }
                @Override
                public void onNext(List<LineDataSet> lineDataSetList) {
                    //顯示圖表
                    showChart(lineDataSetList);
                }
            });
    
  • 更新chart

    private void showChart(List<LineDataSet> dataSetList) {
        //設置日間溫度曲線
        dataSetList.get(0).setMode(LineDataSet.Mode.HORIZONTAL_BEZIER);
        dataSetList.get(0).setColor(ContextCompat.getColor(this,R.color.colorAccent));
        dataSetList.get(0).setDrawCircleHole(false);
        dataSetList.get(0).setDrawCircles(false);
        
        //設置晚間溫度曲線
        dataSetList.get(1).setMode(LineDataSet.Mode.HORIZONTAL_BEZIER);
        dataSetList.get(1).setColor(ContextCompat.getColor(this,R.color.colorPrimaryDark));
        dataSetList.get(1).setDrawCircleHole(false);
        dataSetList.get(1).setDrawCircles(false);
        
        //設置數據
        LineData dayLineData = new LineData();
        LineData infoLineData = new LineData();
        for (int i = 0; i < dataSetList.size(); i++) {
            dayLineData.addDataSet(dataSetList.get(i));
        }
        dayLineData.setValueFormatter(vFormatter);
        dayLineData.setValueTextSize(8f);
        dayLineData.setValueTextColor(Color.BLACK);
    
        //設置X軸
        XAxis dayXAxis = mDayLineChart.getXAxis();
        dayXAxis.setDrawGridLines(false);
        dayXAxis.setPosition(XAxis.XAxisPosition.BOTTOM);
        dayXAxis.setValueFormatter(xFormatter);
        //設置Y軸right
        YAxis axisRight = mDayLineChart.getAxisRight();
        axisRight.setDrawAxisLine(false);
        axisRight.setDrawGridLines(false);
        axisRight.setDrawLabels(false);
        //設置Y軸left
        YAxis axisLeft = mDayLineChart.getAxisLeft();
        axisLeft.setDrawAxisLine(false);
        axisLeft.setDrawGridLines(false);
        axisLeft.setDrawLabels(false);
        //設置chart
        Description description = new Description();
        description.setText("氣溫預測圖");
        description.setTextSize(15f);
        description.setTextColor(getResources().getColor(R.color.colorPrimaryDark));
        mDayLineChart.setDescription(description);
        mDayLineChart.setData(dayLineData);
        mDayLineChart.setMarker(mIMarker);
        mDayLineChart.invalidate();
    

5.查看源碼

一起進步吧,少年~
點擊這里查看源碼

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,546評論 6 533
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,570評論 3 418
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,505評論 0 376
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,017評論 1 313
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,786評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,219評論 1 324
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,287評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,438評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,971評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,796評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,995評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,540評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,230評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,662評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,918評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,697評論 3 392
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,991評論 2 374

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,662評論 25 708
  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,785評論 18 139
  • afinalAfinal是一個android的ioc,orm框架 https://github.com/yangf...
    passiontim閱讀 15,467評論 2 45
  • 題外:#睡前語#是我和四歲寶寶睡前的對話記錄,希望通過這個,記錄寶寶成長點滴,探尋小朋友的心理世界。 2月22日...
    佩蕓說閱讀 764評論 0 0
  • 如果浪費時間是一種犯罪的話 那我活到現在 已經都不知道被槍斃多少次了吧 今天去看了《一條狗的使命》 本來想下午3點...
    阿驕要堅持啊閱讀 260評論 0 1