summaryrefslogtreecommitdiff
path: root/include/media-thumbnail.h
blob: ab68c4a7fa1be756d2574af259f142928a533d73 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
/*
 * libmedia-thumbnail
 *
 * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
 *
 * Contact: Hyunjun Ko <zzoon.ko@samsung.com>
 *
 * 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.
 *
 */


#ifndef _MEDIA_THUMBNAIL_H_
#define _MEDIA_THUMBNAIL_H_

#include "media-thumb-types.h"
#include "media-thumb-error.h"

#ifdef __cplusplus
extern "C" {
#endif


/**
	@defgroup	THUMB_GENERATE	Thumbnail generator
	 @{
	  * @file			media-thumbnail.h
	  * @brief		This file defines API's for thumbnail generator.
	  * @version	 	1.0
 */

/**
        @defgroup THUMB_API    Thumbnail generator API
        @{

        @par
        generates thumbnail data and return the path of the generated thumbnail file.
 */


/**
 *	thumbnail_request_from_db:
 * 	This function connects to the media database and find thumbnail path of the passed original image. 
 *  If found, the thumbnail path will be returned, or starts to generate thumbnail
 *
 *	@return		This function returns zero(MEDIA_THUMB_ERROR_NONE) on success, or negative value with error code.
 *				Please refer 'media-thumb-error.h' to know the exact meaning of the error.
 *  @param[in]				origin_path      The path of the original image
 *  @param[out]				thumb_path       The path of generated thumbnail image.
 *  @param[in]				max_length       The max length of the returned thumbnail path.
 *	@see		None.
 *	@pre		None.
 *	@post		None.
 *	@remark	The database name is "/opt/dbspace/.media.db".
 * 	@par example
 * 	@code

#include <media-thumbnail.h>

void gen_thumbs()
{
	int ret = MEDIA_THUMB_ERROR_NONE;
	const char *origin_path = "/opt/media/test.jpg";
	char thumb_path[255];

	ret = thumbnail_request_from_db(origin_path, thumb_path, 255);

	if (ret < 0)
	{
		printf( "thumbnail_request_from_db fails. error code->%d", ret);
	}

	return;
}

 * 	@endcode
 */
int thumbnail_request_from_db(const char *origin_path, char *thumb_path, int max_length);

/**
 *	thumbnail_request_save_to_file:
 * 	This function generates thumbnail of the original path and save it to the file system as jpeg format with the passed thumbnail path.
 *  This function doesn't care about media DB.
 *
 *	@return		This function returns zero(MEDIA_THUMB_ERROR_NONE) on success, or negative value with error code.
 *				Please refer 'media-thumb-error.h' to know the exact meaning of the error.
 *  @param[in]				origin_path      The path of the original image
 *  @param[in]				thumb_type       The type of the returned thumbnail data.
 *  @param[in]				thumb_path       The path of generated thumbnail image.
 *	@see		None.
 *	@pre		None.
 *	@post		None.
 * 	@par example
 * 	@code

#include <media-thumbnail.h>

void save_thumbs()
{
	int ret = MEDIA_THUMB_ERROR_NONE;
	const char *origin_path = "/opt/media/test.jpg";
	const char *thumb_path = "/my_dir/thumb.jpg";

	ret = thumbnail_request_save_to_file(origin_path, thumb_path);

	if (ret < 0) {
		printf( "thumbnail_request_save_to_file fails. error code->%d", ret);
	}

	return;
}

 * 	@endcode
 */
int thumbnail_request_save_to_file(const char *origin_path,
									media_thumb_type thumb_type,
									const char *thumb_path);





/** @} */

/**
	@}
 */

#ifdef __cplusplus
}
#endif

#endif /*_MEDIA_THUMBNAIL_H_*/