0

x秒ごとに写真を撮り、しきい値を超える違いを検出し、最終的に高解像度の写真を電子メールで送信するアプリを作成しています。すべてのカメラ機能をメインと同じクラスに保持すると、アプリは正常に機能しましたが、コードが乱雑になり、スレッドで写真を撮るのも難しくなります。そこで、すべてのカメラ関数を 2 番目の Java クラス (TakePic.java) に移動し、これを x 秒ごとにメイン クラスから呼び出すことにしました。今のところ、1回でも呼べればいいのですが、できません。これが私のコードです:

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest android:versionCode="1"
      android:versionName="1.0"
      package="com.lyo.android.CameraSender5"
      xmlns:android="http://schemas.android.com/apk/res/android">

<uses-sdk android:minSdkVersion="5"
        android:targetSdkVersion="6" />
<supports-screens android:largeScreens="false"
                android:normalScreens="true"
                android:smallScreens="false" />

<uses-permission android:name="android.permission.CAMERA" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.INTERNET"></uses-permission>  
<uses-feature android:name="android.hardware.camera" />
<uses-feature android:name="android.hardware.RECEIVE_SMS" />
<uses-feature android:name="android.hardware.RECEIVE_MMS" />
<uses-feature android:name="android.hardware.read_owner_data" />
<uses-feature android:name="android.hardware.write_owner_data" />
<uses-feature android:name="android.hardware.acccess_network_state" />

<application 
  android:icon="@drawable/cw"
  android:label="@string/app_name">
<activity 
    android:configChanges="keyboardHidden|orientation"
    android:label="@string/app_name"
    android:name=".PreviewDemo"
    android:screenOrientation="landscape"
    android:theme="@android:style/Theme.NoTitleBar.Fullscreen">

  <intent-filter>
    <action android:name="android.intent.action.MAIN" />
    <category android:name="android.intent.category.LAUNCHER" />
  </intent-filter>
</activity>
<activity 
    android:configChanges="keyboardHidden|orientation"
    android:label="@string/app_name"
    android:name=".TakePic"
    android:screenOrientation="landscape"
    android:theme="@android:style/Theme.NoTitleBar.Fullscreen">        
  <intent-filter>
    <action android:name="com.lyo.android.TAKEPIC" />
    <category android:name="android.intent.category.DEFAULT" />
  </intent-filter>
</activity>
</application>
</manifest>

以下はメインクラスです。

package com.lyo.android.CameraSender5;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;
import javax.mail.BodyPart;
import javax.mail.Multipart;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;
import android.app.Activity;
import android.content.Intent;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Color;
//import android.hardware.Camera;
//import android.hardware.Camera.PictureCallback;
import android.os.Bundle;
import android.os.Environment;
import android.util.Log;
//import android.view.SurfaceHolder;
//import android.view.SurfaceView;
import android.widget.TextView;
import android.widget.Toast;


import com.lyo.android.CameraSender5.R;


public class PreviewDemo extends Activity 
{
  //private SurfaceView preview=null;
  //private SurfaceHolder previewHolder=null;
  //private Camera camera=null;
  private boolean inPreview=false;
  private boolean cameraConfigured=false;
  public static Integer fileNameINT = 1; 
  /*START*/  
  public static final int MEDIA_TYPE_IMAGE = 1;
  public Bitmap bitmapPictureOld;
  public Bitmap bitmapPictureNew;
  public int singlePixelNew;
  public int singlePixelOld;
  public int colorREDsum = 0;
  public int firstLoop = 1;
  public int tollerance = 500000; //Devi ridurre la tolleranza fino a che c'e' una image detection
  @Override
  public void onCreate(Bundle savedInstanceState) 
  {
  Log.e("onCreate", "onCreate started");
  super.onCreate(savedInstanceState);
  setContentView(R.layout.main);
  Log.e("onCreate", "ContentView set");
  //TakePic TakePic = new TakePic();
  Log.e("onCreate", "TakePic called");
  //TakePic.initialize(this);
  Log.e("onCreate", "Initialized");
  startActivity(new Intent("com.lyo.android.TAKEPIC"));
    //try 
    //{
//  Thread.sleep(1000);
//} 
    //catch (InterruptedException e) 
//{
//  // TODO Auto-generated catch block
//  e.printStackTrace();
//}
    //colorREDsum = 0;
  try 
  {
    Thread.sleep(3000);
  } 
  catch (InterruptedException e) 
  {
    // TODO Auto-generated catch block
    e.printStackTrace();
  }
    //this.runOnUiThread(Timer_Tick);
    //camera.takePicture(null, null, mPicture);
  }};

これは、すべてのカメラ関数を入力した TakePic.java クラスです (これらは以前はメイン クラスにあり、正常に機能していました)。

package com.lyo.android.CameraSender5;

import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.Date;
import java.util.Timer;
import java.util.TimerTask;

import javax.mail.BodyPart;
import javax.mail.Multipart;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;

import android.app.Activity;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Color;
import android.hardware.Camera;
import android.hardware.Camera.PictureCallback;
import android.hardware.Camera.PreviewCallback;
import android.os.Bundle;
import android.os.Environment;
import android.util.Log;
import android.view.SurfaceHolder;
import android.view.SurfaceView;
import android.widget.TextView;
import android.widget.Toast;

import com.lyo.android.CameraSender5.R; 

public class TakePic extends Activity
{

public SurfaceView preview=null;
public SurfaceHolder previewHolder=null;
public Camera camera=null;
public boolean inPreview=false;
public boolean cameraConfigured=false;
public static Integer fileNameINT = 1;

/*START*/  
public static final int MEDIA_TYPE_IMAGE = 1;
public Bitmap bitmapPictureOld;
public Bitmap bitmapPictureNew;
public int singlePixelNew;
public int singlePixelOld;
public int colorREDsum = 0;
public int firstLoop = 1;
public int tollerance = 500000; //Devi ridurre la tolleranza fino a che c'e' una image detection


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

//@Override
public void surfaceCreated(SurfaceHolder holder) {
if (camera == null) {
    camera = Camera.open();
    try {
        camera.setPreviewDisplay(holder);

        // TODO test how much setPreviewCallbackWithBuffer is faster
        camera.setPreviewCallback((PreviewCallback) this);
    } catch (IOException e) {
        camera.release();
        camera = null;
    }
    }
}


@Override
protected void onResume() {
    // TODO Auto-generated method stub
    super.onResume();
    //setContentView(R.layout.main);
    if (camera != null) {
        Log.e("LYO TakePic onResume", "CAMERA NOT NULL");
        camera.unlock();
        camera.stopPreview();
        camera.unlock();
        camera.setPreviewCallback(null);
        camera.unlock();
        camera.release();
        camera.unlock();
        camera = null;
    }
    else
    {
        Log.e("LYO TakePic onResume", "CAMERA NULL");
    }

    Log.e("LYO TakePic onResume", "onResume Start");
    camera = Camera.open();
    Log.e("LYO TakePic onResume", "Camera opened");
    camera.startPreview();
    startPreview();
    Log.e("LYO TakePic onResume", "Preview Started");
    colorREDsum = 0;
}


@Override
protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    Log.e("LYO TakePic onCreate", "Setting content view");
    setContentView(R.layout.main);
    Log.e("LYO TakePic onCreate", "Content View Set");
    Log.e("LYO TakePic onCreate", "Initialization started");
    preview=(SurfaceView)this.findViewById(R.id.preview);
    Log.e("LYO TakePic onCreate", "preview set");
    previewHolder=preview.getHolder();
    previewHolder.addCallback(surfaceCallback);
    previewHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
    Log.e("LYO TakePic onCreate", "holder set");
    colorREDsum = 0;
}


private PictureCallback mPicture = new PictureCallback() 
  {

        //@Override
        public void onPictureTaken(byte[] data, Camera camera) 
        {
            Log.e("PICTURE TAKEN", "START");
            colorREDsum = 0;
            if (firstLoop == 1)
            {
                Log.e("PICTURE TAKEN", "1st LOOP");
                bitmapPictureNew = BitmapFactory.decodeByteArray(data, 0, data.length);
                firstLoop = 0;
            } 
            else 
            {
                Log.e("PICTURE TAKEN", "OTHER LOOP");
                bitmapPictureOld = Bitmap.createBitmap(bitmapPictureNew);
                //bitmapPictureOld.createBitmap(bitmapPictureNew, 0, 0, bitmapPictureNew.getWidth(), bitmapPictureNew.getHeight());

                //Bitmap bitmapPictureOld = bitmapPictureNew;
                bitmapPictureNew = BitmapFactory.decodeByteArray(data, 0, data.length);
                colorREDsum = 0;
                int counter = 0;
                for (int height = 0; height <= bitmapPictureNew.getHeight() - 1; height++)
                {
                    for (int width = 0; width <= bitmapPictureNew.getWidth() - 1; width++)
                    {
                        singlePixelNew = bitmapPictureNew.getPixel(width, height);
                        singlePixelOld = bitmapPictureOld.getPixel(width, height);
                        colorREDsum = colorREDsum + (Color.red(singlePixelNew) - Color.red(singlePixelOld));
                        counter = counter +1;
                    }
                }

                TextView tv1 = (TextView) findViewById(R.id.integer1);
                tv1.setText(String.valueOf(colorREDsum));
                try 
                {
                    Thread.sleep(500);
                } 
                catch (InterruptedException e) 
                {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }


                if(colorREDsum > tollerance)
                {
                    //send message
                    Log.e("PICTURE TAKEN", "RED > TOLLERANCE");
                    //TEMP
                    ByteArrayOutputStream bytes = new ByteArrayOutputStream();
bitmapPictureOld.compress(Bitmap.CompressFormat.PNG, 100, bytes);

                    //you can create a new file name "test.jpg" in sdcard folder.
                    File f = new File(Environment.getExternalStorageDirectory() + File.separator + "ALARM.png");

                    try 
                    {
                        f.createNewFile();
                        //write the bytes in file
                        FileOutputStream fo = new FileOutputStream(f);
                        fo.write(bytes.toByteArray());
                        fo.close();
                    } 
                    catch (IOException e1) 
                    {
                        // TODO Auto-generated catch block
                        e1.printStackTrace();
                    }

                    //camera.startPreview();    

                    Log.e("PICTURE TAKEN", "START MAILING");
                    Mail m = new Mail("*****@.com", "*****");
                    String[] toArr = {"*****@hotmail.com"}; 
                    m.setTo(toArr); 
                    m.setFrom("*****@gmail.com"); 
                    m.setSubject("Ciao Ciao"); 
                    m.setBody("You never know... :)"); 

                    try
                    {
                        Log.e("PICTURE TAKEN", "START SEND TRY");
                        tv1.setText("Start Sending");
                        //try 
                        //{
                        //  Log.e("PICTURE TAKEN", "SLEEP 500");
                        //  Thread.sleep(500);
                        //} 
                        //catch (InterruptedException e) 
                        //{
                        //  // TODO Auto-generated catch block
                        //  e.printStackTrace();
                        //}
                        //START SEND
                        MimeMessage msg = new MimeMessage(m.sessionFCN()); 
                        msg.setFrom(new InternetAddress("*****@gmail.com")); //_from
                        msg.setRecipients(MimeMessage.RecipientType.TO, "*****@hotmail.com"); //addressTo
                        msg.setSubject("Ciao Ciao"); 
                        msg.setSentDate(new Date()); 

                        // setup message body 
                        BodyPart messageBodyPart = new MimeBodyPart();  
                        messageBodyPart.setText("You never know... :)"); //_body
                        Multipart _multipart;
                        _multipart = new MimeMultipart();
                        _multipart.addBodyPart(messageBodyPart); 

                        // Put parts in message 
                        try 
                        {
                        msg.setContent(_multipart);
                        } 
                        catch (Exception e) 
                        {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        } 

                        // send email 
                        try 
                        {
                            Transport.send(msg);
                        } 
                        catch (Exception e) 
                        {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                            Log.e("PICTURE TAKEN", "ERROR WITH Transport.send(msg)");
                        }
                    //END SEND
                    //m.send();
                    }
                    catch (Exception e)
                    {
                        tv1.setText("Sending Failed");
                    }

                    //try 
                    //{
                    //  Thread.sleep(500);
                    //} 
                    //catch (InterruptedException e) 
                    //{
                    //  // TODO Auto-generated catch block
                    //  e.printStackTrace();
                    //}

                }
                //camera.startPreview();
            }
        }
    };

    private Camera.Size getBestPreviewSize(int width, int height, Camera.Parameters parameters) 
    {
      Camera.Size result=null;

      for (Camera.Size size : parameters.getSupportedPreviewSizes()) 
      {
        if (size.width<=width && size.height<=height) 
        {
          if (result==null) 
          {
            result=size;
          }
          else 
          {
            int resultArea=result.width*result.height;
            int newArea=size.width*size.height;

            if (newArea>resultArea) 
            {
              result=size;
            }
          }
        }
      }

      return(result);
    }

    private void initPreview(int width, int height) 
    {
      if (camera!=null && previewHolder.getSurface()!=null) 
      {
        try 
        {
          camera.setPreviewDisplay(previewHolder);
        }
        catch (Throwable t) 
        {
          Log.e("PreviewDemo-surfaceCallback", "Exception in setPreviewDisplay()", t);
          //Toast.makeText(PreviewDemo.this, t.getMessage(), Toast.LENGTH_LONG).show();
        }

        if (!cameraConfigured) 
        {
          Camera.Parameters parameters=camera.getParameters();
          Camera.Size size=getBestPreviewSize(width, height, parameters);

          if (size!=null) 
          {
            parameters.setPreviewSize(size.width, size.height);
            camera.setParameters(parameters);
            cameraConfigured=true;
          }
        }
      }
    }

    private void startPreview() 
    {
      if (cameraConfigured && camera!=null) 
      {
        camera.startPreview();
        inPreview=true;
      }
    }

    SurfaceHolder.Callback surfaceCallback=new SurfaceHolder.Callback() 
    {
      public void surfaceCreated(SurfaceHolder holder) 
      {
        // no-op -- wait until surfaceChanged()
      }

      public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) 
      {
        initPreview(width, height);
        startPreview();
      }

      public void surfaceDestroyed(SurfaceHolder holder) 
      {
        // no-op
      }
    };

    public void initialize(Context c)
    {
        //Log.e("initialize", "Setting content view");
        //setContentView(R.layout.main);
        //Log.e("initialize", "Content View Set");
        //Log.e("initialize", "Initialization started");
        //preview=(SurfaceView)this.findViewById(R.id.preview);
        //Log.e("initialize", "preview set");
        //previewHolder=preview.getHolder();
        //previewHolder.addCallback(surfaceCallback);
        //previewHolder.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
        //Log.e("initialize", "holder set");
        //colorREDsum = 0;
    }

}

完全性の問題として、メールの送信に使用するクラスも投稿しています。

package com.lyo.android.CameraSender5;

import java.util.Date; 
import java.util.Properties; 
import javax.activation.CommandMap; 
import javax.activation.DataHandler; 
import javax.activation.DataSource; 
import javax.activation.FileDataSource; 
import javax.activation.MailcapCommandMap; 
import javax.mail.BodyPart; 
import javax.mail.Multipart; 
import javax.mail.PasswordAuthentication; 
import javax.mail.Session; 
import javax.mail.Transport; 
import javax.mail.internet.InternetAddress; 
import javax.mail.internet.MimeBodyPart; 
import javax.mail.internet.MimeMessage; 
import javax.mail.internet.MimeMultipart; 
import javax.mail.Authenticator;
import javax.mail.PasswordAuthentication;

import android.os.Bundle;
import android.util.Log;
import android.widget.TextView;
import android.widget.Toast;

public class Mail extends javax.mail.Authenticator 
{ 
  private String _user; 
  private String _pass; 

  private String[] _to; 
  private String _from; 

  private String _port; 
  private String _sport; 

  private String _host; 

  private String _subject; 
  private String _body; 

  private boolean _auth; 

  private boolean _debuggable; 

  private Multipart _multipart; 


  public Mail() 
  { 
    _host = "smtp.gmail.com"; // default smtp server 
    _port = "465"; // default smtp port 
    _sport = "465"; // default socketfactory port 

    _user = "*****@gmail.com"; // username 
    _pass = "*****"; // password 
    _from = "*****@gmail.com"; // email sent from 
    _subject = "Ciao Ciao"; // email subject 
    _body = "You never know... :)"; // email body 

    _debuggable = false; // debug mode on or off - default off 
    _auth = true; // smtp authentication - default on 

    _multipart = new MimeMultipart(); 

    // There is something wrong with MailCap, javamail can not find a handler for the multipart/mixed part, so this bit needs to be added. 
    MailcapCommandMap mc = (MailcapCommandMap) CommandMap.getDefaultCommandMap(); 
    mc.addMailcap("text/html;; x-java-content-handler=com.sun.mail.handlers.text_html"); 
    mc.addMailcap("text/xml;; x-java-content-handler=com.sun.mail.handlers.text_xml"); 
    mc.addMailcap("text/plain;; x-java-content-handler=com.sun.mail.handlers.text_plain"); 
    mc.addMailcap("multipart/*;; x-java-content-handler=com.sun.mail.handlers.multipart_mixed"); 
    mc.addMailcap("message/rfc822;; x-java-content-handler=com.sun.mail.handlers.message_rfc822"); 
    CommandMap.setDefaultCommandMap(mc); 
  } 

  public Mail(String user, String pass) { 
    this(); 

    _user = user; 
    _pass = pass; 
  } 

  //mie

  public Session sessionFCN()
  {
      Properties props = _setProperties();
      Session session;
    try {
        Log.e("SESSION","TRYING Session.getInstance");
        session = Session.getInstance(props, new GMailAuthenticator("*****@gmail.com", "*****"));
    return session;
    } catch (Exception e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
        Log.e("SESSION","ERROR WITH Session.getInstance");
    }
      //DUMMY
    session = Session.getInstance(props, new GMailAuthenticator("*****@gmail.com", "*****"));
    return session;
  }

  class GMailAuthenticator extends Authenticator {
         String user;
         String pw;
         public GMailAuthenticator (String username, String password)
         {
            super();
            this.user = username;
            this.pw = password;
         }
        public PasswordAuthentication getPasswordAuthentication()
        {
           return new PasswordAuthentication(user, pw);
        }
    }

  //stop mie

  public boolean send() throws Exception { 
    Properties props = _setProperties(); 

    if(!"*****@gmail.com".equals("") && !"*****".equals("") && _to.length > 0 && !"*****@gmail.com".equals("") && !"Ciao Ciao".equals("") && !"You never know... :)".equals("")) 
    { 

      Session session = Session.getInstance(props, this); 
      MimeMessage msg = new MimeMessage(session); 
      msg.setFrom(new InternetAddress("*****@gmail.com")); //_from
      InternetAddress[] addressTo = new InternetAddress[_to.length]; 
      for (int i = 0; i < _to.length; i++) 
      { 
        addressTo[i] = new InternetAddress(_to[i]); 
      } 
      msg.setRecipients(MimeMessage.RecipientType.TO, addressTo); 
      msg.setSubject("Ciao Ciao"); 
      msg.setSentDate(new Date()); 
      //

      // setup message body 
      BodyPart messageBodyPart = new MimeBodyPart();  
      messageBodyPart.setText("You never know... :)"); //_body
      _multipart.addBodyPart(messageBodyPart); 

      // Put parts in message 
      msg.setContent(_multipart); 

      // send email 
      Transport.send(msg); 

      return true; 
    } 
    else 
    { 
      return false; 
    } 
  } 

  //You can call this method at any time if you want to add an attachment, but make sure you call it before the send method.
  public void addAttachment(String filename) throws Exception 
  { 
    BodyPart messageBodyPart = new MimeBodyPart(); 
    DataSource source = new FileDataSource(filename); 
    messageBodyPart.setDataHandler(new DataHandler(source)); 
    messageBodyPart.setFileName(filename); 

    _multipart.addBodyPart(messageBodyPart); 
  } 

  @Override 
  public PasswordAuthentication getPasswordAuthentication() 
  { 
    return new PasswordAuthentication(_user, _pass); 
  } 

  public Properties _setProperties() //private
  { 
    Properties props = new Properties(); 

    props.put("mail.smtp.host", _host); 

    if(_debuggable) 
    { 
      props.put("mail.debug", "true"); 
    } 

    if(_auth) 
    { 
      props.put("mail.smtp.auth", "true"); 
    } 

    props.put("mail.smtp.port", _port); 
    props.put("mail.smtp.socketFactory.port", _sport); 
    props.put("mail.smtp.socketFactory.class", "javax.net.ssl.SSLSocketFactory"); 
    props.put("mail.smtp.socketFactory.fallback", "false"); 

    return props; 
  } 

  // the getters and setters 
  public String getBody() 
  { 
    return _body; 
  } 

  public void setBody(String _body) 
  { 
    this._body = _body; 
  } 

  // more of the getters and setters ….. 
  public void setTo(String[] toArr) 
  {
    this._to = toArr;
  }

  public void setFrom(String string) 
  {
    this._from = string;
  }

  public void setSubject(String string) 
  {
    this._subject = string;
  } 
  };

Log.e メッセージのおかげで、カメラ = Camera.open(); でエラーが発生していることがわかりました。以下は、Eclipse から取得した LogCat です。

08-03 22:00:24.135: E/onCreate(1817): onCreate started
08-03 22:00:24.205: E/onCreate(1817): ContentView set
08-03 22:00:24.215: E/onCreate(1817): TakePic called
08-03 22:00:24.215: E/onCreate(1817): Initialized
08-03 22:00:27.295: E/LYO TakePic onCreate(1817): Setting content view
08-03 22:00:27.305: E/LYO TakePic onCreate(1817): Content View Set
08-03 22:00:27.305: E/LYO TakePic onCreate(1817): Initialization started
08-03 22:00:27.305: E/LYO TakePic onCreate(1817): preview set
08-03 22:00:27.305: E/LYO TakePic onCreate(1817): holder set
08-03 22:00:27.305: E/LYO TakePic onResume(1817): CAMERA NULL
08-03 22:00:27.305: E/LYO TakePic onResume(1817): onResume Start
08-03 22:00:27.325: E/AndroidRuntime(1817): FATAL EXCEPTION: main
08-03 22:00:27.325: E/AndroidRuntime(1817): java.lang.RuntimeException: Unable to resume activity {com.lyo.android.CameraSender5/com.lyo.android.CameraSender5.TakePic}: java.lang.RuntimeException: Fail to connect to camera service
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3128)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.app.ActivityThread.handleResumeActivity(ActivityThread.java:3143)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2684)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.app.ActivityThread.access$2300(ActivityThread.java:125)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.os.Handler.dispatchMessage(Handler.java:99)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.os.Looper.loop(Looper.java:123)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.app.ActivityThread.main(ActivityThread.java:4627)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at java.lang.reflect.Method.invokeNative(Native Method)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at java.lang.reflect.Method.invoke(Method.java:521)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at dalvik.system.NativeStart.main(Native Method)
08-03 22:00:27.325: E/AndroidRuntime(1817): Caused by: java.lang.RuntimeException: Fail to connect to camera service
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.hardware.Camera.native_setup(Native Method)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.hardware.Camera.<init>(Camera.java:110)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.hardware.Camera.open(Camera.java:90)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at com.lyo.android.CameraSender5.TakePic.onResume(TakePic.java:107)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.app.Instrumentation.callActivityOnResume(Instrumentation.java:1149)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.app.Activity.performResume(Activity.java:3823)
08-03 22:00:27.325: E/AndroidRuntime(1817):     at android.app.ActivityThread.performResumeActivity(ActivityThread.java:3118)
08-03 22:00:27.325: E/AndroidRuntime(1817):     ... 12 more

ご覧のとおり、カメラがまだ使用されていないことを確認するために、呼び出す前にカメラを解放/ロック解除しようとしていますが、それでも同じエラーが発生します...何が間違っていますか?

よろしくお願いします。

4

2 に答える 2

0

私はこの投稿に出くわしましたが、彼/彼女のコメントを読むまでOPが解決したかどうかは明確ではありませんでした。これは将来のつまずきのためにのみ投稿しています(賛成票/反対票はありません)。


ユーザーのコメントによると:

なんとかうまくいく方法を見つけました。TakePic.java問題は、メインのアクティビティから適切に呼び出していなかったことです。

それ以外の:

startActivity(new Intent("com.lyo.android.TAKEPIC")); 

以下を使用する必要があります。

final Intent takePic = new Intent(this, TakePic.class);
takePic.setFlags(Intent.FLAG_ACTIVITY_MULTIPLE_TASK);
takePic.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 
startActivity(takePic); 

これを再帰的に呼び出すとまだ問題がありましたが、タイマー自体をTakePic.java

于 2013-03-08T20:44:12.877 に答える
0

なんとかうまくいく方法を見つけました。TakePic.java問題は、メインのアクティビティから適切に呼び出していなかったことです。それ以外の:

startActivity(new Intent("com.lyo.android.TAKEPIC")); 

私は以下を使用する必要があります:

final Intent takePic = new Intent(this, TakePic.class);
takePic.setFlags(Intent.FLAG_ACTIVITY_MULTIPLE_TASK);
takePic.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK); 
startActivity(takePic); 

これを再帰的に呼び出すとまだ問題がありましたが、タイマー自体をTakePic.java

于 2015-05-27T21:30:00.503 に答える