Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> 關於Android編程 >> Android開發學習筆記之通過API接口將LaTex數學函數表達式轉化為圖片形式

Android開發學習筆記之通過API接口將LaTex數學函數表達式轉化為圖片形式

編輯:關於Android編程

本文將講解如何通過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內):

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表達式是嚴格合法的(比如所有單元都用{}括起來)。

Screenshot_2015-11-17-22-21-34 Screenshot_2015-11-17-22-23-00

完整代碼:

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
    }
  }
}

以上內容是小編給大家介紹的關於Android開發學習筆記之通過API接口將LaTex數學函數表達式轉化為圖片形式,希望大家喜歡。

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