本文将讲解如何通过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”就显示一个希腊字母。所以我们可以在其后加上我们希望转换的公式即可。但是需要注意的是,网络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
}
} }

Android开发手记(29) 基于Http的LaTeX数学公式转换器的更多相关文章

  1. C#开发基于Http的LaTeX数学公式转换器

    本文将讲解如何通过codecogs.com和Google.com提供的API接口来将LaTeX数学函数表达式转化为图片形式.具体思路如下: (1)通过TextBox获取用户输入的LaTeX数学表达式, ...

  2. Android开发自学笔记(基于Android Studio1.3.1)—1.环境搭建(转)

    一.引言    本套学习笔记的开发环境是Windows 10 专业版和Android Studio 的最新版1.3.1. Android Studio 是一个Android开发环境,基于Intelli ...

  3. Android 开发手记一NDK编程实例

    在Android上,应用程序的开发,大部分基于Java语言来实现.要使用c或是c++的程序或库,就需要使用NDK来实现.NDK是Native Development Kit的简称.它是一个工具集,集成 ...

  4. Android开发手记(28) Handler和Looper

    Android的消息处理有三个核心类:Looper,Handler和Message.其实还有一个Message Queue(消息队列),但是MQ被封装到Looper里面了,我们不会直接与MQ打交道.平 ...

  5. Android开发手记(24) Log的使用及颜色的更改

    在程序开发过程中,LOG是广泛使用的用来记录程序执行过程的机制,它既可以用于程序调试,也可以用于产品运营中的事件记录.在Android系统中,提供了简单.便利的LOG机制,开发人员可以方便地使用.本文 ...

  6. Android开发手记(19) 数据存储四 ContentProvider

    转载自:http://www.cnblogs.com/devinzhang/archive/2012/01/20/2327863.html Android为数据存储提供了五种方式: 1.SharedP ...

  7. Android开发手记(22) 传感器的使用

    Android的传感器主要包括八大传感器,他们分别是:加速度传感器(accelerometer).陀螺仪(gyroscope).方向传感器(orientation).磁力传感器(magnetic fi ...

  8. Android开发手记(18) 数据存储三 SQLite存储数据

    Android为数据存储提供了五种方式: 1.SharedPreferences 2.文件存储 3.SQLite数据库 4.ContentProvider 5.网络存储 SQLite 是以嵌入式为目的 ...

  9. Android开发手记(17) 数据存储二 文件存储数据

    Android为数据存储提供了五种方式: 1.SharedPreferences 2.文件存储 3.SQLite数据库 4.ContentProvider 5.网络存储 本文主要介绍如何使用文件来存储 ...

随机推荐

  1. Install php-mcrypt on CentOS 6

    http://stackoverflow.com/questions/17109818/install-php-mcrypt-on-centos-6

  2. 【POJ2778】AC自动机+矩阵乘法

    DNA Sequence Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 14758 Accepted: 5716 Descrip ...

  3. Silicon Labs电容式触摸感应按键技术原理及应用

    市场上的消费电子产品已经开始逐步采用触摸感应按键,以取代传统的机械式按键.针对此趋势,Silicon Labs公司推出了内置微控制器(MCU)功能的电容式触摸感应按键(Capacitive Touch ...

  4. Apache OFBiz

    Apache OFBiz® Apache OFBiz offers a great deal of functionality, including: advanced e-commerce cata ...

  5. 14.6.7 Configuring the Number of Background InnoDB IO Threads 配置InnoDB IO Threads的数量

    14.6.7 Configuring the Number of Background InnoDB IO Threads 配置InnoDB IO Threads的数量 InnoDB 使用后台线程来服 ...

  6. bzoj2165

    类似于bzoj1706,考虑到楼层是等价的我们令f[p,i,j]为用了2^p次电梯,从房间i到j最多上升了多少层然后从2^p很容易推到2^(p+1),类似于floyd的转移即可下面我们要用最小的电梯次 ...

  7. WordPress Download Monitor插件跨站脚本漏洞

    漏洞名称: WordPress Download Monitor插件跨站脚本漏洞 CNNVD编号: CNNVD-201308-139 发布时间: 2013-08-14 更新时间: 2013-08-14 ...

  8. Light OJ 1032 - Fast Bit Calculations(数位DP)

    题目大意: 一个数字把他看成二进制数字,数字里又会一些相邻的1,问从0到n至间所有相邻1的总和是多少?   分解成2进制数字,然后数位DP就行了.   ======================== ...

  9. 哈希表(Hashtable)简述

    一,哈希表(Hashtable)简述 在.NET Framework中,Hashtable是System.Collections命名空间提供的一个容器,用于处理和表现类似keyvalue的键值对,其中 ...

  10. Unity3d HDR和Bloom效果(高动态范围图像和泛光)

    文章开始先放两组效果,文章结尾再放两组效果本文测试场景资源来自浅墨大神,shader效果为本文效果 HDR 人们有限的视觉系统,只支持16.7百万的颜色,超出这个范围的颜色就不能显示了bmp或jprg ...