816 lines
28 KiB
C++
816 lines
28 KiB
C++
/*
|
|
**
|
|
** Copyright 2008, The Android Open Source Project
|
|
**
|
|
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
** you may not use this file except in compliance with the License.
|
|
** You may obtain a copy of the License at
|
|
**
|
|
** http://www.apache.org/licenses/LICENSE-2.0
|
|
**
|
|
** Unless required by applicable law or agreed to in writing, software
|
|
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
** See the License for the specific language governing permissions and
|
|
** limitations under the License.
|
|
*/
|
|
|
|
//#define LOG_NDEBUG 0
|
|
#define LOG_TAG "IMediaRecorder"
|
|
|
|
#include <inttypes.h>
|
|
#include <unistd.h>
|
|
|
|
#include <utils/Log.h>
|
|
#include <binder/Parcel.h>
|
|
#include <camera/android/hardware/ICamera.h>
|
|
#include <camera/ICameraRecordingProxy.h>
|
|
#include <media/IMediaRecorderClient.h>
|
|
#include <media/IMediaRecorder.h>
|
|
#include <gui/Surface.h>
|
|
#include <gui/IGraphicBufferProducer.h>
|
|
#include <media/stagefright/PersistentSurface.h>
|
|
|
|
namespace android {
|
|
|
|
enum {
|
|
RELEASE = IBinder::FIRST_CALL_TRANSACTION,
|
|
INIT,
|
|
CLOSE,
|
|
SET_INPUT_SURFACE,
|
|
QUERY_SURFACE_MEDIASOURCE,
|
|
RESET,
|
|
STOP,
|
|
START,
|
|
PREPARE,
|
|
GET_MAX_AMPLITUDE,
|
|
SET_VIDEO_SOURCE,
|
|
SET_AUDIO_SOURCE,
|
|
SET_OUTPUT_FORMAT,
|
|
SET_VIDEO_ENCODER,
|
|
SET_AUDIO_ENCODER,
|
|
SET_OUTPUT_FILE_FD,
|
|
SET_NEXT_OUTPUT_FILE_FD,
|
|
SET_VIDEO_SIZE,
|
|
SET_VIDEO_FRAMERATE,
|
|
SET_PARAMETERS,
|
|
SET_PREVIEW_SURFACE,
|
|
SET_CAMERA,
|
|
SET_LISTENER,
|
|
SET_CLIENT_NAME,
|
|
PAUSE,
|
|
RESUME,
|
|
GET_METRICS,
|
|
SET_INPUT_DEVICE,
|
|
GET_ROUTED_DEVICE_ID,
|
|
ENABLE_AUDIO_DEVICE_CALLBACK,
|
|
GET_ACTIVE_MICROPHONES,
|
|
GET_PORT_ID,
|
|
GET_RTP_DATA_USAGE,
|
|
SET_PREFERRED_MICROPHONE_DIRECTION,
|
|
SET_PREFERRED_MICROPHONE_FIELD_DIMENSION,
|
|
SET_PRIVACY_SENSITIVE,
|
|
GET_PRIVACY_SENSITIVE
|
|
};
|
|
|
|
class BpMediaRecorder: public BpInterface<IMediaRecorder>
|
|
{
|
|
public:
|
|
explicit BpMediaRecorder(const sp<IBinder>& impl)
|
|
: BpInterface<IMediaRecorder>(impl)
|
|
{
|
|
}
|
|
|
|
status_t setCamera(const sp<hardware::ICamera>& camera, const sp<ICameraRecordingProxy>& proxy)
|
|
{
|
|
ALOGV("setCamera(%p,%p)", camera.get(), proxy.get());
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeStrongBinder(IInterface::asBinder(camera));
|
|
data.writeStrongBinder(IInterface::asBinder(proxy));
|
|
remote()->transact(SET_CAMERA, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setInputSurface(const sp<PersistentSurface>& surface)
|
|
{
|
|
ALOGV("setInputSurface(%p)", surface.get());
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
surface->writeToParcel(&data);
|
|
remote()->transact(SET_INPUT_SURFACE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
sp<IGraphicBufferProducer> querySurfaceMediaSource()
|
|
{
|
|
ALOGV("Query SurfaceMediaSource");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(QUERY_SURFACE_MEDIASOURCE, data, &reply);
|
|
int returnedNull = reply.readInt32();
|
|
if (returnedNull) {
|
|
return NULL;
|
|
}
|
|
return interface_cast<IGraphicBufferProducer>(reply.readStrongBinder());
|
|
}
|
|
|
|
status_t setPreviewSurface(const sp<IGraphicBufferProducer>& surface)
|
|
{
|
|
ALOGV("setPreviewSurface(%p)", surface.get());
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeStrongBinder(IInterface::asBinder(surface));
|
|
remote()->transact(SET_PREVIEW_SURFACE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t init()
|
|
{
|
|
ALOGV("init");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(INIT, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setVideoSource(int vs)
|
|
{
|
|
ALOGV("setVideoSource(%d)", vs);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(vs);
|
|
remote()->transact(SET_VIDEO_SOURCE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setAudioSource(int as)
|
|
{
|
|
ALOGV("setAudioSource(%d)", as);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(as);
|
|
remote()->transact(SET_AUDIO_SOURCE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setPrivacySensitive(bool privacySensitive)
|
|
{
|
|
ALOGV("%s(%s)", __func__, privacySensitive ? "true" : "false");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(privacySensitive ? 1 : 0);
|
|
status_t status = remote()->transact(SET_PRIVACY_SENSITIVE, data, &reply);
|
|
if (status != NO_ERROR) {
|
|
return status;
|
|
}
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t isPrivacySensitive(bool *privacySensitive) const
|
|
{
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
*privacySensitive = false;
|
|
status_t status = remote()->transact(GET_PRIVACY_SENSITIVE, data, &reply);
|
|
if (status != NO_ERROR) {
|
|
return status;
|
|
}
|
|
status = reply.readInt32();
|
|
if (status == NO_ERROR) {
|
|
*privacySensitive = reply.readInt32() == 1;
|
|
}
|
|
ALOGV("%s status %d enabled: %s", __func__, status, *privacySensitive ? "true" : "false");
|
|
return status;
|
|
}
|
|
|
|
status_t setOutputFormat(int of)
|
|
{
|
|
ALOGV("setOutputFormat(%d)", of);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(of);
|
|
remote()->transact(SET_OUTPUT_FORMAT, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setVideoEncoder(int ve)
|
|
{
|
|
ALOGV("setVideoEncoder(%d)", ve);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(ve);
|
|
remote()->transact(SET_VIDEO_ENCODER, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setAudioEncoder(int ae)
|
|
{
|
|
ALOGV("setAudioEncoder(%d)", ae);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(ae);
|
|
remote()->transact(SET_AUDIO_ENCODER, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setOutputFile(int fd) {
|
|
ALOGV("setOutputFile(%d)", fd);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeFileDescriptor(fd);
|
|
remote()->transact(SET_OUTPUT_FILE_FD, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setNextOutputFile(int fd) {
|
|
ALOGV("setNextOutputFile(%d)", fd);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeFileDescriptor(fd);
|
|
remote()->transact(SET_NEXT_OUTPUT_FILE_FD, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setVideoSize(int width, int height)
|
|
{
|
|
ALOGV("setVideoSize(%dx%d)", width, height);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(width);
|
|
data.writeInt32(height);
|
|
remote()->transact(SET_VIDEO_SIZE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setVideoFrameRate(int frames_per_second)
|
|
{
|
|
ALOGV("setVideoFrameRate(%d)", frames_per_second);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(frames_per_second);
|
|
remote()->transact(SET_VIDEO_FRAMERATE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setParameters(const String8& params)
|
|
{
|
|
ALOGV("setParameter(%s)", params.string());
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeString8(params);
|
|
remote()->transact(SET_PARAMETERS, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setListener(const sp<IMediaRecorderClient>& listener)
|
|
{
|
|
ALOGV("setListener(%p)", listener.get());
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeStrongBinder(IInterface::asBinder(listener));
|
|
remote()->transact(SET_LISTENER, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setClientName(const String16& clientName)
|
|
{
|
|
ALOGV("setClientName(%s)", String8(clientName).string());
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeString16(clientName);
|
|
remote()->transact(SET_CLIENT_NAME, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t prepare()
|
|
{
|
|
ALOGV("prepare");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(PREPARE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t getMaxAmplitude(int* max)
|
|
{
|
|
ALOGV("getMaxAmplitude");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(GET_MAX_AMPLITUDE, data, &reply);
|
|
*max = reply.readInt32();
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t getMetrics(Parcel* reply)
|
|
{
|
|
ALOGV("getMetrics");
|
|
Parcel data;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
status_t ret = remote()->transact(GET_METRICS, data, reply);
|
|
if (ret == NO_ERROR) {
|
|
return OK;
|
|
}
|
|
return UNKNOWN_ERROR;
|
|
}
|
|
|
|
status_t start()
|
|
{
|
|
ALOGV("start");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(START, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t stop()
|
|
{
|
|
ALOGV("stop");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(STOP, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t reset()
|
|
{
|
|
ALOGV("reset");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(RESET, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t pause()
|
|
{
|
|
ALOGV("pause");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(PAUSE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t resume()
|
|
{
|
|
ALOGV("resume");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(RESUME, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t close()
|
|
{
|
|
ALOGV("close");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(CLOSE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t release()
|
|
{
|
|
ALOGV("release");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
remote()->transact(RELEASE, data, &reply);
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t setInputDevice(audio_port_handle_t deviceId)
|
|
{
|
|
ALOGV("setInputDevice");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(deviceId);
|
|
|
|
status_t status = remote()->transact(SET_INPUT_DEVICE, data, &reply);
|
|
if (status != OK) {
|
|
ALOGE("setInputDevice binder call failed: %d", status);
|
|
return status;
|
|
}
|
|
return reply.readInt32();;
|
|
}
|
|
|
|
audio_port_handle_t getRoutedDeviceId(audio_port_handle_t *deviceId)
|
|
{
|
|
ALOGV("getRoutedDeviceId");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
|
|
status_t status = remote()->transact(GET_ROUTED_DEVICE_ID, data, &reply);
|
|
if (status != OK) {
|
|
ALOGE("getRoutedDeviceid binder call failed: %d", status);
|
|
*deviceId = AUDIO_PORT_HANDLE_NONE;
|
|
return status;
|
|
}
|
|
|
|
status = reply.readInt32();
|
|
if (status != NO_ERROR) {
|
|
*deviceId = AUDIO_PORT_HANDLE_NONE;
|
|
} else {
|
|
*deviceId = reply.readInt32();
|
|
}
|
|
return status;
|
|
}
|
|
|
|
status_t enableAudioDeviceCallback(bool enabled)
|
|
{
|
|
ALOGV("enableAudioDeviceCallback");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeBool(enabled);
|
|
status_t status = remote()->transact(ENABLE_AUDIO_DEVICE_CALLBACK, data, &reply);
|
|
if (status != OK) {
|
|
ALOGE("enableAudioDeviceCallback binder call failed: %d, %d", enabled, status);
|
|
return status;
|
|
}
|
|
return reply.readInt32();
|
|
}
|
|
|
|
status_t getActiveMicrophones(std::vector<media::MicrophoneInfo>* activeMicrophones)
|
|
{
|
|
ALOGV("getActiveMicrophones");
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
status_t status = remote()->transact(GET_ACTIVE_MICROPHONES, data, &reply);
|
|
if (status != OK
|
|
|| (status = (status_t)reply.readInt32()) != NO_ERROR) {
|
|
return status;
|
|
}
|
|
status = reply.readParcelableVector(activeMicrophones);
|
|
return status;
|
|
}
|
|
|
|
status_t setPreferredMicrophoneDirection(audio_microphone_direction_t direction) {
|
|
ALOGV("setPreferredMicrophoneDirection(%d)", direction);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeInt32(direction);
|
|
status_t status = remote()->transact(SET_PREFERRED_MICROPHONE_DIRECTION, data, &reply);
|
|
return status == NO_ERROR ? (status_t)reply.readInt32() : status;
|
|
}
|
|
|
|
status_t setPreferredMicrophoneFieldDimension(float zoom) {
|
|
ALOGV("setPreferredMicrophoneFieldDimension(%f)", zoom);
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
data.writeFloat(zoom);
|
|
status_t status = remote()->transact(SET_PREFERRED_MICROPHONE_FIELD_DIMENSION, data, &reply);
|
|
return status == NO_ERROR ? (status_t)reply.readInt32() : status;
|
|
}
|
|
|
|
status_t getPortId(audio_port_handle_t *portId)
|
|
{
|
|
ALOGV("getPortId");
|
|
if (portId == nullptr) {
|
|
return BAD_VALUE;
|
|
}
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
status_t status = remote()->transact(GET_PORT_ID, data, &reply);
|
|
if (status != OK
|
|
|| (status = (status_t)reply.readInt32()) != NO_ERROR) {
|
|
*portId = AUDIO_PORT_HANDLE_NONE;
|
|
return status;
|
|
}
|
|
*portId = (audio_port_handle_t)reply.readInt32();
|
|
return NO_ERROR;
|
|
}
|
|
|
|
status_t getRtpDataUsage(uint64_t *bytes)
|
|
{
|
|
ALOGV("getRtpDataUsage");
|
|
if (bytes == nullptr) {
|
|
return BAD_VALUE;
|
|
}
|
|
Parcel data, reply;
|
|
data.writeInterfaceToken(IMediaRecorder::getInterfaceDescriptor());
|
|
status_t status = remote()->transact(GET_RTP_DATA_USAGE, data, &reply);
|
|
if (status != OK
|
|
|| (status = (status_t)reply.readInt32()) != NO_ERROR) {
|
|
*bytes = 0;
|
|
return status;
|
|
}
|
|
return reply.readUint64(bytes);
|
|
}
|
|
};
|
|
|
|
IMPLEMENT_META_INTERFACE(MediaRecorder, "android.media.IMediaRecorder");
|
|
|
|
// ----------------------------------------------------------------------
|
|
|
|
status_t BnMediaRecorder::onTransact(
|
|
uint32_t code, const Parcel& data, Parcel* reply,
|
|
uint32_t flags)
|
|
{
|
|
switch (code) {
|
|
case RELEASE: {
|
|
ALOGV("RELEASE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(release());
|
|
return NO_ERROR;
|
|
} break;
|
|
case INIT: {
|
|
ALOGV("INIT");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(init());
|
|
return NO_ERROR;
|
|
} break;
|
|
case CLOSE: {
|
|
ALOGV("CLOSE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(close());
|
|
return NO_ERROR;
|
|
} break;
|
|
case RESET: {
|
|
ALOGV("RESET");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(reset());
|
|
return NO_ERROR;
|
|
} break;
|
|
case STOP: {
|
|
ALOGV("STOP");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(stop());
|
|
return NO_ERROR;
|
|
} break;
|
|
case START: {
|
|
ALOGV("START");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(start());
|
|
return NO_ERROR;
|
|
} break;
|
|
case PAUSE: {
|
|
ALOGV("PAUSE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(pause());
|
|
return NO_ERROR;
|
|
} break;
|
|
case RESUME: {
|
|
ALOGV("RESUME");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(resume());
|
|
return NO_ERROR;
|
|
} break;
|
|
case PREPARE: {
|
|
ALOGV("PREPARE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(prepare());
|
|
return NO_ERROR;
|
|
} break;
|
|
case GET_MAX_AMPLITUDE: {
|
|
ALOGV("GET_MAX_AMPLITUDE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int max = 0;
|
|
status_t ret = getMaxAmplitude(&max);
|
|
reply->writeInt32(max);
|
|
reply->writeInt32(ret);
|
|
return NO_ERROR;
|
|
} break;
|
|
case GET_METRICS: {
|
|
ALOGV("GET_METRICS");
|
|
status_t ret = getMetrics(reply);
|
|
return ret;
|
|
} break;
|
|
case SET_VIDEO_SOURCE: {
|
|
ALOGV("SET_VIDEO_SOURCE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int vs = data.readInt32();
|
|
reply->writeInt32(setVideoSource(vs));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_AUDIO_SOURCE: {
|
|
ALOGV("SET_AUDIO_SOURCE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int as = data.readInt32();
|
|
reply->writeInt32(setAudioSource(as));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_PRIVACY_SENSITIVE: {
|
|
ALOGV("SET_PRIVACY_SENSITIVE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
bool privacySensitive = data.readInt32() == 1;
|
|
reply->writeInt32(setPrivacySensitive(privacySensitive));
|
|
return NO_ERROR;
|
|
} break;
|
|
case GET_PRIVACY_SENSITIVE: {
|
|
ALOGV("GET_PRIVACY_SENSITIVE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
bool privacySensitive = false;
|
|
status_t status = isPrivacySensitive(&privacySensitive);
|
|
reply->writeInt32(status);
|
|
if (status == NO_ERROR) {
|
|
reply->writeInt32(privacySensitive ? 1 : 0);
|
|
}
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_OUTPUT_FORMAT: {
|
|
ALOGV("SET_OUTPUT_FORMAT");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int of = data.readInt32();
|
|
reply->writeInt32(setOutputFormat(of));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_VIDEO_ENCODER: {
|
|
ALOGV("SET_VIDEO_ENCODER");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int ve = data.readInt32();
|
|
reply->writeInt32(setVideoEncoder(ve));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_AUDIO_ENCODER: {
|
|
ALOGV("SET_AUDIO_ENCODER");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int ae = data.readInt32();
|
|
reply->writeInt32(setAudioEncoder(ae));
|
|
return NO_ERROR;
|
|
|
|
} break;
|
|
case SET_OUTPUT_FILE_FD: {
|
|
ALOGV("SET_OUTPUT_FILE_FD");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int fd = dup(data.readFileDescriptor());
|
|
reply->writeInt32(setOutputFile(fd));
|
|
::close(fd);
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_NEXT_OUTPUT_FILE_FD: {
|
|
ALOGV("SET_NEXT_OUTPUT_FILE_FD");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int fd = dup(data.readFileDescriptor());
|
|
reply->writeInt32(setNextOutputFile(fd));
|
|
::close(fd);
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_VIDEO_SIZE: {
|
|
ALOGV("SET_VIDEO_SIZE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int width = data.readInt32();
|
|
int height = data.readInt32();
|
|
reply->writeInt32(setVideoSize(width, height));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_VIDEO_FRAMERATE: {
|
|
ALOGV("SET_VIDEO_FRAMERATE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int frames_per_second = data.readInt32();
|
|
reply->writeInt32(setVideoFrameRate(frames_per_second));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_PARAMETERS: {
|
|
ALOGV("SET_PARAMETER");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(setParameters(data.readString8()));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_LISTENER: {
|
|
ALOGV("SET_LISTENER");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
sp<IMediaRecorderClient> listener =
|
|
interface_cast<IMediaRecorderClient>(data.readStrongBinder());
|
|
reply->writeInt32(setListener(listener));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_CLIENT_NAME: {
|
|
ALOGV("SET_CLIENT_NAME");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
reply->writeInt32(setClientName(data.readString16()));
|
|
return NO_ERROR;
|
|
}
|
|
case SET_PREVIEW_SURFACE: {
|
|
ALOGV("SET_PREVIEW_SURFACE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
sp<IGraphicBufferProducer> surface = interface_cast<IGraphicBufferProducer>(
|
|
data.readStrongBinder());
|
|
reply->writeInt32(setPreviewSurface(surface));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_CAMERA: {
|
|
ALOGV("SET_CAMERA");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
sp<hardware::ICamera> camera =
|
|
interface_cast<hardware::ICamera>(data.readStrongBinder());
|
|
sp<ICameraRecordingProxy> proxy =
|
|
interface_cast<ICameraRecordingProxy>(data.readStrongBinder());
|
|
reply->writeInt32(setCamera(camera, proxy));
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_INPUT_SURFACE: {
|
|
ALOGV("SET_INPUT_SURFACE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
sp<PersistentSurface> surface = new PersistentSurface();
|
|
surface->readFromParcel(&data);
|
|
reply->writeInt32(setInputSurface(surface));
|
|
return NO_ERROR;
|
|
} break;
|
|
case QUERY_SURFACE_MEDIASOURCE: {
|
|
ALOGV("QUERY_SURFACE_MEDIASOURCE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
// call the mediaserver side to create
|
|
// a surfacemediasource
|
|
sp<IGraphicBufferProducer> surfaceMediaSource = querySurfaceMediaSource();
|
|
// The mediaserver might have failed to create a source
|
|
int returnedNull= (surfaceMediaSource == NULL) ? 1 : 0 ;
|
|
reply->writeInt32(returnedNull);
|
|
if (!returnedNull) {
|
|
reply->writeStrongBinder(IInterface::asBinder(surfaceMediaSource));
|
|
}
|
|
return NO_ERROR;
|
|
} break;
|
|
case SET_INPUT_DEVICE: {
|
|
ALOGV("SET_INPUT_DEVICE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
audio_port_handle_t deviceId;
|
|
status_t status = data.readInt32(&deviceId);
|
|
if (status == NO_ERROR) {
|
|
reply->writeInt32(setInputDevice(deviceId));
|
|
} else {
|
|
reply->writeInt32(BAD_VALUE);
|
|
}
|
|
return NO_ERROR;
|
|
} break;
|
|
case GET_ROUTED_DEVICE_ID: {
|
|
ALOGV("GET_ROUTED_DEVICE_ID");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
audio_port_handle_t deviceId;
|
|
status_t status = getRoutedDeviceId(&deviceId);
|
|
reply->writeInt32(status);
|
|
if (status == NO_ERROR) {
|
|
reply->writeInt32(deviceId);
|
|
}
|
|
return NO_ERROR;
|
|
} break;
|
|
case ENABLE_AUDIO_DEVICE_CALLBACK: {
|
|
ALOGV("ENABLE_AUDIO_DEVICE_CALLBACK");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
bool enabled;
|
|
status_t status = data.readBool(&enabled);
|
|
if (status == NO_ERROR) {
|
|
reply->writeInt32(enableAudioDeviceCallback(enabled));
|
|
} else {
|
|
reply->writeInt32(BAD_VALUE);
|
|
}
|
|
return NO_ERROR;
|
|
} break;
|
|
case GET_ACTIVE_MICROPHONES: {
|
|
ALOGV("GET_ACTIVE_MICROPHONES");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
std::vector<media::MicrophoneInfo> activeMicrophones;
|
|
status_t status = getActiveMicrophones(&activeMicrophones);
|
|
reply->writeInt32(status);
|
|
if (status != NO_ERROR) {
|
|
return NO_ERROR;
|
|
}
|
|
reply->writeParcelableVector(activeMicrophones);
|
|
return NO_ERROR;
|
|
|
|
}
|
|
case GET_PORT_ID: {
|
|
ALOGV("GET_PORT_ID");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
audio_port_handle_t portId;
|
|
status_t status = getPortId(&portId);
|
|
reply->writeInt32(status);
|
|
if (status == NO_ERROR) {
|
|
reply->writeInt32(portId);
|
|
}
|
|
return NO_ERROR;
|
|
}
|
|
case GET_RTP_DATA_USAGE: {
|
|
ALOGV("GET_RTP_DATA_USAGE");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
uint64_t bytes;
|
|
status_t status = getRtpDataUsage(&bytes);
|
|
reply->writeInt32(status);
|
|
if (status == NO_ERROR) {
|
|
reply->writeUint64(bytes);
|
|
}
|
|
return NO_ERROR;
|
|
}
|
|
case SET_PREFERRED_MICROPHONE_DIRECTION: {
|
|
ALOGV("SET_PREFERRED_MICROPHONE_DIRECTION");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
int direction = data.readInt32();
|
|
status_t status = setPreferredMicrophoneDirection(
|
|
static_cast<audio_microphone_direction_t>(direction));
|
|
reply->writeInt32(status);
|
|
return NO_ERROR;
|
|
}
|
|
case SET_PREFERRED_MICROPHONE_FIELD_DIMENSION: {
|
|
ALOGV("SET_MICROPHONE_FIELD_DIMENSION");
|
|
CHECK_INTERFACE(IMediaRecorder, data, reply);
|
|
float zoom = data.readFloat();
|
|
status_t status = setPreferredMicrophoneFieldDimension(zoom);
|
|
reply->writeInt32(status);
|
|
return NO_ERROR;
|
|
}
|
|
default:
|
|
return BBinder::onTransact(code, data, reply, flags);
|
|
}
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
|
|
} // namespace android
|