Activity 中的代码,我只贴出重要的事件部分代码
public void doPhoto(View view) { destoryBimap(); String state = Environment.getExternalStorageState(); if (state.equals(Environment.MEDIA_MOUNTED)) { Intent intent = new Intent("android.media.action.IMAGE_CAPTURE"); startActivityForResult(intent, 1); } else { Toast.makeText(MainActivity.this, "没有SD卡", Toast.LENGTH_LONG).show(); } } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { Uri uri = data.getData(); if (uri != null) { this.photo = BitmapFactory.decodeFile(uri.getPath()); } if (this.photo == null) { Bundle bundle = data.getExtras(); if (bundle != null) { this.photo = (Bitmap) bundle.get("data"); } else { Toast.makeText(MainActivity.this, "拍照失败", Toast.LENGTH_LONG).show(); return; } } FileOutputStream fileOutputStream = null; try { // 获取 SD 卡根目录 String saveDir = Environment.getExternalStorageDirectory() + "/meitian_photos"; // 新建目录 File dir = new File(saveDir); if (! dir.exists()) dir.mkdir(); // 生成文件名 SimpleDateFormat t = new SimpleDateFormat("yyyyMMddssSSS"); String filename = "MT" + (t.format(new Date())) + ".jpg"; // 新建文件 File file = new File(saveDir, filename); // 打开文件输出流 fileOutputStream = new FileOutputStream(file); // 生成图片文件 this.photo.compress(Bitmap.CompressFormat.JPEG, 100, fileOutputStream); // 相片的完整路径 this.picPath = file.getPath(); ImageView imageView = (ImageView) findViewById(R.id.showPhoto); imageView.setImageBitmap(this.photo); } catch (Exception e) { e.printStackTrace(); } finally { if (fileOutputStream != null) { try { fileOutputStream.close(); } catch (Exception e) { e.printStackTrace(); } } } } /** * 销毁图片文件 */ private void destoryBimap() { if (photo != null && ! photo.isRecycled()) { photo.recycle(); photo = null; } }
Layout 布局页面
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <ScrollView android:layout_width="fill_parent" android:layout_height="fill_parent" > <LinearLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <Button android:id="@+id/doPhoto" android:layout_width="fill_parent" android:layout_height="wrap_content" android:padding="10dp" android:layout_marginBottom="10dp" android:text="拍照" android:onClick="doPhoto" /> <TextView android:id="@+id/showContent" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_marginBottom="10dp" /> <ImageView android:id="@+id/showPhoto" android:layout_width="fill_parent" android:layout_height="250dp" android:scaleType="centerCrop" android:src="@drawable/add" android:layout_marginBottom="10dp" /> </LinearLayout> </ScrollView> </LinearLayout>
其中的上传工具类我们下面一起来看:
Android 发送HTTP GET POST 请求以及通过 MultipartEntityBuilder 上传文件
全部使用新的方式 MultipartEntityBuilder 来处理了。
httpmime-4.3.2.jar
httpcore-4.3.1.jar
下载地址:http://hc.apache.org/downloads.cgi
有些镜像貌似打不开,页面上可以可以选择国内的 .cn 后缀的域名镜像服务器来下载
直接上代码了:
ZHttpRequset.java
package com.ai9475.util; import org.apache.http.HttpEntity; import org.apache.http.HttpResponse; import org.apache.http.HttpStatus; import org.apache.http.client.HttpClient; import org.apache.http.client.methods.HttpGet; import org.apache.http.client.methods.HttpPost; import org.apache.http.client.methods.HttpRequestBase; import org.apache.http.entity.mime.HttpMultipartMode; import org.apache.http.entity.mime.MultipartEntityBuilder; import org.apache.http.impl.client.DefaultHttpClient; import org.apache.http.params.BasicHttpParams; import org.apache.http.params.HttpConnectionParams; import org.apache.http.params.HttpParams; import org.apache.http.protocol.HTTP; import java.io.ByteArrayOutputStream; import java.io.IOException; import java.io.InputStream; import java.nio.charset.Charset; /** * Created by ZHOUZ on 14-2-3. */ public class ZHttpRequest { public final String HTTP_GET = "GET"; public final String HTTP_POST = "POST"; /** * 当前请求的 URL */ protected String url = ""; /** * HTTP 请求的类型 */ protected String requsetType = HTTP_GET; /** * 连接请求的超时时间 */ protected int connectionTimeout = 5000; /** * 读取远程数据的超时时间 */ protected int soTimeout = 10000; /** * 服务端返回的状态码 */ protected int statusCode = -1; /** * 当前链接的字符编码 */ protected String charset = HTTP.UTF_8; /** * HTTP GET 请求管理器 */ protected HttpRequestBase httpRequest= null; /** * HTTP 请求的配置参数 */ protected HttpParams httpParameters= null; /** * HTTP 请求响应 */ protected HttpResponse httpResponse= null; /** * HTTP 客户端连接管理器 */ protected HttpClient httpClient= null; /** * HTTP POST 方式发送多段数据管理器 */ protected MultipartEntityBuilder multipartEntityBuilder= null; /** * 绑定 HTTP 请求的事件监听器 */ protected OnHttpRequestListener onHttpRequestListener = null; public ZHttpRequest(){} public ZHttpRequest(OnHttpRequestListener listener) { this.setOnHttpRequestListener(listener); } /** * 设置当前请求的链接 * * @param url * @return */ public ZHttpRequest setUrl(String url) { this.url = url; return this; } /** * 设置连接超时时间 * * @param timeout 单位(毫秒),默认 5000 * @return */ public ZHttpRequest setConnectionTimeout(int timeout) { this.connectionTimeout = timeout; return this; } /** * 设置 socket 读取超时时间 * * @param timeout 单位(毫秒),默认 10000 * @return */ public ZHttpRequest setSoTimeout(int timeout) { this.soTimeout = timeout; return this; } /** * 设置获取内容的编码格式 * * @param charset 默认为 UTF-8 * @return */ public ZHttpRequest setCharset(String charset) { this.charset = charset; return this; } /** * 获取当前 HTTP 请求的类型 * * @return */ public String getRequestType() { return this.requsetType; } /** * 判断当前是否 HTTP GET 请求 * * @return */ public boolean isGet() { return this.requsetType == HTTP_GET; } /** * 判断当前是否 HTTP POST 请求 * * @return */ public boolean isPost() { return this.requsetType == HTTP_POST; } /** * 获取 HTTP 请求响应信息 * * @return */ public HttpResponse getHttpResponse() { return this.httpResponse; } /** * 获取 HTTP 客户端连接管理器 * * @return */ public HttpClient getHttpClient() { return this.httpClient; } /** * 添加一条 HTTP 请求的 header 信息 * * @param name * @param value * @return */ public ZHttpRequest addHeader(String name, String value) { this.httpRequest.addHeader(name, value); return this; } /** * 获取 HTTP GET 控制器 * * @return */ public HttpGet getHttpGet() { return (HttpGet) this.httpRequest; } /** * 获取 HTTP POST 控制器 * * @return */ public HttpPost getHttpPost() { return (HttpPost) this.httpRequest; } /** * 获取请求的状态码 * * @return */ public int getStatusCode() { return this.statusCode; } /** * 通过 GET 方式请求数据 * * @param url * @return * @throws IOException */ public String get(String url) throws Exception { this.requsetType = HTTP_GET; // 设置当前请求的链接 this.setUrl(url); // 新建 HTTP GET 请求 this.httpRequest = new HttpGet(this.url); // 执行客户端请求 this.httpClientExecute(); // 监听服务端响应事件并返回服务端内容 return this.checkStatus(); } /** * 获取 HTTP POST 多段数据提交管理器 * * @return */ public MultipartEntityBuilder getMultipartEntityBuilder() { if (this.multipartEntityBuilder == null) { this.multipartEntityBuilder = MultipartEntityBuilder.create(); // 设置为浏览器兼容模式 multipartEntityBuilder.setMode(HttpMultipartMode.BROWSER_COMPATIBLE); // 设置请求的编码格式 multipartEntityBuilder.setCharset(Charset.forName(this.charset)); } return this.multipartEntityBuilder; } /** * 配置完要 POST 提交的数据后, 执行该方法生成数据实体等待发送 */ public void buildPostEntity() { // 生成 HTTP POST 实体 HttpEntity httpEntity = this.multipartEntityBuilder.build(); this.getHttpPost().setEntity(httpEntity); } /** * 发送 POST 请求 * * @param url * @return * @throws Exception */ public String post(String url) throws Exception { this.requsetType = HTTP_POST; // 设置当前请求的链接 this.setUrl(url); // 新建 HTTP POST 请求 this.httpRequest = new HttpPost(this.url); // 执行客户端请求 this.httpClientExecute(); // 监听服务端响应事件并返回服务端内容 return this.checkStatus(); } /** * 执行 HTTP 请求 * * @throws Exception */ protected void httpClientExecute() throws Exception { // 配置 HTTP 请求参数 this.httpParameters = new BasicHttpParams(); this.httpParameters.setParameter("charset", this.charset); // 设置 连接请求超时时间 HttpConnectionParams.setConnectionTimeout(this.httpParameters, this.connectionTimeout); // 设置 socket 读取超时时间 HttpConnectionParams.setSoTimeout(this.httpParameters, this.soTimeout); // 开启一个客户端 HTTP 请求 this.httpClient = new DefaultHttpClient(this.httpParameters); // 启动 HTTP POST 请求执行前的事件监听回调操作(如: 自定义提交的数据字段或上传的文件等) this.getOnHttpRequestListener().onRequest(this); // 发送 HTTP 请求并获取服务端响应状态 this.httpResponse = this.httpClient.execute(this.httpRequest); // 获取请求返回的状态码 this.statusCode = this.httpResponse.getStatusLine().getStatusCode(); } /** * 读取服务端返回的输入流并转换成字符串返回 * * @throws Exception */ public String getInputStream() throws Exception { // 接收远程输入流 InputStream inStream = this.httpResponse.getEntity().getContent(); // 分段读取输入流数据 ByteArrayOutputStream baos = new ByteArrayOutputStream(); byte[] buf = new byte[1024]; int len = -1; while ((len = inStream.read(buf)) != -1) { baos.write(buf, 0, len); } // 数据接收完毕退出 inStream.close(); // 将数据转换为字符串保存 return new String(baos.toByteArray(), this.charset); } /** * 关闭连接管理器释放资源 */ protected void shutdownHttpClient() { if (this.httpClient != null && this.httpClient.getConnectionManager() != null) { this.httpClient.getConnectionManager().shutdown(); } } /** * 监听服务端响应事件并返回服务端内容 * * @return * @throws Exception */ protected String checkStatus() throws Exception { OnHttpRequestListener listener = this.getOnHttpRequestListener(); String content; if (this.statusCode == HttpStatus.SC_OK) { // 请求成功, 回调监听事件 content = listener.onSucceed(this.statusCode, this); } else { // 请求失败或其他, 回调监听事件 content = listener.onFailed(this.statusCode, this); } // 关闭连接管理器释放资源 this.shutdownHttpClient(); return content; } /** * HTTP 请求操作时的事件监听接口 */ public interface OnHttpRequestListener { /** * 初始化 HTTP GET 或 POST 请求之前的 header 信息配置 或 其他数据配置等操作 * * @param request * @throws Exception */ public void onRequest(ZHttpRequest request) throws Exception; /** * 当 HTTP 请求响应成功时的回调方法 * * @param statusCode 当前状态码 * @param request * @return 返回请求获得的字符串内容 * @throws Exception */ public String onSucceed(int statusCode, ZHttpRequest request) throws Exception; /** * 当 HTTP 请求响应失败时的回调方法 * * @param statusCode 当前状态码 * @param request * @return 返回请求失败的提示内容 * @throws Exception */ public String onFailed(int statusCode, ZHttpRequest request) throws Exception; } /** * 绑定 HTTP 请求的监听事件 * * @param listener * @return */ public ZHttpRequest setOnHttpRequestListener(OnHttpRequestListener listener) { this.onHttpRequestListener = listener; return this; } /** * 获取已绑定过的 HTTP 请求监听事件 * * @return */ public OnHttpRequestListener getOnHttpRequestListener() { return this.onHttpRequestListener; } }
在 Activity 中的使用方法(这里我还是只写主体部分代码):
MainActivity.java
public void doClick(View view) { ZHttpRequest get = new ZHttpRequest(); get .setCharset(HTTP.UTF_8) .setConnectionTimeout(5000) .setSoTimeout(5000); get.setOnHttpRequestListener(new ZHttpRequest.OnHttpRequestListener() { @Override public void onRequest(ZHttpRequest request) throws Exception { } @Override public String onSucceed(int statusCode, ZHttpRequest request) throws Exception { return request.getInputStream(); } @Override public String onFailed(int statusCode, ZHttpRequest request) throws Exception { return "GET 请求失败:statusCode "+ statusCode; } }); ZHttpRequest post = new ZHttpRequest(); post .setCharset(HTTP.UTF_8) .setConnectionTimeout(5000) .setSoTimeout(10000); post.setOnHttpRequestListener(new ZHttpRequest.OnHttpRequestListener() { private String CHARSET = HTTP.UTF_8; private ContentType TEXT_PLAIN = ContentType.create("text/plain", Charset.forName(CHARSET)); @Override public void onRequest(ZHttpRequest request) throws Exception { // 设置发送请求的 header 信息 request.addHeader("cookie", "abc=123;456=爱就是幸福;"); // 配置要 POST 的数据 MultipartEntityBuilder builder = request.getMultipartEntityBuilder(); builder.addTextBody("p1", "abc"); builder.addTextBody("p2", "中文", TEXT_PLAIN); builder.addTextBody("p3", "abc中文cba", TEXT_PLAIN); if (picPath != null && ! "".equals(picPath)) { builder.addTextBody("pic", picPath); builder.addBinaryBody("file", new File(picPath)); } request.buildPostEntity(); } @Override public String onSucceed(int statusCode, ZHttpRequest request) throws Exception { return request.getInputStream(); } @Override public String onFailed(int statusCode, ZHttpRequest request) throws Exception { return "POST 请求失败:statusCode "+ statusCode; } }); TextView textView = (TextView) findViewById(R.id.showContent); String content = "初始内容"; try { if (view.getId() == R.id.doGet) { content = get.get("http://www.baidu.com"); content = "GET数据:isGet: " + (get.isGet() ? "yes" : "no") + " =>" + content; } else { content = post.post("http://192.168.1.6/test.php"); content = "POST数据:isPost" + (post.isPost() ? "yes" : "no") + " =>" + content; } } catch (IOException e) { content = "IO异常:" + e.getMessage(); } catch (Exception e) { content = "异常:" + e.getMessage(); } textView.setText(content); }
其中 picPath 为 SD 卡中的图片路径 String 类型,我是直接拍照后进行上传用的
布局页面
activity_main.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <ScrollView android:layout_width="fill_parent" android:layout_height="fill_parent" > <LinearLayout android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="vertical" > <Button android:id="@+id/doGet" android:layout_width="fill_parent" android:layout_height="wrap_content" android:padding="10dp" android:layout_marginBottom="10dp" android:text="GET请求" android:onClick="doClick" /> <Button android:id="@+id/doPost" android:layout_width="fill_parent" android:layout_height="wrap_content" android:padding="10dp" android:layout_marginBottom="10dp" android:text="POST请求" android:onClick="doClick" /> <Button android:id="@+id/doPhoto" android:layout_width="fill_parent" android:layout_height="wrap_content" android:padding="10dp" android:layout_marginBottom="10dp" android:text="拍照" android:onClick="doPhoto" /> <TextView android:id="@+id/showContent" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_marginBottom="10dp" /> <ImageView android:id="@+id/showPhoto" android:layout_width="fill_parent" android:layout_height="250dp" android:scaleType="centerCrop" android:src="@drawable/add" android:layout_marginBottom="10dp" /> </LinearLayout> </ScrollView> </LinearLayout>
至于服务端我用的 PHP ,只是简单的输出获取到的数据而已
<?php echo 'GET:<br>'. "\n"; //print_r(array_map('urldecode', $_GET)); print_r($_GET); echo '<br>'. "\n". 'POST:<br>'. "\n"; //print_r(array_map('urldecode', $_POST)); print_r($_POST); echo '<br>'. "\n". 'FILES:<br>'. "\n"; print_r($_FILES); echo '<br>'. "\n". 'COOKIES:<br>'. "\n"; print_r($_COOKIE);
本文向大家介绍Android拍照和获取相册图片,包括了Android拍照和获取相册图片的使用技巧和注意事项,需要的朋友参考一下 之前遇到各种拍照啊,获取相册图片之类,都是直接去度娘,要么之前的代码复制下,没好好总结过。 再也不要问度娘了,再也不用一堆博客里找啊找了。。。 ----------------------------------------------我是正文的分割线--------
本文向大家介绍Android 拍照并对照片进行裁剪和压缩实例详解,包括了Android 拍照并对照片进行裁剪和压缩实例详解的使用技巧和注意事项,需要的朋友参考一下 Android 拍照并对照片进行裁剪和压缩实例详解 本文主要介绍 Android 调用摄像头拍照并对照片进行裁剪和压缩,文中给出了主要步骤和关键代码。 调用摄像头拍照,对拍摄照片进行裁剪,代码如下。 对拍摄照片进行裁剪,代码如下。 得到
本文向大家介绍Android拍照上传功能示例代码,包括了Android拍照上传功能示例代码的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android实现拍照上传功能的方法。分享给大家供大家参考,具体如下: 1、LoginWindow.java --登录窗口 2. FuncSelector.java -- 功能模块选择窗口 3. PhotoUpload.java -- 照片上传模块 4.
本文向大家介绍Android 拍照,包括了Android 拍照的使用技巧和注意事项,需要的朋友参考一下 示例 向AndroidManifest文件添加访问摄像头的权限: Xml文件: 活动
可使用前端相机或背面相机拍摄照片。 A ) (显示模式) 轻触图标可切换为显示模式。 B ) (位置数据)/(切换相机)/(切换图像大小) 启用位置数据的使用设定即可显示(位置数据)。轻触图标可使用Wi-Fi、GPS*、手机基地台*的信息取得位置数据。取得后会显示(已取得位置数据),拍摄照片时会同时记录位置数据。 * 仅限3G/Wi-Fi机种 C ) (快门) 轻触图标可拍摄照片。 D ) 已拍摄
本文向大家介绍Android设置拍照或者上传本地图片的示例,包括了Android设置拍照或者上传本地图片的示例的使用技巧和注意事项,需要的朋友参考一下 前几天,我们客户端这边收到了市场部的一个需求,需要在我们订单成交后,我们的客户端有一个上传交易凭证的功能,那么如何在Android实现上传图片的这个功能呢?在我进行编码之前,我先问自己几个问题。 第一, 图片是直接选择图库里的,还是需要拍照和选择图