package com.samsung.android.activity;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileNotFoundException;
import android.app.Activity;
import android.content.ContentResolver;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.net.Uri;
import android.os.Bundle;
import android.os.Environment;
import android.provider.MediaStore;
import android.view.Gravity;
import android.view.KeyEvent;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.Window;
import android.widget.Button;
import android.widget.ImageButton;
import android.widget.ImageView;
import android.widget.PopupWindow;
public class ImagePageActivity extends Activity implements OnClickListener {
private ImageButton addbtn;
private ImageButton back_btn;
private PopupWindow popupWindow;
private Button openPhoto, camera, close;
private ImageView imageView;
private int REQUEST_CAMERA = 1;
@Override
protected void onCreate(Bundle savedInstanceState) {
// TODO Auto-generated method stub
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.photopage);
LayoutInflater inflater = LayoutInflater.from(this);
View layout = inflater.inflate(R.layout.popupmenu, null);
popupWindow = new PopupWindow(layout, 200, 200);
addbtn = (ImageButton) findViewById(R.id.photopage_addphoto_btn);
addbtn.setOnClickListener(this);
back_btn = (ImageButton) findViewById(R.id.photopage_backmain_btn);
back_btn.setOnClickListener(this);
close = (Button) layout.findViewById(R.id.closepop);
close.setOnClickListener(this);
camera = (Button) layout.findViewById(R.id.camera);
camera.setOnClickListener(this);
openPhoto = (Button) layout.findViewById(R.id.openPhoto);
openPhoto.setOnClickListener(this);
imageView = (ImageView)findViewById(R.id.imageView1);
}
@Override
public void onClick(View v) {
// TODO Auto-generated method stub
switch (v.getId()) {
case R.id.closepop:
popupWindow.dismiss();
popupWindow.setFocusable(false);
break;
case R.id.photopage_addphoto_btn:
popupWindow.showAtLocation(
findViewById(R.id.photopage_addphoto_btn), Gravity.BOTTOM,
0, 30);
popupWindow.setFocusable(true);
popupWindow.update();
break;
case R.id.photopage_backmain_btn:
ImagePageActivity.this.finish();
break;
case R.id.openPhoto:
Intent intent = new Intent();
/* 开启Pictures画面Type设定为image */
intent.setType("image/*");
/* 使用Intent.ACTION_GET_CONTENT这个Action */
intent.setAction(Intent.ACTION_GET_CONTENT);
/* 取得相片后返回本画面 */
startActivityForResult(intent, 1);
REQUEST_CAMERA =0;
break;
case R.id.camera:
Intent getImageByCamera = new Intent(
"android.media.action.IMAGE_CAPTURE");
startActivityForResult(getImageByCamera,REQUEST_CAMERA);
REQUEST_CAMERA =1;
break;
default:
break;
}
}
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
// TODO Auto-generated method stub
if(keyCode == KeyEvent.KEYCODE_BACK){
startActivity(new Intent(ImagePageActivity.this,OrderMsgActivity.class));
ImagePageActivity.this.finish();
}
return super.onKeyDown(keyCode, event);
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (REQUEST_CAMERA == 0) {
Uri uri = data.getData();
// Log.e("uri", uri.toString());
ContentResolver cr = this.getContentResolver();
try {
Bitmap bitmap = BitmapFactory.decodeStream(cr.openInputStream(uri));
/* 将Bitmap设定到ImageView */
imageView.setImageBitmap(bitmap);
} catch (FileNotFoundException e) {
// Log.e("Exception", e.getMessage(),e);
}
}else if (REQUEST_CAMERA == 1){
Bitmap myBitmap = null;
try
{
super.onActivityResult(requestCode, resultCode, data);
Bundle extras = data.getExtras();
myBitmap = (Bitmap) extras.get("data");
ByteArrayOutputStream baos = new ByteArrayOutputStream();
myBitmap.compress(Bitmap.CompressFormat.JPEG, 100, baos);
byte[] mContent = baos.toByteArray();
} catch ( Exception e )
{
e.printStackTrace();
}
// 把得到的图片绑定在控件上显示
imageView.setImageBitmap(myBitmap);//把拍摄的照片转成圆角显示在预览控件
}
super.onActivityResult(requestCode, resultCode, data);
}
}
分享到:
相关推荐
本文将详细讲解如何在Android的Webview中调用相册和拍照功能,以实现H5与原生Android应用的深度集成。 首先,我们需要了解`WebView`的基本用法。`WebView`是Android SDK中的一个类,它可以加载URL,展示HTML页面,...
以上就是如何在Android 2.2项目中使用Eclipse调用相册和拍照功能的基本步骤。通过这些步骤,你的应用就能让用户方便地选择或拍摄图片,并进行后续处理。请确保在实际开发中考虑到不同设备和Android版本的兼容性问题...
以上就是使用Delphi 11.3在Android平台上调用相册并显示图片的主要步骤和技术点。通过这个模板,开发者可以快速构建类似功能的应用。同时,记得在实际项目中根据具体需求进行适应性调整和错误处理。
本文将详细讲解如何不依赖第三方库,仅使用Android原生API实现拍照和图片多选功能。 首先,调用系统相机拍摄照片。在Android中,可以使用Intent来启动相机应用。创建一个Intent,指定ACTION_IMAGE_CAPTURE action,...
对于调用相册选择图片,同样需要创建一个Intent,但这次是使用`ACTION_PICK`: ```java Intent choosePictureIntent = new Intent(Intent.ACTION_PICK); choosePictureIntent.setType("image/*"); if ...
为了解决这个问题,我们需要采用另一种策略,即手动处理拍照后的图片存储和获取。 下面是兼容小米设备的调用相机代码: ```java Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); if ...
在Android开发中,调用相机拍照和选择相册...总结,Android Studio调用相机拍照和选择相册照片,主要涉及权限管理、启动相机Intent、处理返回结果以及图片的存储操作。对于更复杂的相机功能,可以深入研究Camera2 API。
安卓,调用系统相机拍照/调用系统相册返回图片,可同时设置调用系统裁剪工具进行裁剪/设置输出尺寸 工具,代码内含注释
在Android应用开发中,用户交互是至关重要的,特别是在涉及到多媒体功能时,如调用系统相机拍照、从相册选取图片以及图片的展示和处理。这个DEMO提供了一个基础的实现框架,涵盖了这些关键功能,使得开发者能够理解...
在Android应用开发中,有时我们需要集成拍照和图片选择功能,以提供用户更加便捷的操作体验。本文将详细讲解如何不依赖第三方库,仅通过调用系统自带的相机和相册来实现这一功能。我们将以"AddImageDemo"这个项目为...
在Android应用开发中,调用照相机和相册是常见的功能需求,允许用户拍摄照片或选择已有的图片。本文将详细讲解如何实现这一功能,并提供源码参考。 首先,我们需要在AndroidManifest.xml文件中添加权限,以便访问...
在这个场景中,我们需要关注的是H5+中的多媒体处理能力,尤其是摄像头访问和图片选择功能。 1. **调用摄像头**:HTML5引入了`<input type="file">`元素的`accept`属性,可以指定用户可以选择的文件类型。当设置为`...
综上所述,通过 Xamarin.Forms 和依赖服务,我们可以轻松地实现在跨平台应用中调用设备的相机拍照以及访问图库选择图片的功能。这不仅简化了代码,而且保证了在不同平台上的一致用户体验。在开发过程中,确保遵循...
通过以上步骤,你就可以在Qt应用中实现调用原生安卓照相机的功能,包括拍照、摄像、打开相册以及播放视频。这种方式既保留了Qt的跨平台特性,又充分利用了Android系统的原生能力,提高了用户体验。在实际开发中,你...
在Android开发中,涉及到相机拍照、图片存储、调用相册、图片旋转和裁剪等是常见的功能需求。这些功能的实现涉及到多个Android系统API的使用,包括相机API、文件I/O、媒体库以及图像处理库。下面我们将详细探讨这些...
以下是关于“调用本地相册和本地图片”的详细知识点: 1. **Intent用于图片选择** Android系统提供了Intent机制,允许开发者启动系统服务,如打开相册。通过创建一个ACTION_PICK Intent,你可以让用户在相册中选择...
在Android应用开发中,调用系统相机拍照和访问相册是常见的功能,用户可以通过这些功能获取并处理图像。...通过深入理解这些步骤,您将能够有效地在Android应用中调用相机拍照和访问相册,并上传图片到服务器。
最近一直抽空在做仿微信朋友圈的功能,在点击加号选择选择拍摄进入相机拍照并将图片显示出来,因为版本迭代(Android11马上也就出来了),所以需要进行版本适配,所以在这里进行记录一下,方便以后查看和小伙伴们...
在iOS端,我们需要创建一个Objective-C或Swift的静态库(.dylib文件),实现相册访问和图片剪裁的功能。 1. **访问iOS相册**: - 在iOS端,使用Photos框架(在iOS 6及以上版本中替代了旧的AssetsLibrary框架)。...
本文将深入探讨如何使用H5技术来实现调用手机摄像头、相册,以及图片的压缩、预览和删除功能。这些功能对于移动设备上的网页应用尤其重要,因为它们能够提供与原生应用类似的用户体验。 首先,调用手机摄像头和相册...