亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

android之camera用法實例詳解

 更新時間:2015年09月23日 11:59:03   作者:Ruthless  
這篇文章主要介紹了android之camera用法,以實例形式較為詳細的分析了Android使用camera拍照的相關技巧與注意事項,需要的朋友可以參考下

本文實例講述了android之camera用法。分享給大家供大家參考。具體如下:

1.關于預覽橫豎差90度的問題

原因分析

經(jīng)過查證和實驗,可以證實:Android提供的SDK(android.hardware.Camera)里大概不能正常的使用豎屏(portrait layout)加載照相機,當用豎屏模式加載照相機時會產(chǎn)生以下情況:

①. 照相機成像左傾90度(傾斜);

②. 照相機成像長寬比例不對(失比)。

之所以是“大概”,原因是因為可能可以通過一些比較復雜的手段解決。如果以上成立,那為什么豎屏不能正常成像也就很顯然了。為什么會產(chǎn)生這樣的情況,請看下面的研究分析。

照相機在一般情況下是必須用landscape layout(橫屏)的,可以證明,先寫一個照相機(只要能preview就行),如果Manifest的activity里不加入android:screenOrientation="landscape",即默認了 android:screenOrientation="portrait"(豎屏),照相機preview時就會出現(xiàn)左傾90度的現(xiàn)象,并且失比。原因是這樣的(我推測的),攝像頭對照物的映射是Android底層固定了的,以landscape方式為正,并且產(chǎn)生大小為320*480的像,如果換成portrait方式了,攝像頭還是產(chǎn)生320*480的像,然后分別對應的放入到一個480*320的屏內(nèi),顯然會失比,然后根據(jù)豎、橫屏的規(guī)則,就產(chǎn)生了左傾90度的情況。為了進一步證實我對失比原因的推測,我照相機內(nèi)加載的SurfaceView調成了320*213,比例大概是(320:213)*1.5=(480:320),所成像結果如愿的形成左傾但是沒有失比的狀況,這就證實了我的想法。

綜上可以看出,左傾是因為攝像頭映射產(chǎn)生的,而失比是由于像素比例映射產(chǎn)生的。

解決方案

暫無好的解決方案,只能強制橫屏,記載代碼中加入

復制代碼 代碼如下:
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);

暫無好的解決方案,只能強制橫屏,記載代碼中加入
復制代碼 代碼如下:
android:screenOrientation="landscape"

2.關于拍出來的照片不能正確成像,如綠屏,紅綠相間,重疊等

原因分析

有的手機不支持parameter.setPictureSize(width,height)、parameters.setPreviewSize(width,height)方法,為了兼容性建議不設置這兩個方法。

附:完整示例代碼:

main.xml布局文件:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="fill_parent"
 android:layout_height="fill_parent"
 android:orientation="vertical" >
 <LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:orientation="vertical"
  android:layout_weight="2">
  <SurfaceView
   android:id="@+id/surfaceView"
   android:layout_width="fill_parent"
   android:layout_height="fill_parent" />
 </LinearLayout>
 <LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="fill_parent"
  android:layout_height="wrap_content"
  android:orientation="horizontal"
  android:layout_weight="1"
  android:background="@android:color/white"
  android:layout_gravity="center">
  <ImageButton android:layout_width="fill_parent"
   android:layout_height="80dip"
   android:id="@+id/btnTakePicture"
   android:layout_gravity="center"
   android:textSize="30dip"
   android:layout_weight="1"
   android:src="@drawable/btn_take_pic"/>
  <ImageButton android:layout_width="fill_parent"
   android:layout_height="80dip"
   android:id="@+id/btnAutoFocus"
   android:layout_gravity="center"
   android:textSize="30dip"
   android:layout_weight="1"
   android:src="@drawable/btn_auto_focus"/>
 </LinearLayout>
</LinearLayout>

二、MainActivity拍照核心代碼:

package cn.itcast.takepicture;
import java.io.File;
import java.io.FileOutputStream;
import android.app.Activity;
import android.content.pm.ActivityInfo;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Matrix;
import android.graphics.PixelFormat;
import android.graphics.Bitmap.CompressFormat;
import android.hardware.Camera;
import android.hardware.Camera.PictureCallback;
import android.os.Bundle;
import android.os.Environment;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;
import android.view.SurfaceHolder.Callback;
import android.widget.ImageButton;
public class MainActivity extends Activity {
 private ImageButton btnTakePicture = null;
 private ImageButton btnAutoFocus = null;
 private Camera camera = null;
 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  // 設置窗口標題
  requestWindowFeature(Window.FEATURE_NO_TITLE);
  // 橫屏
  setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
  // 全屏顯示
  getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,
  WindowManager.LayoutParams.FLAG_FULLSCREEN);
  // 當此窗口為用戶可見時,保持設備常開,并保持亮度不變。
  getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
  setContentView(R.layout.main);
  SurfaceView surfaceView = (SurfaceView) this
    .findViewById(R.id.surfaceView);
  surfaceView.getHolder()
    .setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
  surfaceView.getHolder().setFixedSize(320, 240); // 設置分辨率
  surfaceView.getHolder().addCallback(new SurfaceCallback());
  btnTakePicture = (ImageButton) findViewById(R.id.btnTakePicture);
  btnAutoFocus = (ImageButton) findViewById(R.id.btnAutoFocus);
  btnTakePicture.setOnClickListener(onClickListener);
  btnAutoFocus.setOnClickListener(onClickListener);
 }
 private final View.OnClickListener onClickListener = new View.OnClickListener() {
  @Override
  public void onClick(View v) {
   if (v == btnTakePicture) {
    if (camera != null)
     camera.takePicture(null, null, new TakePictureCallback()); // 拍照
   } else if (v == btnAutoFocus) {
    if (camera != null)
     camera.autoFocus(null); // 對焦
   }
  }
 };
 private final class SurfaceCallback implements Callback {
  private boolean preview; // 是否正在預覽
  @Override
  public void surfaceChanged(SurfaceHolder holder, int format, int width,
    int height) {
  }
  @Override
  public void surfaceCreated(SurfaceHolder holder) {
   try {
    camera = Camera.open();
    Camera.Parameters parameters = camera.getParameters();
    parameters.setPreviewFrameRate(5); //每秒5幀
    parameters.setPictureFormat(PixelFormat.JPEG);//設置照片的輸出格式
    parameters.set("jpeg-quality", 85);//照片質量
    camera.setParameters(parameters);
    camera.setPreviewDisplay(holder);
    camera.startPreview();
    preview = true;
   } catch (Exception e) {
    e.printStackTrace();
   }
  }
  @Override
  public void surfaceDestroyed(SurfaceHolder holder) {
   if (camera != null) {
    if (preview) {
     camera.stopPreview();
     preview = false;
    }
    camera.release();
    camera = null; // 記得釋放
   }
  }
 }
 private final class TakePictureCallback implements PictureCallback {
  public void onPictureTaken(byte[] data, Camera camera) {
   Bitmap bitmap = BitmapFactory.decodeByteArray(data, 0, data.length);
   Matrix matrix=new Matrix();
   //設置縮放
   matrix.postScale(0.5f, 0.5f);
   bitmap=Bitmap.createBitmap(bitmap, 0, 0, bitmap.getWidth(), bitmap.getHeight(), matrix, true);
   File file = new File(Environment.getExternalStorageDirectory(),
     System.currentTimeMillis() + ".jpg");
   try {
    FileOutputStream outStream = new FileOutputStream(file);
    bitmap.compress(CompressFormat.JPEG, 100, outStream);
    outStream.close();
    camera.startPreview();
   } catch (Exception e) {
    e.printStackTrace();
   }
  }
 }
}

清單文件:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
 package="cn.itcast.takepicture"
 android:versionCode="1"
 android:versionName="1.0" >
 <application
  android:icon="@drawable/icon"
  android:label="@string/app_name" >
  <activity
   android:label="@string/app_name"
   android:name=".MainActivity" >
   <intent-filter >
    <action android:name="android.intent.action.MAIN" />
    <category android:name="android.intent.category.LAUNCHER" />
   </intent-filter>
  </activity>
 </application>
 <uses-sdk android:minSdkVersion="7" />
 <uses-permission android:name="android.permission.CAMERA" />
 <!-- 在SDCard中創(chuàng)建與刪除文件權限 -->
 <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS" />
 <!-- 往SDCard寫入數(shù)據(jù)權限 -->
 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
</manifest>

希望本文所述對大家的Android程序設計有所幫助。

相關文章

  • Flutter 首頁必用組件NestedScrollView的示例詳解

    Flutter 首頁必用組件NestedScrollView的示例詳解

    今天介紹的組件是NestedScrollView,大部分的App首頁都會用到這個組件。對Flutter 首頁必用組件NestedScrollView的相關知識感興趣的一起看看吧
    2020-05-05
  • Android studio 快速刪除無用資源的方法

    Android studio 快速刪除無用資源的方法

    最近苦于android 項目越來越大,項目需求不停變動。項目中的資源文件越來越雜,越來越亂。android studio怎么刪除無用資源呢?下文圖文并茂給大家介紹的非常詳細,需要的朋友參考下吧
    2017-11-11
  • Android實現(xiàn)調用攝像頭

    Android實現(xiàn)調用攝像頭

    本文給大家分享的是,在安卓APP開發(fā)的過程中,經(jīng)常會需要調用手機自身攝像頭拍照的代碼,十分的簡單實用,有需要的小伙伴可以參考下。
    2015-07-07
  • 簡單談談我的Android屏幕適配之路

    簡單談談我的Android屏幕適配之路

    我相信Android碎片化問題是讓所有的Android開發(fā)者都比較頭疼的問題.尤其是屏幕適配這一塊兒.想要自己的app在不同的設備上面都有一個比較好的顯示效果.就必須做好相應的屏幕適配.
    2017-11-11
  • Android利用Theme自定義Activity間的切換動畫

    Android利用Theme自定義Activity間的切換動畫

    這篇文章主要為大家詳細介紹了Android利用Theme自定義Activity間的切換動畫,感興趣的小伙伴們可以參考一下
    2016-09-09
  • Android入門之動態(tài)BroadCast的使用教程

    Android入門之動態(tài)BroadCast的使用教程

    系統(tǒng)自己在很多時候都會發(fā)送廣播,比如電量低或者充足,剛啟動完,插入耳機,你有一條新的微信消息,這種都是使用BroadCast機制去實現(xiàn)的。BroadCast分為靜態(tài)和動態(tài)BroadCast兩種,本文就來聊聊動態(tài)BroadCast的使用,需要的可以參考一下
    2022-12-12
  • Android 微信搖骰子和猜拳作弊器原理解析

    Android 微信搖骰子和猜拳作弊器原理解析

    這篇文章主要介紹了Android 微信搖骰子和猜拳作弊器原理解析的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-11-11
  • Android ViewPager實現(xiàn)無限循環(huán)效果

    Android ViewPager實現(xiàn)無限循環(huán)效果

    這篇文章主要為大家詳細介紹了Android ViewPager實現(xiàn)無限循環(huán)效果的相關資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-03-03
  • Android 多線程的實現(xiàn)方法總結

    Android 多線程的實現(xiàn)方法總結

    這篇文章主要介紹了Android 多線程的實現(xiàn)方法總結的相關資料,這里提供三種方法,幫助大家掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-08-08
  • Android動畫學習筆記之補間動畫

    Android動畫學習筆記之補間動畫

    這篇文章主要為大家詳細介紹了Android動畫學習筆記之補間動畫,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12

最新評論