Функция StartPreview медленная, любая работа?

Проблема:

Я делаю приложение на Android, который требует быстрой реакции с камеры во время съемки изображений, я заметил медленное поведение Из приложения, после измерения времени я заметил, что функция StartPreview () является ответственным за проблему.

Предварительный просмотр кода:

Это необходимая часть кода (связанная с проблемой).

Previewgoogle Класс (пользовательский превью): В начале приложения вызывается SurfaceChanged, я устанавливаю несколько параметров камеры, которые затем называется CARTPREVIEW

public class PreviewGoogle extends ViewGroup implements SurfaceHolder.Callback {
    private final String TAG = "myapp1";
    Camera mCamera;

    public void surfaceChanged(SurfaceHolder holder, int format, int w, int h) {
        try
        {
            // Now that the size is known, set up the camera parameters and begin
            // the preview.
            Camera.Parameters parameters = mCamera.getParameters();

            parameters.setFlashMode(Camera.Parameters.FLASH_MODE_OFF);
            parameters.setFocusMode(Camera.Parameters.FOCUS_MODE_INFINITY);
            parameters.setWhiteBalance(Camera.Parameters.WHITE_BALANCE_AUTO);
            parameters.setSceneMode(Camera.Parameters.SCENE_MODE_AUTO);
            parameters.setJpegQuality(100);
            parameters.setPictureSize(Globals.CAMERA_WIDTH, Globals.CAMERA_HEIGHT);

            requestLayout();
            mCamera.setParameters(parameters);

            long before = System.currentTimeMillis();
            mCamera.startPreview();
            long after = System.currentTimeMillis();

            Log.d(TAG, "PreviewGoogle, surfaceChanged: startPreview took " + (after - before) + " ms");
        }
        catch (Exception e) {
            Log.d(TAG, "PreviewGoogle, surfaceChanged: " + e.getMessage());
        }
    }
}

Classhoogle Class: в этом классе я позвонил STARTPREVIEW на RawImageCallback, потому что я использую растровое производство в JPEGCallback (не надо)

public class PhotoShootActivity extends Activity
{
    private static final String TAG = "myapp1";
    PreviewGoogle preview;

    // Handles data for raw picture
    PictureCallback rawCallback = new PictureCallback()
    {
        public void onPictureTaken(byte[] data, Camera camera)
        {
            try
            {
                long before = System.currentTimeMillis();
                preview.getCamera().startPreview();
                long after = System.currentTimeMillis();

                Log.d(PhotoShootActivity.TAG, "PhotoShootActivity, rawCallback: preview started in " + (after - before) + " ms");
            }
            catch(Exception e)
            {
                Log.e(TAG, "PhotoShootActivity, rawCallback: " + e.getMessage());
            }
        }
    };
}

номера таймеров были такими:

09-09 10:58:42.336: DEBUG/myapp1(21958): PhotoShootActivity, onCreate
**09-09 10:58:44.396: DEBUG/myapp1(21958): PreviewGoogle, surfaceChanged: startPreview took 1457 ms**
09-09 10:58:48.438: DEBUG/myapp1(21958): PhotoShootActivity, buttonCapture: Picture taken in 65ms
09-09 10:58:48.496: DEBUG/myapp1(21958): PhotoShootActivity, shutterCallback: Empty
**09-09 10:58:49.790: DEBUG/myapp1(21958): PhotoShootActivity, rawCallback: preview started in 662 ms**

Первый стартовый отправитель занял ~ 1500 мс, а второй занял 662 мс !!!

Искали решение:

Вопрос, который я ищу, не полный код (просто подсказки меня :)), я подумал, что я мог бы что-то упустить в предварительном просмотре, и я думал об использовании нитей в этом Случай, но я пока не знаком с Android-SDK (я начал с программирования Android 4 дней назад)

С уважением ...

8
задан Ayman Kouzayha 9 September 2011 в 09:05
поделиться