MM_ATTRS_VALID_TYPE_INT_ARRAY,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_camera_format,
},
{
MM_CAM_CAMERA_RECORDING_MOTION_RATE,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = 1},
- NULL,
+ _mmcamcorder_commit_camera_fps,
},
{
MM_CAM_CAMERA_DELAY_ATTR_SETTING,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = _MMCAMCORDER_MAX_INT},
- NULL,
+ _mmcamcorder_commit_encoder_bitrate,
},
/* 40 */
{
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = _MMCAMCORDER_MAX_INT},
- NULL,
+ _mmcamcorder_commit_encoder_bitrate,
},
{
MM_CAM_IMAGE_ENCODER_QUALITY,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = _MMCAMCORDER_MAX_INT},
- NULL,
+ _mmcamcorder_commit_recording_max_limit,
},
{
MM_CAM_TARGET_TIME_LIMIT,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = _MMCAMCORDER_MAX_INT},
- NULL,
+ _mmcamcorder_commit_recording_max_limit,
},
{
MM_CAM_TAG_ENABLE,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = 1},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_IMAGE_DESCRIPTION,
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_ORIENTATION,
MM_ATTRS_VALID_TYPE_INT_ARRAY,
{tag_orientation_values},
{ARRAY_SIZE(tag_orientation_values)},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_SOFTWARE,
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
/* 70 */
{
MM_ATTRS_VALID_TYPE_DOUBLE_RANGE,
{.double_min = -360.0},
{.double_max = 360.0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_LONGITUDE,
MM_ATTRS_VALID_TYPE_DOUBLE_RANGE,
{.double_min = -360.0},
{.double_max = 360.0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_ALTITUDE,
MM_ATTRS_VALID_TYPE_DOUBLE_RANGE,
{.double_min = -999999.0},
{.double_max = 999999.0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_STROBE_CONTROL,
MM_ATTRS_VALID_TYPE_INT_RANGE,
{.int_min = 0},
{.int_max = 1},
- NULL,
+ _mmcamcorder_commit_tag,
},
/* 90 */
{
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_GPS_DATE_STAMP,
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_TAG_GPS_PROCESSING_METHOD,
MM_ATTRS_VALID_TYPE_NONE,
{0},
{0},
- NULL,
+ _mmcamcorder_commit_tag,
},
{
MM_CAM_CAMERA_ROTATION,
MMHandleType attr = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_return_val_if_fail(handle && value, FALSE);
+
attr = MMF_CAMCORDER_ATTRS(handle);
mmf_return_val_if_fail(attr, FALSE);
bool _mmcamcorder_commit_capture_break_cont_shot(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
- int current_state = _mmcamcorder_get_state(handle);
- int ivalue = value->value.i_val;
-
- mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+ int current_state = 0;
+ int ivalue = 0;
+ const char *videosrc_name = NULL;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- GstCameraControl *control = NULL;
- type_element *VideosrcElement = NULL;
+ GstCameraControl *control = NULL;
+ type_element *VideosrcElement = NULL;
- const char *videosrc_name = NULL;
+ mmf_return_val_if_fail(handle && value, FALSE);
+
+ current_state = _mmcamcorder_get_state(handle);
+ ivalue = value->value.i_val;
_mmcamcorder_conf_get_element(handle, hcamcorder->conf_main,
CONFIGURE_CATEGORY_MAIN_VIDEO_INPUT,
{
int mode = MM_CAMCORDER_MODE_VIDEO_CAPTURE;
int current_state = MM_CAMCORDER_STATE_NONE;
-
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
mm_camcorder_get_attributes(handle, NULL, MMCAM_MODE, &mode, NULL);
{
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
_mmcam_dbg_log("shutter sound policy: %d", hcamcorder->shutter_sound_policy);
_MMCamcorderSubContext *sc = NULL;
bool bret = FALSE;
+ mmf_return_val_if_fail(handle && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
}
+bool _mmcamcorder_commit_camera_format(MMHandleType handle, int attr_idx, const mmf_value_t *value)
+{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+ int current_state = MM_CAMCORDER_STATE_NONE;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state > MM_CAMCORDER_STATE_READY) {
+ _mmcam_dbg_err("invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ return TRUE;
+}
+
+
bool _mmcamcorder_commit_camera_fps(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
MMCamAttrsInfo fps_info;
int resolution_width = 0;
int resolution_height = 0;
- int i;
- int ret;
+ int i = 0;
+ int ret = 0;
+ int current_state = MM_CAMCORDER_STATE_NONE;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state > MM_CAMCORDER_STATE_PREPARE) {
+ _mmcam_dbg_err("invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ if (attr_idx == MM_CAM_CAMERA_FPS_AUTO)
+ return TRUE;
_mmcam_dbg_log("FPS(%d)", value->value.i_val);
}
_mmcam_dbg_err("FAILED : %d is not supported FPS", value->value.i_val);
+
return FALSE;
}
bool _mmcamcorder_commit_camera_recording_motion_rate(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
-
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_warn("invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_log("Resolution can't be changed.(state=%d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else {
int width = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(hcamcorder, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_err("Video Resolution can't be changed.(state=%d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else {
_mmcam_dbg_warn("Video Resolution %d [attr_idx %d] ",
bool _mmcamcorder_commit_camera_zoom(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
GstCameraControl *control = NULL;
- int zoom_level = value->value.i_val;
- int zoom_type;
+ int zoom_level = 0;
+ int zoom_type = 0;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
+ zoom_level = value->value.i_val;
+
_mmcam_dbg_log("(%d)", attr_idx);
current_state = _mmcamcorder_get_state(handle);
_mmcam_dbg_log("will be applied when preview starts");
return TRUE;
} else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
- _mmcam_dbg_warn("Can not set while CAPTURING");
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_ptz_type(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
const GList *controls = NULL;
const GList *item = NULL;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
mmf_return_val_if_fail(sc, TRUE);
if (current_state < MM_CAMCORDER_STATE_PREPARE ||
current_state == MM_CAMCORDER_STATE_CAPTURING) {
_mmcam_dbg_err("invalid state[%d]", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_pan(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
const GList *controls = NULL;
const GList *item = NULL;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
mmf_return_val_if_fail(sc, TRUE);
if (current_state < MM_CAMCORDER_STATE_PREPARE ||
current_state == MM_CAMCORDER_STATE_CAPTURING) {
_mmcam_dbg_err("invalid state[%d]", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_tilt(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
const GList *controls = NULL;
const GList *item = NULL;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
mmf_return_val_if_fail(sc, TRUE);
if (current_state < MM_CAMCORDER_STATE_PREPARE ||
current_state == MM_CAMCORDER_STATE_CAPTURING) {
_mmcam_dbg_err("invalid state[%d]", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
{
MMHandleType attr = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
GstCameraControl *control = NULL;
int mslVal;
int cur_focus_mode = 0;
int cur_focus_range = 0;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
attr = MMF_CAMCORDER_ATTRS(handle);
mmf_return_val_if_fail(attr, FALSE);
if (current_state < MM_CAMCORDER_STATE_NULL) {
_mmcam_dbg_log("Focus mode will be changed later.(state=%d)", current_state);
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
if (sc->element[_MMCAMCORDER_VIDEOSRC_SRC].gst) {
bool _mmcamcorder_commit_camera_af_scan_range(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
GstCameraControl *control = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
int msl_mode = MM_CAMCORDER_FOCUS_MODE_NONE;
int converted_mode = 0;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
if (current_state < MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_log("It doesn't need to change dynamically.(state=%d)", current_state);
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
if (sc->element[_MMCAMCORDER_VIDEOSRC_SRC].gst) {
bool _mmcamcorder_commit_camera_af_touch_area(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
GstCameraControl *control = NULL;
GstCameraControlRectType set_area = { 0, 0, 0, 0 };
MMCamAttrsInfo info_w;
MMCamAttrsInfo info_h;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
if (current_state < MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_log("It doesn't need to change dynamically.(state=%d)", current_state);
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
ret = mm_camcorder_get_attributes(handle, NULL,
bool _mmcamcorder_commit_camera_capture_mode(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
GstCameraControl *control = NULL;
- int ivalue = value->value.i_val;
- int mslVal1 = 0, mslVal2 = 0;
- int newVal1 = 0, newVal2 = 0;
+ int ivalue = 0;
+ int mslVal1 = 0;
+ int mslVal2 = 0;
+ int newVal1 = 0;
+ int newVal2 = 0;
int exposure_type = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int scene_mode = MM_CAMCORDER_SCENE_MODE_NORMAL;
gboolean check_scene_mode = FALSE;
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
}
current_state = _mmcamcorder_get_state(handle);
- if (current_state < MM_CAMCORDER_STATE_READY)
+ if (current_state < MM_CAMCORDER_STATE_READY) {
+ _mmcam_dbg_log("will be applied when preview starts");
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ ivalue = value->value.i_val;
if (attr_idx == MM_CAM_CAMERA_F_NUMBER) {
exposure_type = GST_CAMERA_CONTROL_F_NUMBER;
int mslVal = 0;
int newVal = 0;
int cur_value = 0;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
int current_state = MM_CAMCORDER_STATE_NONE;
- mmf_return_val_if_fail(handle && value, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check whether set or not */
if (!_mmcamcorder_check_supported_attribute(handle, attr_idx)) {
_mmcam_dbg_log("will be applied when preview starts");
return TRUE;
} else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
- _mmcam_dbg_warn("Can not set while CAPTURING");
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_anti_handshake(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check whether set or not */
if (!_mmcamcorder_check_supported_attribute(handle, attr_idx)) {
return TRUE;
} else if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_err("Invaild state (state %d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
}
+bool _mmcamcorder_commit_encoder_bitrate(MMHandleType handle, int attr_idx, const mmf_value_t *value)
+{
+ int audio_enc = 0;
+ int bitrate = 0;
+ int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+ _MMCamcorderSubContext *sc = NULL;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
+ bitrate = value->value.i_val;
+
+ sc = MMF_CAMCORDER_SUBCONTEXT(handle);
+ if (!sc || !sc->encode_element) {
+ _mmcam_dbg_log("will be applied later - idx %d, bitrate %d", attr_idx, bitrate);
+ return TRUE;
+ }
+
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state >= MM_CAMCORDER_STATE_RECORDING) {
+ _mmcam_dbg_err("Can not set while RECORDING - attr idx %d", attr_idx);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ if (attr_idx == MM_CAM_AUDIO_ENCODER_BITRATE) {
+ mm_camcorder_get_attributes(handle, NULL, MMCAM_AUDIO_ENCODER, &audio_enc, NULL);
+
+ _mmcamcorder_set_encoder_bitrate(MM_CAMCORDER_ENCODER_TYPE_AUDIO, audio_enc,
+ bitrate, sc->encode_element[_MMCAMCORDER_ENCSINK_AENC].gst);
+ } else {
+ _mmcamcorder_set_encoder_bitrate(MM_CAMCORDER_ENCODER_TYPE_VIDEO, 0,
+ bitrate, sc->encode_element[_MMCAMCORDER_ENCSINK_VENC].gst);
+ }
+
+ return TRUE;
+}
+
+
bool _mmcamcorder_commit_camera_video_stabilization(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
if (current_state < MM_CAMCORDER_STATE_READY) {
return TRUE;
} else if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_err("Invaild state (state %d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_camera_rotate(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
_mmcam_dbg_log("rotate(%d)", value->value.i_val);
if (current_state > MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_err("camera rotation setting failed.(state=%d)", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else {
return _mmcamcorder_set_videosrc_rotation(handle, value->value.i_val);
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
if (current_state < MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_log("NOT initialized. this will be applied later");
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
bool _mmcamcorder_commit_target_filename(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
_MMCamcorderSubContext *sc = NULL;
- const char * filename = NULL;
+ const char *filename = NULL;
int size = 0;
+ mmf_return_val_if_fail(handle && value, FALSE);
+
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
}
+bool _mmcamcorder_commit_recording_max_limit(MMHandleType handle, int attr_idx, const mmf_value_t *value)
+{
+ int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state >= MM_CAMCORDER_STATE_RECORDING) {
+ _mmcam_dbg_err("Can not set while RECORDING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ return TRUE;
+}
bool _mmcamcorder_commit_filter(MMHandleType handle, int attr_idx, const mmf_value_t *value)
int scene_mode = MM_CAMCORDER_SCENE_MODE_NORMAL;
gboolean check_scene_mode = FALSE;
- if (hcamcorder == NULL) {
- _mmcam_dbg_log("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
_mmcam_dbg_log("will be applied when preview starts");
return TRUE;
} else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
- _mmcam_dbg_warn("Can not set while CAPTURING");
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
bool _mmcamcorder_commit_filter_scene_mode(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ int mslVal = 0;
+ int newVal = 0;
+ int current_state = MM_CAMCORDER_STATE_NONE;
GstCameraControl *control = NULL;
- int mslVal = value->value.i_val;
- int newVal = _mmcamcorder_convert_msl_to_sensor(handle, MM_CAM_FILTER_SCENE_MODE, mslVal);
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- int current_state = MM_CAMCORDER_STATE_NONE;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
return TRUE;
+ mslVal = value->value.i_val;
+ newVal = _mmcamcorder_convert_msl_to_sensor(handle, MM_CAM_FILTER_SCENE_MODE, mslVal);
+
/* check whether set or not */
if (!_mmcamcorder_check_supported_attribute(handle, attr_idx)) {
_mmcam_dbg_log("skip set value %d", value->value.i_val);
if (current_state < MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_log("It doesn't need to change dynamically.(state=%d)", current_state);
return TRUE;
+ } else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
}
if (sc->element[_MMCAMCORDER_VIDEOSRC_SRC].gst) {
bool _mmcamcorder_commit_filter_flip(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_return_val_if_fail(handle && value, FALSE);
+
_mmcam_dbg_warn("Filter Flip(%d)", value->value.i_val);
+
return TRUE;
}
bool _mmcamcorder_commit_audio_input_route(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
+ mmf_return_val_if_fail(handle && value, FALSE);
+
_mmcam_dbg_log("Commit : Do nothing. this attr will be removed soon.");
+
return TRUE;
}
bool _mmcamcorder_commit_audio_disable(MMHandleType handle, int attr_idx, const mmf_value_t *value)
{
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_warn("Can NOT Disable AUDIO. invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else {
_mmcam_dbg_log("Disable AUDIO when Recording");
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- mmf_return_val_if_fail(handle, FALSE);
+ mmf_return_val_if_fail(handle && value, FALSE);
/* check type */
if (hcamcorder->type == MM_CAMCORDER_MODE_AUDIO) {
int strobe_type, mslVal, newVal, cur_value;
int current_state = MM_CAMCORDER_STATE_NONE;
- if (hcamcorder == NULL) {
- _mmcam_dbg_err("NULL handle");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
_mmcam_dbg_log("It doesn't need to change dynamically.(state=%d)", current_state);
return TRUE;
} else if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
- _mmcam_dbg_warn("invalid state[capturing]");
+ _mmcam_dbg_err("Can not set while CAPTURING");
hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
{
int ret = 0;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
_mmcam_dbg_log("Commit : flip %d", value->value.i_val);
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_err("Can not set camera FLIP horizontal at state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
} else if (current_state < MM_CAMCORDER_STATE_READY) {
_mmcam_dbg_log("Pipeline is not created yet. This will be set when create pipeline.");
{
int set_hdr_mode = MM_CAMCORDER_HDR_OFF;
int current_state = MM_CAMCORDER_STATE_NONE;
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
_MMCamcorderSubContext *sc = NULL;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/*_mmcam_dbg_log("Commit : HDR Capture %d", value->value.i_val);*/
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_PREPARE) {
_mmcam_dbg_err("can NOT set HDR capture at state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
int current_state = MM_CAMCORDER_STATE_NONE;
GstCameraControl *control = NULL;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(handle && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc)
int current_state = MM_CAMCORDER_STATE_NONE;
int preview_format = MM_PIXEL_FORMAT_NV12;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(handle && value, FALSE);
_mmcam_dbg_log("Commit : encoded preview bitrate - %d", value->value.i_val);
int current_state = MM_CAMCORDER_STATE_NONE;
int preview_format = MM_PIXEL_FORMAT_NV12;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(handle && value, FALSE);
_mmcam_dbg_log("Commit : encoded preview I-frame interval - %d", value->value.i_val);
int current_state = MM_CAMCORDER_STATE_NONE;
mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
- if (hcamcorder == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
/* state check */
current_state = _mmcamcorder_get_state(handle);
if (current_state > MM_CAMCORDER_STATE_NULL) {
_mmcam_dbg_log("invalid state %d", current_state);
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
return FALSE;
}
int stream_type_len = 0;
_MMCamcorderSubContext *sc = NULL;
- if ((void *)handle == NULL) {
- _mmcam_dbg_warn("handle is NULL");
- return FALSE;
- }
+ mmf_return_val_if_fail(handle && value, FALSE);
sc = MMF_CAMCORDER_SUBCONTEXT(handle);
if (!sc || !sc->encode_element ||
}
+bool _mmcamcorder_commit_tag(MMHandleType handle, int attr_idx, const mmf_value_t *value)
+{
+ mmf_camcorder_t *hcamcorder = MMF_CAMCORDER(handle);
+ int current_state = MM_CAMCORDER_STATE_NONE;
+
+ mmf_return_val_if_fail(hcamcorder && value, FALSE);
+
+ current_state = _mmcamcorder_get_state(handle);
+ if (current_state == MM_CAMCORDER_STATE_CAPTURING) {
+ _mmcam_dbg_err("Can not set while CAPTURING");
+ hcamcorder->error_code = MM_ERROR_CAMCORDER_INVALID_STATE;
+ return FALSE;
+ }
+
+ return TRUE;
+}
+
+
static bool __mmcamcorder_attrs_is_supported(MMHandleType handle, int idx)
{
mmf_attrs_t *attr = (mmf_attrs_t*)handle;