編輯:關於android開發
網上有很多關於拍照上傳的實現方法,如果用新版本android去運行有可能會發現根本實現不了。主要原因是android從4.4版本開始通過intent.ACTION_GET_CONTENT打開選擇器後,getData()返回的URI沒有包含真實的文件路徑,而是像這樣“content://com.android.providers.media.documents/document/image:1234”,以至於用傳統的方式找不到圖片的路徑。最簡單的解決辦法是用intent.ACTION_PICK代替intent.ACTION_GET_CONTENT。下面給出4.4版本後拍照上傳的具體實現方法:
第一步:點擊拍照按鈕代碼
//點擊拍照
btnHeadCamera.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
Intent itCamera=new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
startActivityForResult(itCamera,0);
}
});
第二步:保存拍照圖片代碼
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
switch (requestCode){
case 0://拍照
savePhoto(data);
break;
}
super.onActivityResult(requestCode, resultCode, data);
}
final String SAVE_PATH=Environment.getExternalStorageDirectory()+"/my_head.jpg"; //拍照後保存路徑
//保存圖片
public void savePhoto(Intent it){ Bundle bundle=it.getExtras(); if(bundle!=null){ Bitmap photo = bundle.getParcelable("data"); imgHead.setImageBitmap(photo); File fileHead=new File(SAVE_PATH); try { if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){ if(!fileHead.getParentFile().exists()){ fileHead.getParentFile().mkdir(); } BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream(fileHead)); photo.compress(Bitmap.CompressFormat.JPEG,80,bos); bos.flush(); bos.close(); }else { Toast toast = Toast.makeText(HeadPhotoActivity.this, "保存失敗!", Toast.LENGTH_SHORT); toast.setGravity(Gravity.CENTER, 0, 0); toast.show(); } }catch (FileNotFoundException e){ e.printStackTrace(); }catch (IOException e){ e.printStackTrace(); } } }
第三步:上傳圖片代碼
String SERVER_URL = Config.PhotoAPI+"/UploadImage";//上傳的服務端API地址
btnHeadCancel.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { new Thread(new Runnable() { @Override public void run() { File file = new File(SAVE_PATH); Message msg = new Message(); msg.what = 0; if(file!=null) { try { int re = ImageUtils.uploadForm(file, SERVER_URL); msg.obj = re; } catch (IOException ex) { msg.obj = 0; Toast.makeText(HeadPhotoActivity.this, "上傳失敗", Toast.LENGTH_SHORT).show(); } handler.sendMessage(msg); }else { Toast.makeText(HeadPhotoActivity.this, "找不到上傳圖片", Toast.LENGTH_SHORT).show(); } } }).start(); } });
final Handler handler=new Handler(){
@Override
public void handleMessage(Message msg) {
switch (msg.what) {
case 0:
if ((int)msg.obj == 1) {
Toast.makeText(HeadPhotoActivity.this, "上傳成功", Toast.LENGTH_SHORT).show();
} else {
Toast.makeText(HeadPhotoActivity.this, "上傳失敗", Toast.LENGTH_SHORT).show();
}
break;
}
}
};
/**
*
* @param uploadFile
* 需要上傳的文件
* @param serverUrl
* 上傳的服務器的路徑
* @throws IOException
*/
public static int uploadForm(File uploadFile, String serverUrl)
throws IOException {
int re=0;
String fileName = uploadFile.getName();
StringBuilder sb = new StringBuilder();
sb.append("--" + BOUNDARY + "\r\n");
sb.append("Content-Disposition: form-data; name=\"" + fileName
+ "\"; filename=\"" + fileName + "\"" + "\r\n");
sb.append("Content-Type: image/jpeg" + "\r\n");
sb.append("\r\n");
byte[] headerInfo = sb.toString().getBytes("UTF-8");
byte[] endInfo = ("\r\n--" + BOUNDARY + "--\r\n").getBytes("UTF-8");
System.out.println(sb.toString());
URL url = new URL(serverUrl);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod("POST");
conn.setRequestProperty("Content-Type",
"multipart/form-data; boundary=" + BOUNDARY);
conn.setRequestProperty("Content-Length", String
.valueOf(headerInfo.length + uploadFile.length()
+ endInfo.length));
conn.setDoOutput(true);
OutputStream out = conn.getOutputStream();
InputStream in = new FileInputStream(uploadFile);
out.write(headerInfo);
byte[] buf = new byte[1024];
int len;
while ((len = in.read(buf)) != -1)
out.write(buf, 0, len);
out.write(endInfo);
in.close();
out.close();
if (conn.getResponseCode() == 200) {
re=1;
}
return re;
}
最後給出服務端WebAPI代碼:
[HttpPost]
public async Task<HttpResponseMessage> UploadImage()
{
string filePath = "~\\UploadFiles\\Photo";
// 取得文件夾
string dir = HttpContext.Current.Server.MapPath(filePath);
//如果不存在文件夾,就創建文件夾
if (!Directory.Exists(dir))
Directory.CreateDirectory(dir);
if (!Request.Content.IsMimeMultipartContent("form-data"))
{
throw new HttpResponseException(HttpStatusCode.UnsupportedMediaType);
}
var provider = new CustomMultipartFormDataStreamProvider(dir);
try
{
// Read the form data.
await Request.Content.ReadAsMultipartAsync(provider);
foreach (MultipartFileData file in provider.FileData)
{
//file.Headers.ContentDisposition.FileName;//上傳文件前的文件名
//file.LocalFileName;//上傳後的文件名
Photo p = new Photo();
p.ImgInfo = file.LocalFileName.Substring(file.LocalFileName.LastIndexOf("\\"));
p.Sort = "員工相冊";
p.AddUser = "admin";
p.AddTime = DateTime.Now;
p.Url = filePath + p.ImgInfo;
db.Photo.Add(p);
db.SaveChanges();
}
return Request.CreateResponse(HttpStatusCode.OK);
}
catch
{
return Request.CreateResponse(HttpStatusCode.BadRequest);
}
}
//重寫上傳文件名
public class CustomMultipartFormDataStreamProvider : MultipartFormDataStreamProvider
{
public CustomMultipartFormDataStreamProvider(string path)
: base(path)
{ }
public override string GetLocalFileName(System.Net.Http.Headers.HttpContentHeaders headers)
{
string fileName = DateTime.Now.ToString("yyyyMMddHHmmssfff");
return fileName + "_" + headers.ContentDisposition.FileName.Replace("\"", string.Empty);//base.GetLocalFileName(headers);
}
}
算法—7.無序鏈表中的順序查找,算法無序
算法—7.無序鏈表中的順序查找,算法無序1.基本思想 符號表中使用的數據結構的一個簡單選擇是鏈表,每個結點存儲一個鍵值對,如算法中的代碼所示。get()的實現即為遍歷鏈表
Android開發技巧——定制仿微信圖片裁剪控件
Android開發技巧——定制仿微信圖片裁剪控件 拍照——裁剪,或者是選擇圖片——裁剪,是我們設置頭像或上傳圖片時經常
Android Picasso 獲取遠程圖片並顯示,
Android Picasso 獲取遠程圖片並顯示, Picasso是Square公司開源的一個Android圖形緩存庫,地址http://square.git
Android 手機衛士--獲取聯系人信息並顯示與回顯,android回顯
Android 手機衛士--獲取聯系人信息並顯示與回顯,android回顯前面的文章已經實現相關的布局,本文接著進行相關的功能實現 本文地址:http://www.cnb