Subversion Repositories seema-scanner

Rev

Rev 1 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
1 jakw 1
#include "CameraIIDC.h"
2
#include <cstring>
3
 
4
vector<CameraInfo> CameraIIDC::getCameraList(){
5
 
6
    dc1394_t *context = dc1394_new();
7
 
8
    dc1394camera_list_t *camera_list;
9
    dc1394error_t err;
10
    err = dc1394_camera_enumerate(context, &camera_list);
11
    DC1394_WRN(err,"libdc1394: Failed to enumerate cameras!");
12
 
13
    vector<CameraInfo> ret;
14
 
15
    for (unsigned int i=0; i<camera_list->num; i++) {
16
        CameraInfo info;
17
        dc1394camera_t *cam;
18
        cam = dc1394_camera_new(context, camera_list->ids[i].guid);
19
 
20
        //info.vendor = std::string(cam->vendor ? cam->vendor : "");
21
        info.vendor = "IIDC";
22
        info.model = string(cam->model ? cam->model : "");
23
        info.busID = (unsigned int)cam->guid;
24
 
25
        dc1394_camera_free(cam);
26
        ret.push_back(info);
27
    }
28
 
29
    dc1394_camera_free_list(camera_list);
30
    dc1394_free(context);
31
 
32
    return ret;
33
}
34
 
18 jakw 35
CameraIIDC::CameraIIDC(unsigned int camNum, CameraTriggerMode triggerMode) : Camera(triggerMode) {
1 jakw 36
 
37
    context = dc1394_new();
38
 
39
    dc1394camera_list_t *camera_list;
40
    dc1394error_t err;
41
    err = dc1394_camera_enumerate(context, &camera_list);
42
 
18 jakw 43
    if(camNum+1 > camera_list->num){
1 jakw 44
        cerr << "libdc1394: Selected camera is not available!";
45
        return;
46
    }
47
 
48
    cam = NULL;
49
 
18 jakw 50
    cam = dc1394_camera_new(context, camera_list->ids[camNum].guid);
1 jakw 51
    if(!cam){
52
        cerr << "libdc1394: Could not open camera!";
53
        return;
54
    }
55
 
56
    dc1394_camera_free_list(camera_list);
57
 
58
//    // Get video modes
59
//    dc1394video_modes_t video_modes;
60
//    err=dc1394_video_get_supported_modes(cam, &video_modes);
61
//    DC1394_WRN(err,"Can't get video modes");
62
//    // Select highest res mode
63
//    int i;
64
//    dc1394color_coding_t coding;
65
//    for (i=video_modes.num-1;i>=0;i--) {
66
//        if (!dc1394_is_video_mode_scalable(video_modes.modes[i])) {
67
//            dc1394_get_color_coding_from_video_mode(cam, video_modes.modes[i], &coding);
68
//            DC1394_WRN(err,"libdc1394: Could not get color coding");
69
//            if (coding==DC1394_COLOR_CODING_MONO8) {
70
//                video_mode=video_modes.modes[i];
71
//                break;
72
//            }
73
//        }
74
//    }
75
//    if (i < 0) {
76
//        cerr << "libdc1394: Could not get a valid gray scale mode!";
77
//        return;
78
//    }
79
 
80
    // Select format 7 mode 0
81
    video_mode = DC1394_VIDEO_MODE_FORMAT7_0;
82
 
18 jakw 83
    // Set bit depth
84
    err = dc1394_format7_set_color_coding(cam, video_mode, DC1394_COLOR_CODING_MONO16);
1 jakw 85
    if (err!=DC1394_SUCCESS)
18 jakw 86
        cerr << "libdc1394: Could not set video mode or color coding!";
1 jakw 87
 
18 jakw 88
//    // Set video mode
89
//    err=dc1394_video_set_mode(cam, video_mode);
90
//    if (err!=DC1394_SUCCESS)
91
//        cerr << "libdc1394: Could not set video mode!";
92
 
1 jakw 93
    // Setup capture
94
    err=dc1394_video_set_operation_mode(cam, DC1394_OPERATION_MODE_1394B);
95
    if (err!=DC1394_SUCCESS)
96
        cerr << "libdc1394: Could not set operation mode!";
97
 
98
    err=dc1394_video_set_iso_speed(cam, DC1394_ISO_SPEED_800);
99
    if (err!=DC1394_SUCCESS)
100
        cerr << "libdc1394: Could not set iso speed!";
101
 
102
    // Size of ringbuffer (Note: on OS X 10.9, size must be greater than 1)
103
#ifdef __APPLE__
104
    unsigned int bufferSize = 2;
105
#else
106
    unsigned int bufferSize = 1;
107
#endif
108
 
109
    err=dc1394_capture_setup(cam, bufferSize, DC1394_CAPTURE_FLAGS_DEFAULT);
110
    if (err!=DC1394_SUCCESS)
111
        cerr << "libdc1394: Could not set up camera!";
112
 
113
    // Disable auto exposure mode
114
    dc1394_feature_set_power(cam, DC1394_FEATURE_EXPOSURE, DC1394_OFF);
115
 
116
    // Disable gamma mode
117
    dc1394_feature_set_power(cam, DC1394_FEATURE_GAMMA, DC1394_OFF);
118
 
119
    // Disable sharpness mode
120
    dc1394_feature_set_power(cam, DC1394_FEATURE_SHARPNESS, DC1394_OFF);
121
 
122
    // Disable frame-rate mode
123
    dc1394_feature_set_power(cam, DC1394_FEATURE_FRAME_RATE, DC1394_OFF);
124
 
125
    // Set manual settings
126
    dc1394_feature_set_mode(cam, DC1394_FEATURE_SHUTTER, DC1394_FEATURE_MODE_MANUAL);
127
    dc1394_feature_set_mode(cam, DC1394_FEATURE_GAIN, DC1394_FEATURE_MODE_MANUAL);
128
 
129
 
130
    // Set reasonable default settings
131
    CameraSettings settings;
132
    //settings.shutter = 8.333;
133
    settings.shutter = 16.66;
134
    settings.gain = 0.0;
135
    this->setCameraSettings(settings);
136
 
137
    // Print camera features and settings
138
    dc1394featureset_t features;
139
    err=dc1394_feature_get_all(cam, &features);
140
    DC1394_WRN(err, "libdc1394: Could not get feature set.");
141
    dc1394_feature_print_all(&features, stdout);
142
    fflush(stdout);
143
 
144
    return;
145
}
146
 
18 jakw 147
 
148
unsigned int getSetting(dc1394camera_t *cam, dc1394feature_t setting){
149
    dc1394error_t err;
150
    unsigned int value;
151
    err = dc1394_feature_get_value(cam, setting, &value);
152
    if(err != DC1394_SUCCESS)
153
        cerr << "Could not get setting!" << endl;
154
 
155
    return value;
156
}
157
 
158
CameraSettings CameraIIDC::getCameraSettings(){
159
 
160
    // Get settings:
161
    CameraSettings settings;
162
    settings.gain = getSetting(cam, DC1394_FEATURE_GAIN);
163
    settings.shutter = getSetting(cam, DC1394_FEATURE_SHUTTER);
164
 
165
    return settings;
166
}
167
 
168
void setSetting(dc1394camera_t *cam, dc1394feature_t setting, float value){
169
    dc1394error_t err;
170
    float min, max;
171
    dc1394_feature_get_absolute_boundaries(cam, setting, &min, &max);
172
    if(value < min || value > max){
173
        std::cerr << "CameraIIDC: cannot set value. Out of permissable range." << std::endl;
174
    } else {
175
        err = dc1394_feature_set_absolute_control(cam, setting, DC1394_ON);
176
        if(err != DC1394_SUCCESS)
177
            cerr << "Could not enable absolute control!" << endl;
178
        err = dc1394_feature_set_absolute_value(cam, setting, value);
179
        if(err != DC1394_SUCCESS)
180
            cerr << "Could not set absolute value!" << endl;
181
    }
182
}
183
 
184
void CameraIIDC::setCameraSettings(CameraSettings settings){
185
 
186
    // Set settings:
187
    setSetting(cam, DC1394_FEATURE_GAIN, settings.gain);
188
    setSetting(cam, DC1394_FEATURE_SHUTTER, settings.shutter/1000.0); // [ms]
189
}
190
 
191
 
1 jakw 192
void CameraIIDC::startCapture(){
193
 
194
    dc1394error_t err;
195
 
18 jakw 196
    // Print camera information
197
    dc1394_camera_print_info(cam, stdout);
198
    fflush(stdout);
1 jakw 199
 
18 jakw 200
    if(triggerMode == triggerModeHardware){
1 jakw 201
 
18 jakw 202
        // Set hardware trigger
203
        err=dc1394_external_trigger_set_power(cam, DC1394_ON);
204
        if (err!=DC1394_SUCCESS)
205
            cerr << "libdc1394: Could not set external trigger on!";
1 jakw 206
 
18 jakw 207
        err=dc1394_external_trigger_set_source(cam, DC1394_TRIGGER_SOURCE_0);
208
        if (err!=DC1394_SUCCESS)
209
            cerr << "libdc1394: Could not set external trigger source!";
1 jakw 210
 
18 jakw 211
        err=dc1394_external_trigger_set_mode(cam, DC1394_TRIGGER_MODE_14);
212
        if (err!=DC1394_SUCCESS)
213
            cerr << "libdc1394: Could not set external trigger mode!";
214
 
215
        err=dc1394_external_trigger_set_polarity(cam, DC1394_TRIGGER_ACTIVE_HIGH);
216
        if (err!=DC1394_SUCCESS)
217
            cerr << "libdc1394: Could not set external trigger polarity!";
218
 
219
    } else if(triggerMode == triggerModeSoftware) {
220
 
221
        // Disable hardware trigger
222
        err=dc1394_external_trigger_set_power(cam, DC1394_OFF);
223
        if (err!=DC1394_SUCCESS)
224
            cerr << "libdc1394: Could not set external trigger off!";
225
 
226
    }
227
 
1 jakw 228
    // Begin transmission
229
	err = dc1394_video_set_transmission(cam, DC1394_ON);
230
	if (err!=DC1394_SUCCESS)
231
	{
232
		cerr << "ERROR: Could not begin transmission!" << endl;
233
	}    
234
 
235
    capturing = true;
236
}
237
 
238
void CameraIIDC::stopCapture(){
239
 
240
    dc1394error_t err;
241
 
242
    err = dc1394_video_set_transmission(cam, DC1394_OFF);
243
    err = dc1394_capture_stop(cam);
244
 
18 jakw 245
//    // Disable trigger
246
//    err=dc1394_external_trigger_set_power(cam, DC1394_OFF);
247
//    if (err!=DC1394_SUCCESS)
248
//        cerr << "libdc1394: Could not set external trigger on!";
1 jakw 249
 
250
    capturing = false;
251
}
252
 
18 jakw 253
CameraFrame CameraIIDC::getFrame(){
1 jakw 254
 
255
    CameraFrame frame;
256
 
257
    if (!capturing) {
258
        cerr << "ERROR: Not capturing on camera. Call startCapture() before lockFrame()." << endl;
259
        return frame;
260
    }
261
 
262
    dc1394error_t err;
263
 
18 jakw 264
    if(triggerMode == triggerModeSoftware){
265
 
266
        if (cam->one_shot_capable != DC1394_TRUE){
267
            cerr << "ERROR: Camera is not one_shot_capable." << endl;
268
            return frame;
269
        }
270
 
271
        dc1394error_t err;
272
 
273
        // Flush the ring buffer
274
        flushBuffer();
275
 
276
        // One-shot trigger
277
        err == dc1394_video_set_one_shot(cam, DC1394_ON);
278
 
279
    }
280
 
281
    // Get frame from ring buffer:
1 jakw 282
    err = dc1394_capture_dequeue(cam, DC1394_CAPTURE_POLICY_WAIT, &currentFrame);
283
    if (err!=DC1394_SUCCESS){
284
        cerr << "ERROR: Could not capture a frame." << endl;
285
        return frame;
18 jakw 286
    }
287
 
288
    // Return the frame to the ring buffer:
289
    dc1394_capture_enqueue(cam, currentFrame);
290
    currentFrame = NULL;
291
 
1 jakw 292
    // Copy frame address and properties
18 jakw 293
    frame.memory = (unsigned short*)currentFrame->image;
1 jakw 294
    frame.width = currentFrame->size[0];
295
    frame.height = currentFrame->size[1];
18 jakw 296
    frame.bitDepth = 16;
1 jakw 297
    frame.sizeBytes = currentFrame->image_bytes;
298
 
299
    return frame;
300
}
301
 
302
void CameraIIDC::flushBuffer(){
303
    // This function is courtesy of ofxVideoGrabber/Libdc1394Grabber
304
    bool bufferEmpty = false;
305
 
306
    while (!bufferEmpty){
307
        if(dc1394_capture_dequeue(cam, DC1394_CAPTURE_POLICY_POLL, &currentFrame) == DC1394_SUCCESS){
308
            if(currentFrame != NULL){
309
                dc1394_capture_enqueue(cam, currentFrame);
310
            } else {
311
                bufferEmpty = true;
312
            }
313
        } else {
314
            bufferEmpty = true;
315
        }
316
    }
317
}
318
 
319
 
320
size_t CameraIIDC::getFrameSizeBytes(){
321
    if (!capturing) {
322
        cerr << "ERROR: Cannot get frame size before capturing. Call startCapture() before getFrameSizeBytes()." << endl;
323
        return 0;
324
    }
325
 
326
//    dc1394video_frame_t *frame = NULL;
327
//    dc1394error_t err;
328
 
329
//	// Get frame from ring buffer:
330
//    err = dc1394_capture_dequeue(cam, DC1394_CAPTURE_POLICY_WAIT, &frame);
331
//    err = dc1394_capture_enqueue(cam, frame);
332
 
333
//    return frame->image_bytes;
334
    uint64_t total_bytes;
335
    dc1394_format7_get_total_bytes(cam, video_mode, &total_bytes);
336
 
337
    return total_bytes;
338
}
339
 
18 jakw 340
size_t CameraIIDC::getFrameWidth(){
1 jakw 341
    uint32_t _width, _height;
342
    dc1394_get_image_size_from_video_mode(cam, video_mode, &_width, &_height);
18 jakw 343
    return _width;
1 jakw 344
}
345
 
346
 
18 jakw 347
size_t CameraIIDC::getFrameHeight(){
348
    uint32_t _width, _height;
349
    dc1394_get_image_size_from_video_mode(cam, video_mode, &_width, &_height);
350
    return _height;
1 jakw 351
}
352
 
353
 
354
CameraIIDC::~CameraIIDC(){
355
    // Stop camera transmission
356
    if(capturing)
357
        stopCapture();
358
    else
359
        dc1394_capture_stop(cam);
360
 
361
    // Gracefulle destruct the camera
362
    dc1394_camera_free(cam);
363
    dc1394_free(context);
364
}
365
 
366
 
367