質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

91.35%

  • Android

    5163questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • Android Studio

    2715questions

    Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

らくらくスマートフォンF-06Fでの開発について

解決済

回答 1

投稿 2017/12/02 16:19 ・編集 2017/12/02 16:39

  • 評価
  • クリップ 0
  • VIEW 64

ths

score 2

Android開発で実機を持っていなかったので、中古で安かったF-06Fを購入しました。
開発するアプリはカメラアプリです。
友達の端末では実行できたのですが、F-06Fだとエラーが出てクラッシュしました。
OSは両方同じAndroid4.4です。
やはりらくらくスマートフォンとあって、カメラなどを使用することはできないのでしょうか?
ちゃんとカメラのパーミッションを許可してます。
どなたか原因分かる方いらっしゃいましたらご教授お願い致します。。

補足
ソースコードです
AutoCamera.java

package a.camera;
import android.app.Activity;
import android.bluetooth.BluetoothAdapter;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.hardware.Camera;
import android.os.Bundle;
import android.os.Environment;
import android.os.Handler;
import android.util.Log;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;
import android.widget.Toast;

import java.io.FileOutputStream;

public class AutoCamera extends Activity {
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(new CameraView(this));
        getWindow().addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);
    }
}

CameraPreview.java

package a.camera;

import android.annotation.TargetApi;
import android.content.Context;
import android.graphics.PixelFormat;
import android.hardware.Camera;
import android.os.Build;
import android.os.Handler;
import android.util.Log;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
import android.widget.Toast;

import java.io.BufferedOutputStream;
import java.net.Socket;

import static android.content.ContentValues.TAG;

public class CameraView extends SurfaceView implements SurfaceHolder.Callback{
    private SurfaceHolder holder;
    private Camera camera;
    private static final int WIDTH  = 480;
    private static final int HEIGHT = 320;
    private static final int PORT = 49152;
    private static final String IP_ADDR = "192.168.11.2";
    private static boolean is_save;

    public CameraView(Context context) {
        super(context);
        holder=getHolder();
        holder.addCallback(this);
        holder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
    }

    @Override
    public void surfaceCreated(SurfaceHolder holder) {
        try {
            camera = Camera.open(0);
            camera.setPreviewDisplay(holder);
        } catch (Exception e) {
        }
    }

    @Override
    public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
        Camera.Parameters parameters=camera.getParameters();
        parameters.setPictureSize(WIDTH, HEIGHT);
        camera.setParameters(parameters);
        camera.startPreview();
        faceDetection();
    }

    @Override
    public void surfaceDestroyed(SurfaceHolder holder) {
        camera.setPreviewCallback(null);
        camera.stopPreview();
        camera.release();
        camera=null;
    }

    @TargetApi(Build.VERSION_CODES.ICE_CREAM_SANDWICH)
    public void faceDetection(){
        final int standardFaceScore = 60000;
        try {camera.startFaceDetection();
        } catch (IllegalArgumentException e) {
        } catch (RuntimeException e) {}

        camera.setFaceDetectionListener(new Camera.FaceDetectionListener() {
            @Override
            public void onFaceDetection(Camera.Face[] faces, Camera camera) {
                Log.d(TAG, "faces count: " + faces.length);
                for (Camera.Face face : faces) {
                    Log.d(TAG, "face id: " + face.id);
                    Log.d(TAG, "face score: " + face.score);
                    Log.d(TAG, "face rect: " + face.rect.left + "," + face.rect.top + " - "
                            + face.rect.right + "," + face.rect.bottom);
                    if (face.mouth != null) {
                        Log.d(TAG, "face mouth: " + face.mouth.x + "," + face.mouth.y);
                        Log.d(TAG, "face leftEye: " + face.leftEye.x + "," + face.leftEye.y);
                        Log.d(TAG, "face rightEye: " + face.rightEye.x + "," + face.rightEye.y);
                    }
                    if(face.score > standardFaceScore && !is_save){
                        takePicture();
                    }
                }
            }
        });
    }

    public void takePicture() {
        // カメラのスクリーンショットの取得
        camera.takePicture(null, null,new Camera.PictureCallback() {
            public void onPictureTaken(byte[] data,Camera camera) {
                Toast.makeText(getContext(), "撮影しました", Toast.LENGTH_LONG).show();
                is_save = true;
                sendData(getContext(), data);
                new Handler().postDelayed(new Runnable() {
                    @Override
                    public void run() {
                        is_save = false;
                    }
                }, 3000);
            }
        });
    }

    private void sendData(Context context, byte[] data){
        // ソケットの作成
        Socket socket;
        BufferedOutputStream out;
        try{
            socket = new Socket(IP_ADDR, PORT);
            out = new BufferedOutputStream(socket.getOutputStream());
            out.write(data);
            if(out != null) out.close();
            if(socket != null) socket.close();
        } catch (Exception ex){
            ex.printStackTrace();
        }
    }
}

基本このエラーです。

12-02 16:16:33.598 1305-17957/? E/HCEOutdoorUtil: (413) int HCEView_ManagerSensor::getIdent() Error(ALooper_pollAll returns TIMEOUT. Set Initialized Values)
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • yona

    2017/12/02 16:24

    エラーログを載せてください。

    キャンセル

  • yona

    2017/12/02 17:16

    エラーログは省略しないでください。

    キャンセル

回答 1

check解決した方法

0

yonaさん回答していただき大変ありがとうございました。
surfaceChanged()メソッドの中のプレービューサイズを端末がサポートするサイズに変更したらカメラが起動しました。
これからも詰まったら質問させていただきます。

投稿 2017/12/02 17:48

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

ただいまの回答率

91.35%

関連した質問

同じタグがついた質問を見る

  • Android

    5163questions

    Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

  • Android Studio

    2715questions

    Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。