9
votes

I'm new to Javascript and React. I would like to embed OpenCV.js into a basic React.js web app to build an online client-side document scanner (I already have the image processing pipeline developped in Python).

I used yarn create react-app to get a basic working React sandbox containing : App.js which is the main React component and index.js which plugs it into the DOM. I added a custom imageProcessing.js file that will contain my image processing pipeline. A yarn start command is available to compile everything and display the result in my browser.

In order to use OpenCV in this pipeline, I downloaded opencv.js from official page, put it next to imageProcessing.js and finally called it through const cv = require('../lib/opencv'). The problem is the yarn start command compiles sources for hours and it is clearly not possible to develop anything.

Now my question is : how to efficiently compile my web app with that heavy opencv.js (13MB) in my sources ? Is their a better way of integrating the lib ?

Thanks for your help !

1
Include opencv.js as <script> in your index.html instead.Chris G
Thanks, Chris G. I'm really sorry for my huge misunderstanding of these language but now i have a ` <script async src="../src/lib/opencv.js" type="text/javascript"></script>` in my HTML file, how should i import it in my imageProcessing.js in order to use for instance cv.imread() in it ?fweber
If imageProcessing.js gets bundled by webpack, you need to put /* global cv */ at the top. This should allow you to use cv in your scripts without lint complaining about cv being undefined.Chris G
@fewber did you find solution can you post your code?thug_

1 Answers

0
votes

You could use a cdn instead of using locally this way react won't bother you. (but make sure that you don't have/have sufficient data limit because opencv.js is a heavy library & it'll request everytime when you reload page...) but you can store that library in catch with PWA so that it'll store opencv.js in browser's cache & whenever you reload page it'll send cached file instead of request 1000s of times... & obviously it'll reduce bandwidth usage & other point is you can use their functions methods in useEffect or outside component function

// opencv.js code here

function App(props){...}

OR

function App(props){
    useEffect(() => {

    // opencv.js code here

    }, [])
}

make sure to let the user know that some heavy loading in background running while loading the opencv.js file...