首页 > 系统 > Android > 正文

Android开发学习笔记之通过API接口将LaTex数学函数表达式转化为图片形式

2019-10-24 20:34:36
字体:
来源:转载
供稿:网友

这篇文章主要介绍了Android开发学习笔记之通过API接口将LaTex数学函数表达式转化为图片形式的相关资料,需要的朋友可以参考下

本文将讲解如何通过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单击时执行。

首先要添加网络访问权限:

 

 
  1. <uses-permission android:name="android.permission.INTERNET"/> 
  2. String PicUrlCogs = "http://latex.codecogs.com/gif.latex?"
  3. Url = new URL(PicUrlCogs + editText.getText().toString().replace(" ","")); 
  4. new MyDownloadTask().execute(); // 执行Http请求 
  5. while(!finishFlag) {} // 等待数据接收完毕 
  6. imageView.setImageBitmap(pngBM); // 显示图片 
  7. finishFlag = false// 标识回位 

2、发送Http请求

这里,我们发送Http请求采取异步线程的方式。首先,获取上一步得到的URL地址,然后建立一个Http链接,然后将返回的数据输入到输入流中,最后将输入流进行解码为图片并显示在ImageView中。

 

 
  1. protected Void doInBackground(Void... params) { 
  2. try { 
  3. URL picUrl = Url; // 获取URL地址 
  4. HttpURLConnection conn = (HttpURLConnection) picUrl.openConnection(); 
  5. // conn.setConnectTimeout(1000); // 建立连接 
  6. // conn.setReadTimeout(1000); 
  7. conn.connect(); // 打开连接 
  8. if (conn.getResponseCode() == 200) { // 连接成功,返回数据 
  9. InputStream ins = conn.getInputStream(); // 将数据输入到数据流中 
  10. pngBM = BitmapFactory.decodeStream(picUrl.openStream()); // 解析数据流 
  11. finishFlag = true// 数据传输完毕标识 
  12. ins.close(); // 关闭数据流 
  13. catch (Exception e) { 
  14. e.printStackTrace(); 
  15. return null

完整的MyDownloadTask类代码(在MainActivity内):

3、显示图片

在上一步建立的网络连接类,然后在Button单击事件内实例化一个此类来接收数据,然后将返回的数据显示在ImageView内。

 

  1. btnPreview.setOnClickListener(new View.OnClickListener() { 
  2. @Override 
  3. public void onClick(View v) { 
  4. try { 
  5. Url = new URL(PicUrlCogs + editText.getText().toString().replace(" ","")); // 转换字符串 
  6. new MyDownloadTask().execute(); // 执行Http请求 
  7. while(!finishFlag) {} // 等待数据接收完毕 
  8. imageView.setImageBitmap(pngBM); // 显示图片 
  9. finishFlag = false// 标识回位 
  10. catch (Exception e) { 
  11. e.printStackTrace(); 
  12. }); 

这样,我们在输入LaTeX公式之后,单击PREVIEW按钮,就会在ImageView上显示对应的图片了。由于本文只讨论如何进行转化,并没有对图片进行任何优化处理,可能看起来比较小。另外,如果采取去空格转化URL的方法,尽量保证LaTeX表达式是严格合法的(比如所有单元都用{}括起来)。

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

完整代码:

 

 
  1. import android.app.Activity; 
  2. import android.graphics.Bitmap; 
  3. import android.graphics.BitmapFactory; 
  4. import android.os.AsyncTask; 
  5. import android.os.Bundle; 
  6. import android.view.View; 
  7. import android.widget.Button; 
  8. import android.widget.EditText; 
  9. import android.widget.ImageView; 
  10. import java.io.InputStream; 
  11. import java.net.HttpURLConnection; 
  12. import java.net.URL; 
  13. public class MainActivity extends Activity { 
  14. private String PicUrlGoogle = "http://chart.apis.google.com/chart?cht=tx&chl="
  15. private String PicUrlCogs = "http://latex.codecogs.com/gif.latex?"
  16. private Button btnPreview; 
  17. private EditText editText; 
  18. private ImageView imageView; 
  19. private Bitmap pngBM; 
  20. private URL Url; 
  21. private boolean finishFlag = false
  22. @Override 
  23. protected void onCreate(Bundle savedInstanceState) { 
  24. super.onCreate(savedInstanceState); 
  25. setContentView(R.layout.activity_main); 
  26. btnPreview = (Button) findViewById(R.id.btnPreview); 
  27. imageView = (ImageView) findViewById(R.id.imageView); 
  28. editText = (EditText) findViewById(R.id.editText); 
  29. btnPreview.setOnClickListener(new View.OnClickListener() { 
  30. @Override 
  31. public void onClick(View v) { 
  32. try { 
  33. Url = new URL(PicUrlCogs + editText.getText().toString().replace(" ","")); // 转换字符串 
  34. new MyDownloadTask().execute(); // 执行Http请求 
  35. while(!finishFlag) {} // 等待数据接收完毕 
  36. imageView.setImageBitmap(pngBM); // 显示图片 
  37. finishFlag = false// 标识回位 
  38. catch (Exception e) { 
  39. e.printStackTrace(); 
  40. }); 
  41. @Override 
  42. public void onDestroy() { 
  43. super.onDestroy(); 
  44. class MyDownloadTask extends AsyncTask<Void, Void, Void> { 
  45. protected void onPreExecute() { 
  46. //display progress dialog. 
  47. protected Void doInBackground(Void... params) { 
  48. try { 
  49. URL picUrl = Url; // 获取URL地址 
  50. HttpURLConnection conn = (HttpURLConnection) picUrl.openConnection(); 
  51. // conn.setConnectTimeout(1000); // 建立连接 
  52. // conn.setReadTimeout(1000); 
  53. conn.connect(); // 打开连接 
  54. if (conn.getResponseCode() == 200) { // 连接成功,返回数据 
  55. InputStream ins = conn.getInputStream(); // 将数据输入到数据流中 
  56. pngBM = BitmapFactory.decodeStream(picUrl.openStream()); // 解析数据流 
  57. finishFlag = true// 数据传输完毕标识 
  58. ins.close(); // 关闭数据流 
  59. catch (Exception e) { 
  60. e.printStackTrace(); 
  61. return null
  62. protected void onPostExecute(Void result) { 
  63. // dismiss progress dialog and update ui 

以上内容是小编给大家介绍的关于Android开发学习笔记之通过API接口将LaTex数学函数表达式转化为图片形式,希望大家喜欢。


注:相关教程知识阅读请移步到Android开发频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表