Move qt_cam_copy_register to QtCamera
[harmattan/cameraplus] / lib / qtcamdevice_p.h
index 2699ba3..c8c09fb 100644 (file)
@@ -43,6 +43,7 @@ public:
     cameraBin(0),
     videoSource(0),
     wrapperVideoSource(0),
+    sink(0),
     image(0),
     video(0),
     active(0),
@@ -55,7 +56,7 @@ public:
   }
 
   GstElement *createAndAddElement(const QString& elementName, const char *prop, const char *name) {
-    GstElement *elem = gst_element_factory_make(elementName.toAscii(), name);
+    GstElement *elem = gst_element_factory_make(elementName.toLatin1(), name);
     if (!elem) {
       qWarning() << "Failed to create" << elementName;
       return 0;
@@ -105,22 +106,18 @@ public:
     if (videoSource) {
       if (conf->deviceScannerType() == SCANNER_TYPE_ENUM) {
        int dev = id.toInt();
-       g_object_set(videoSource, conf->deviceScannerProperty().toAscii().constData(), dev, NULL);
+       g_object_set(videoSource, conf->deviceScannerProperty().toLatin1().constData(), dev, NULL);
       }
       else {
        QString dev = id.toString();
-       g_object_set(videoSource, conf->deviceScannerProperty().toAscii().constData(),
-                    dev.toAscii().constData(), NULL);
+       g_object_set(videoSource, conf->deviceScannerProperty().toLatin1().constData(),
+                    dev.toLatin1().constData(), NULL);
       }
     }
   }
 
   bool setViewfinderSink() {
-    GstElement *sink = 0;
-    g_object_get(cameraBin, "viewfinder-sink", &sink, NULL);
-
     if (sink) {
-      gst_object_unref(sink);
       return true;
     }
 
@@ -173,7 +170,7 @@ public:
   void setAudioCaptureCaps() {
     QString captureCaps = conf->audioCaptureCaps();
     if (!captureCaps.isEmpty()) {
-      GstCaps *caps = gst_caps_from_string(captureCaps.toAscii().data());
+      GstCaps *caps = gst_caps_from_string(captureCaps.toLatin1().data());
       if (caps) {
        g_object_set(cameraBin, "audio-capture-caps", caps, NULL);
        gst_caps_unref(caps);
@@ -181,13 +178,18 @@ public:
     }
   }
 
-  bool isWrapperReady() {
-    if (!wrapperVideoSource) {
+  bool isReadyForCapture() {
+    GstElement *src = videoSource;
+    if (wrapperVideoSource) {
+      src = wrapperVideoSource;
+    }
+
+    if (!src) {
       return false;
     }
 
     gboolean ready = FALSE;
-    g_object_get(wrapperVideoSource, "ready-for-capture", &ready, NULL);
+    g_object_get(src, "ready-for-capture", &ready, NULL);
 
     return ready == TRUE;
   }
@@ -220,6 +222,7 @@ public:
   GstElement *cameraBin;
   GstElement *videoSource;
   GstElement *wrapperVideoSource;
+  GstElement *sink;
 
   QtCamImageMode *image;
   QtCamVideoMode *video;