Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發 >> 關於android開發 >> Android開發手記(29) 基於Http的LaTeX數學公式轉換器,androidlatex

Android開發手記(29) 基於Http的LaTeX數學公式轉換器,androidlatex

編輯:關於android開發

Android開發手記(29) 基於Http的LaTeX數學公式轉換器,androidlatex


      本文將講解如何通過codecogs.com和Google.com提供的API接口來將LaTeX數學函數表達式轉化為圖片形式。具體思路如下:

      (1)通過EditText獲取用戶輸入的LaTeX數學表達式,然後對表達式格式化使之便於網絡傳輸。

      (2)將格式化之後的字符串,通過Http請求發送至codecogs.com或者Google.com。

      (3)獲取網站返回的數據流,將其轉化為圖片,並顯示在ImageView上。

具體過程為:

1、獲取並格式化LaTeX數學表達式

      首先,我們在這個網站輸入LaTeX數學公式然後返回圖片時,即“http://latex.codecogs.com/gif.latex?“後面跟上我們輸入的公式內容。比如”http://latex.codecogs.com/gif.latex?\alpha”就顯示一個希臘字母\alpha。所以我們可以在其後加上我們希望轉換的公式即可。但是需要注意的是,網絡URL中的空格有時候會自動轉化為加號”+“。所以,我們在傳輸的時候需要將空格去掉。或者將其轉換為”%20“。Button單擊時執行。

      首先要添加網絡訪問權限:

 <uses-permission android:name="android.permission.INTERNET"/>
String PicUrlCogs = "http://latex.codecogs.com/gif.latex?";
Url = new URL(PicUrlCogs + editText.getText().toString().replace(" ",""));
new MyDownloadTask().execute();                 // 執行Http請求
while(!finishFlag) {}                           // 等待數據接收完畢
imageView.setImageBitmap(pngBM);                // 顯示圖片
finishFlag = false;                             // 標識回位

2、發送Http請求

      這裡,我們發送Http請求采取異步線程的方式。首先,獲取上一步得到的URL地址,然後建立一個Http鏈接,然後將返回的數據輸入到輸入流中,最後將輸入流進行解碼為圖片並顯示在ImageView中。

      protected Void doInBackground(Void... params) {
            try {
                URL picUrl = Url;                            // 獲取URL地址
                  HttpURLConnection conn = (HttpURLConnection) picUrl.openConnection();
//                conn.setConnectTimeout(1000);              // 建立連接
//                conn.setReadTimeout(1000);
                conn.connect();                              // 打開連接
                if (conn.getResponseCode() == 200) {         // 連接成功,返回數據
                    InputStream ins = conn.getInputStream(); // 將數據輸入到數據流中
                    pngBM = BitmapFactory.decodeStream(picUrl.openStream()); // 解析數據流
                    finishFlag = true;                       // 數據傳輸完畢標識
                    ins.close();                             // 關閉數據流
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
            return null;
        }

完整的MyDownloadTask類代碼(在MainActivity內):

class MyDownloadTask extends AsyncTask<Void, Void, Void> {

        protected void onPreExecute() {
            //display progress dialog.

        }

        protected Void doInBackground(Void... params) {
            try {
                URL picUrl = Url;                            // 獲取URL地址
                HttpURLConnection conn = (HttpURLConnection) picUrl.openConnection();
//                conn.setConnectTimeout(1000);              // 建立連接
//                conn.setReadTimeout(1000);
                conn.connect();                              // 打開連接
                if (conn.getResponseCode() == 200) {         // 連接成功,返回數據
                    InputStream ins = conn.getInputStream(); // 將數據輸入到數據流中
                    pngBM = BitmapFactory.decodeStream(picUrl.openStream()); // 解析數據流
                    finishFlag = true;                       // 數據傳輸完畢標識
                    ins.close();                             // 關閉數據流
                }
            } catch (Exception e) {
                e.printStackTrace();
            }
            return null;
        }

        protected void onPostExecute(Void result) {
            // dismiss progress dialog and update ui
        }
    }

3、顯示圖片

       在上一步建立的網絡連接類,然後在Button單擊事件內實例化一個此類來接收數據,然後將返回的數據顯示在ImageView內。

 btnPreview.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                try {
                    Url = new URL(PicUrlCogs + editText.getText().toString().replace(" ","")); // 轉換字符串
                    new MyDownloadTask().execute();                 // 執行Http請求
                    while(!finishFlag) {}                           // 等待數據接收完畢
                    imageView.setImageBitmap(pngBM);                // 顯示圖片
                    finishFlag = false;                             // 標識回位

                } catch (Exception e) {
                    e.printStackTrace();
                }

            }
        });

        這樣,我們在輸入LaTeX公式之後,單擊PREVIEW按鈕,就會在ImageView上顯示對應的圖片了。由於本文只討論如何進行轉化,並沒有對圖片進行任何優化處理,可能看起來比較小。另外,如果采取去空格轉化URL的方法,盡量保證LaTeX表達式是嚴格合法的(比如所有單元都用{}括起來)。

import android.app.Activity; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.os.AsyncTask; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.EditText; import android.widget.ImageView; import java.io.InputStream; import java.net.HttpURLConnection; import java.net.URL; public class MainActivity extends Activity { private String PicUrlGoogle = "http://chart.apis.google.com/chart?cht=tx&chl="; private String PicUrlCogs = "http://latex.codecogs.com/gif.latex?"; private Button btnPreview; private EditText editText; private ImageView imageView; private Bitmap pngBM; private URL Url; private boolean finishFlag = false; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btnPreview = (Button) findViewById(R.id.btnPreview); imageView = (ImageView) findViewById(R.id.imageView); editText = (EditText) findViewById(R.id.editText); btnPreview.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { try { Url = new URL(PicUrlCogs + editText.getText().toString().replace(" ","")); // 轉換字符串 new MyDownloadTask().execute(); // 執行Http請求 while(!finishFlag) {} // 等待數據接收完畢 imageView.setImageBitmap(pngBM); // 顯示圖片 finishFlag = false; // 標識回位 } catch (Exception e) { e.printStackTrace(); } } }); } @Override public void onDestroy() { super.onDestroy(); } class MyDownloadTask extends AsyncTask<Void, Void, Void> { protected void onPreExecute() { //display progress dialog. } protected Void doInBackground(Void... params) { try { URL picUrl = Url; // 獲取URL地址 HttpURLConnection conn = (HttpURLConnection) picUrl.openConnection(); // conn.setConnectTimeout(1000); // 建立連接 // conn.setReadTimeout(1000); conn.connect(); // 打開連接 if (conn.getResponseCode() == 200) { // 連接成功,返回數據 InputStream ins = conn.getInputStream(); // 將數據輸入到數據流中 pngBM = BitmapFactory.decodeStream(picUrl.openStream()); // 解析數據流 finishFlag = true; // 數據傳輸完畢標識 ins.close(); // 關閉數據流 } } catch (Exception e) { e.printStackTrace(); } return null; } protected void onPostExecute(Void result) { // dismiss progress dialog and update ui } } }

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved