本文将讲解如何通过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数学函数表达式转化为图片形式,希望大家喜欢。
本文向大家介绍Lua学习笔记之表和函数,包括了Lua学习笔记之表和函数的使用技巧和注意事项,需要的朋友参考一下 Lua中的表和函数比较重要,正是因为二者的结合才完成了很多很多的功能,Lua才变得如此的强大,所以有必要仔细的学习一下表和函数。如下的代码体现了表的用法。 接下来学习Lua函数的用法,函数涉及的东西比较多,不着急,慢慢来。
本文向大家介绍AngularJS基础学习笔记之表达式,包括了AngularJS基础学习笔记之表达式的使用技巧和注意事项,需要的朋友参考一下 AngularJS通过表达式将数据绑定到HTML。 AngularJS表达式 AngularJS表达式写在双大括号中:{{ 表达式语句 }}。 AngularJS表达式绑定数据到HTML的方式与ng-bind指令的方式相同。 AngularJS会准
本文向大家介绍JavaScript学习笔记之JS函数,包括了JavaScript学习笔记之JS函数的使用技巧和注意事项,需要的朋友参考一下 函数就是包裹在花括号中的代码块,前面使用了关键词function: 函数参数 函数的参数可以任意多个,不用声明变量类型,只用给出变量名: 函数返回值 在函数中使用return语句,函数会停止执行,返回调用它的地方。 函数的返回值也不用声明类型,直接
本文向大家介绍javascript学习笔记之函数定义,包括了javascript学习笔记之函数定义的使用技巧和注意事项,需要的朋友参考一下 函数声明式 声明式的函数并不会马上执行,需要我们调用才会执行:funname(); * 分号是用来分隔可执行JavaScript语句,由于函数声明不是一个可执行语句,所以不以分号结束。 函数表达式 函数表达式定义的函数,实际上也是一个匿名函数(这个函数没有名
本文向大家介绍Shell正则表达式学习笔记,包括了Shell正则表达式学习笔记的使用技巧和注意事项,需要的朋友参考一下 正规表示法(或称为常规表示法)是透过一些特殊字符的排列,用以搜寻/取代/删除一列或多列文字字符串, 简单的说,正规表示法就是用在字符串的处理上面的一项『表示式』。正规表示法并不是一个工具程序, 而是一个字符串处理的标准依据,如果您想要以正规表示法的方式处理字符串,就得要使用支持正
本文向大家介绍php正则表达式学习笔记,包括了php正则表达式学习笔记的使用技巧和注意事项,需要的朋友参考一下 php正则表达式学习笔记分享: 1.创建正则表达式 $regex = '/\d/i'; 与JavaScript中的第一个方式有点像,只是这里的话是个字符串。 2.正则表达式中的特殊字符 特殊字符有: . \ + * ? [ ^ ] $ ( ) { } = ! < > | : - 3