2016-12-07 60 views
0

JavafxとOpenCVを使用して、ワイヤレスでWebカメラ(Axis M1013)にアクセスしてFRCチームのビジョン処理を実行しようとしています。コードを実行すると、Scenebuilderを使って作成したGUIにアクセスできますが、カメラを起動しようとするとプログラムがクラッシュします。 VideoCaptureクラスを利用するのに問題があるようです。私はブラウザのフィードを介してフィードにアクセスできるので、私の問題はカメラではないという事実を知っています。私のラップトップのウェブカメラは正常に動作します。私は、JDK 8u101x64をOpevCVバージョン2.4.13を使用して、そして私が他の記事を見てきました3.2OpenCVでIPカメラにアクセスできない

をffmpegのよ:

stackoverflow.com/questions/18625948/opencv-java-unsatisfiedlinkerror

の回答私が言及した解決策を試してみました.opencv.org /質問/ 21720/javaの - ウェブカメラキャプチャ

answers.opencv.org/question/20071/unsatisfiedlinkerror-given-by-highghuiimread-on-java

これらのすべて。これまでのところ、誰も私の問題を解決していません。ここで

opencv-java-tutorials.readthedocs.io/en/latest/03-first-javafx-application-with-opencv.html

私のコードはでほとんどのチュートリアルをベースにしてい私のメインのJavaコードです:

public class SampleController { 
@FXML 
private Button Start_btn; 

@FXML 
private ImageView currentFrame; 
private ScheduledExecutorService timer; 
private VideoCapture capture; 
private boolean cameraActive = false; 

@FXML 
public void startCamera() 
{ 
    System.loadLibrary("opencv_ffmpeg_64"); 
    if (!this.cameraActive) 
    { 
     try 
     { 
     capture = new VideoCapture("http://FRC:[email protected]:554/mjpg/1/video.mjpg"); 
     } 
     catch (Exception e) 
     { 
      System.out.println("an error occured when attempting to access camera."); 
     } 
     // is the video stream available? 
     if (this.capture.isOpened()) 
     { 
      this.cameraActive = true; 

      // grab a frame every 33 ms (30 frames/sec) 
      Runnable frameGrabber = new Runnable() { 

       @Override 
       public void run() 
       { 
        // effectively grab and process a single frame 
        Mat frame = grabFrame(); 
        // convert and show the frame 
        Image imageToShow = Utils.mat2Image(frame); 
        updateImageView(currentFrame, imageToShow); 
       } 
      }; 

      this.timer = Executors.newSingleThreadScheduledExecutor(); 
      this.timer.scheduleAtFixedRate(frameGrabber, 0, 33, TimeUnit.MILLISECONDS); 

      // update the button content 
      this.Start_btn.setText("Stop Camera"); 
     } 
     else 
     { 
      // log the error 
      System.err.println("Impossible to open the camera connection..."); 
     } 
    } 
    else 
    { 
     // the camera is not active at this point 
     this.cameraActive = false; 
     // update again the button content 
     this.Start_btn.setText("Start Camera"); 

     // stop the timer 
     this.stopAquisition(); 
    } 

    System.out.println("Camera is now on."); 
} 

/** 
* Get frame from open video 
* @return 
*/ 
    private Mat grabFrame() 

    { 
     Mat frame = new Mat(); 
     if (this.capture.isOpened()) 
     { 
      try 
      { 
       this.capture.read(frame); 

       } 
     catch (Exception e) 
     { 
      System.err.println("Exception during the image elaboration: " + e); 
     } 
    } 
    return frame; 
} 
    private void stopAquisition() 
    { 
     if (this.timer!=null && !this.timer.isShutdown()) 
     { 
      try 
      { 
       this.timer.shutdown(); 
       this.timer.awaitTermination(33, TimeUnit.MILLISECONDS); 
      } 
      catch (InterruptedException e) 
      { 
       System.err.println("Exception in stopping the frame capture, trying to release camera now..." + e); 

      } 
     } 
     if (this.capture.isOpened()) 
     { 
      this.capture.release(); 
     } 
    } 
    private void updateImageView(ImageView view, Image image) 
    { 
     Utils.onFXThread(view.imageProperty(), image); 
    } 
    protected void setClosed() 
    { 
     this.stopAquisition(); 
    } 
} 

Whを:

@Override 
public void start(Stage primaryStage) { 
    System.load("C:\\opencv\\build\\x64\\vc12\\bin\\opencv_ffmpeg_64.dll"); 
    try { 
     FXMLLoader loader = new FXMLLoader(getClass().getResource("Sample.fxml")); 
     BorderPane root = (BorderPane) loader.load(); 
     Scene scene = new Scene(root, 400, 400); 
     scene.getStylesheets().add(getClass().getResource("application.css").toExternalForm()); 
     primaryStage.setScene(scene); 
     primaryStage.show(); 
    } catch(Exception e) { 
     System.out.println("error opening camera gui"); 
    } 
} 

public static void main(String[] args) { 
    launch(args); 
} 

そしてここでは、私のカメラコントローラがあります私が試してみて、私は前に述べたように、これを実行する途中、GUIが起動しますが、私がしようとカメラを開いたとき、私は、エラーメッセージが表示されます。

Exception in thread "JavaFX Application Thread" java.lang.RuntimeException: java.lang.reflect.InvocationTargetException 
at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1774) 
at javafx.fxml.FXMLLoader$ControllerMethodEventHandler.handle(FXMLLoader.java:1657) 
at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:86) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191) 
at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74) 
at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:49) 
at javafx.event.Event.fireEvent(Event.java:198) 
at javafx.scene.Node.fireEvent(Node.java:8411) 
at javafx.scene.control.Button.fire(Button.java:185) 
at com.sun.javafx.scene.control.behavior.ButtonBehavior.mouseReleased(ButtonBehavior.java:182) 
at com.sun.javafx.scene.control.skin.BehaviorSkinBase$1.handle(BehaviorSkinBase.java:96) 
at com.sun.javafx.scene.control.skin.BehaviorSkinBase$1.handle(BehaviorSkinBase.java:89) 
at com.sun.javafx.event.CompositeEventHandler$NormalEventHandlerRecord.handleBubblingEvent(CompositeEventHandler.java:218) 
at com.sun.javafx.event.CompositeEventHandler.dispatchBubblingEvent(CompositeEventHandler.java:80) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:238) 
at com.sun.javafx.event.EventHandlerManager.dispatchBubblingEvent(EventHandlerManager.java:191) 
at com.sun.javafx.event.CompositeEventDispatcher.dispatchBubblingEvent(CompositeEventDispatcher.java:59) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:58) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.BasicEventDispatcher.dispatchEvent(BasicEventDispatcher.java:56) 
at com.sun.javafx.event.EventDispatchChainImpl.dispatchEvent(EventDispatchChainImpl.java:114) 
at com.sun.javafx.event.EventUtil.fireEventImpl(EventUtil.java:74) 
at com.sun.javafx.event.EventUtil.fireEvent(EventUtil.java:54) 
at javafx.event.Event.fireEvent(Event.java:198) 
at javafx.scene.Scene$MouseHandler.process(Scene.java:3757) 
at javafx.scene.Scene$MouseHandler.access$1500(Scene.java:3485) 
at javafx.scene.Scene.impl_processMouseEvent(Scene.java:1762) 
at javafx.scene.Scene$ScenePeerListener.mouseEvent(Scene.java:2494) 
at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:380) 
at com.sun.javafx.tk.quantum.GlassViewEventHandler$MouseEventNotification.run(GlassViewEventHandler.java:294) 
at java.security.AccessController.doPrivileged(Native Method) 
at com.sun.javafx.tk.quantum.GlassViewEventHandler.lambda$handleMouseEvent$354(GlassViewEventHandler.java:416) 
at com.sun.javafx.tk.quantum.QuantumToolkit.runWithoutRenderLock(QuantumToolkit.java:389) 
at com.sun.javafx.tk.quantum.GlassViewEventHandler.handleMouseEvent(GlassViewEventHandler.java:415) 
at com.sun.glass.ui.View.handleMouseEvent(View.java:555) 
at com.sun.glass.ui.View.notifyMouse(View.java:937) 
at com.sun.glass.ui.win.WinApplication._runLoop(Native Method) 
at com.sun.glass.ui.win.WinApplication.lambda$null$148(WinApplication.java:191) 
at java.lang.Thread.run(Unknown Source) 
Caused by: java.lang.reflect.InvocationTargetException 
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
at java.lang.reflect.Method.invoke(Unknown Source) 
at sun.reflect.misc.Trampoline.invoke(Unknown Source) 
at sun.reflect.GeneratedMethodAccessor1.invoke(Unknown Source) 
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
at java.lang.reflect.Method.invoke(Unknown Source) 
at sun.reflect.misc.MethodUtil.invoke(Unknown Source) 
at javafx.fxml.FXMLLoader$MethodHandler.invoke(FXMLLoader.java:1771) 
... 48 more 
Caused by: java.lang.UnsatisfiedLinkError:  org.opencv.highgui.VideoCapture.VideoCapture_1(Ljava/lang/String;)J 
at org.opencv.highgui.VideoCapture.VideoCapture_1(Native Method) 
at org.opencv.highgui.VideoCapture.<init>(VideoCapture.java:128) 
at jfxtest1.SampleController.startCamera(SampleController.java:36) 
... 58 more 

誰も私を助けることができる場合は、はるかに高く評価されるだろうという。

ありがとうございます。

public static void main(String[] args) { 
    // load the native OpenCV library 
    System.loadLibrary(Core.NATIVE_LIBRARY_NAME);    
    launch(args); 
} 
:あなたのメインのJavaコードで

答えて

0

は、これを持っている必要があります
関連する問題