JavaCV调用摄像头如何调节分辨率?高分 求高手

求高手! 想用JavaCV获取摄像头图像并拍照,买的高分辨率的摄像头,可是拍出来的照片才55kb,远不及直接连电脑拍出来的效果,请教如何在java程序中调节分辨率
http://blog.csdn.net/sivyer123/article/details/22411861 这是示例程序

public class video
{

public static void main(String[] args) throws Exception
{

    final String savedImageFile = "d:\\my.jpg";   //拍摄所存储的文件
    OpenCVFrameGrabber grabber = new OpenCVFrameGrabber(0);  
    grabber.start();   //开始获取摄像头数据
    IplImage image =grabber.grab(); //将所获取摄像头数据放入IplImage

    int width = image.width();  
    int height = image.height();
    final BufferedImage bImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);  
    Graphics2D bGraphics = bImage.createGraphics();                       

    CanvasFrame canvas = new CanvasFrame("Camera",1);
    canvas.setCanvasSize(width, height);  

    canvas.getCanvas().addMouseListener(new MouseAdapter(){  
            public void mouseClicked(MouseEvent e){       
              try{
                 ImageIO.write(bImage, "jpg", new File(savedImageFile));//数据写入my.jpg
                 } 
              catch (IOException e1){
                // TODO Auto-generated catch block
                e1.printStackTrace();
                }  
           }
        });
   while(canvas.isVisible() && (image=grabber.grab()) != null){  
    canvas.showImage(image); 
    bGraphics.drawImage(image.getBufferedImage(),null,0,0); 
    }

        cvReleaseImage(image);     
        grabber.stop();  
        canvas.dispose();     
}

}

4个回答

参考官方的例子:https://github.com/bytedeco/javacv/blob/master/samples/WebcamAndMicrophoneCapture.java

                int captureWidth = 1280;
        int captureHeight = 720;

        // The available FrameGrabber classes include OpenCVFrameGrabber (opencv_highgui),
        // DC1394FrameGrabber, FlyCaptureFrameGrabber, OpenKinectFrameGrabber,
        // PS3EyeFrameGrabber, VideoInputFrameGrabber, and FFmpegFrameGrabber.
        OpenCVFrameGrabber grabber = new OpenCVFrameGrabber(WEBCAM_DEVICE_INDEX);
        grabber.setImageWidth(captureWidth);
        grabber.setImageHeight(captureHeight);
        grabber.start();

ak199015
ak199015 啊 兄弟 真牛啊! 这个GITHUB这么高端 我是咋搜的 我在网上找了半天没找到呢
接近 5 年之前 回复

啊 兄弟 真牛啊! 这个GITHUB这么高端 我是咋搜的 我在网上找了半天没找到呢

搜索分辨率相关的是根本搜索不到这个的;
我也是抱着试试看的态度,因为搜索分辨率根本找不到有用的信息;
所以想到去JavaCV的官网看看有没有什么帮助。

我想问下,调用摄像头获取的图像全黑是怎么回事,笔记本摄像头灯亮了,摄像头应该是启动了

qq_21221391
不会飞鹦鹉 我也遇到了,之后发现是启动的没有自己关掉
2 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
新手 javacv调用摄像头哪里错了
package com.qqJFrame.soft;import org.bytedeco.javacv.CanvasFrame;import org.bytedeco.javacv.OpenCVFrameGrabber;import javax.swing.*;/**调用窗口摄像头 * Created by asus on 2017/4/1. */public class CameraTest { public static void main(String[] args)throws Exception{ OpenCVFrameGrabber grabber=new OpenCVFrameGrabber(0); grabber.start(); CanvasFrame canvasFrame=new CanvasFrame("摄像头"); canvasFrame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); canvasFrame.setAlwaysOnTop(true); while (true){ if(!canvasFrame.isDisplayable()){ grabber.stop(); System.exit(2); } canvasFrame.showImage(grabber.grab()); Thread.sleep(50); }
Android javacv录制视频求解决思路
Android平板录制另一个机器的摄像头,捕捉画面,以及该机器麦克和Android平板的音频,录制成一个完整的视频,请问有什么好的解决思路? 我目前采用的方案的是用javacv,每当解析出数据是图片时会存在sd卡,然后读取卡中的图片加到FFmpegFrameRecorder类中录制;解析出的数据是声音时(数据是从另一个机器返回的),同样会加到FFmpegFrameRecorder类中录制;现在情况是能有视频文件,画面没问题,但是声音刚开始是噪音,之后就没有任何声音了,这不对。并且如果想录制双音源,这种无法保证自己的平板音频也在里面,请大牛提供解决思路。
javacv1.5.2版本遇到无法加载jniope ncv_videoio.dl
使用 javacv1.5.2,该版本已经封装好所需要的几大类库。 报错如下 ``` Exception in thread "Thread-25" java.lang.UnsatisfiedLinkError: no jniopencv_vid eoio in java.library.path at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1867) at java.lang.Runtime.loadLibrary0(Runtime.java:870) at java.lang.System.loadLibrary(System.java:1122) at org.bytedeco.javacpp.Loader.loadLibrary(Loader.java:1543) at org.bytedeco.javacpp.Loader.load(Loader.java:1192) at org.bytedeco.javacpp.Loader.load(Loader.java:1042) at org.bytedeco.opencv.global.opencv_videoio.<clinit>(opencv_videoio.jav a:20) at java.lang.Class.forName0(Native Method) at java.lang.Class.forName(Class.java:348) at org.bytedeco.javacpp.Loader.load(Loader.java:1109) at org.bytedeco.javacpp.Loader.load(Loader.java:1058) at com.zywl.utils.JavacvUtils.recordPush(JavacvUtils.java:47) at com.zywl.ehome.entity.PreviewServe$FPREVIEW_NEWLINK_CB$1.run(PreviewS erve.java:233) at java.lang.Thread.run(Thread.java:748) Caused by: java.lang.UnsatisfiedLinkError: C:\Users\Administrator\.javacpp\cache \opencv-4.1.2-1.5.2-windows-x86_64.jar\org\bytedeco\opencv\windows-x86_64\jniope ncv_videoio.dll: Can't find dependent libraries at java.lang.ClassLoader$NativeLibrary.load(Native Method) at java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1941) at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1824) at java.lang.Runtime.load0(Runtime.java:809) at java.lang.System.load(System.java:1086) at org.bytedeco.javacpp.Loader.loadLibrary(Loader.java:1493) ... 10 more ``` 网上找的答案都是早期的javacv版本,当时javacv没有封装其他的动态链接库。所以说什么javacv跟opencv版本不一致,是个坑。因为1.5.2封装好了,自动在c盘的用户里生成.javacpp 里面含有了相对应的opencv。 目前不知道是怎么回事。在自己的电脑windows10 可以,正式部署的服务器windows servser2008 r2 ,就报如上错误。有没有大神遇到过,应该如何解决。在线等
javacv下面通过findContours查找轮廓,如何找到轮廓线上的所有点在图片上的坐标?
MatVector contours = new MatVector(); Mat hierarchy=new Mat(); opencv_imgproc.findContours(image, contours,hierarchy, RETR_EXTERNAL, CHAIN_APPROX_NONE);//查找轮廓 opencv_imgproc.drawContours(image, contours, 0, Scalar.RED, 2, 8, hierarchy, 1, new Point(0,0));//在原图上绘制轮廓 Mat target = contours.get(0);//target就是保存了轮廓线条上所有点的对象 在javacv下面,可以顺利找到轮廓,并绘制轮廓了,我想在图上遍历和跟踪轮廓上的每一个点,请问如何获取所有轮廓点的坐标?能否提供java代码示范? 补充:使用的javacv1.4.1,opencv3.4.1版本,本人不太会C/C++,因此其他C++案例中的代码没有办法直接做参考,请提供java代码的解决方案,感谢。 java里面查找轮廓返回的是一个MatVector contours对象,contours.get(0)返回的第一个轮廓是一个Mat对象,在Mat对象应该怎么找到里面的点坐标?
javaCV 视频直播声画同步问题
我用JavaCV做一个类似视频直播的功能,刚开始只传图像到服务器上,现在加上了声音,但是目前声音能传过去,画面非常卡,基本上就是卡住不动了,而且我看网上的代码都是声音和画面在两个线程采集,为什么要用多线程呢?
android 用javacv录制视频,debug程序报异常
07-08 11:04:15.298: E/dalvikvm(19457): Could not find class 'java.awt.Rectangle', referenced from method com.googlecode.javacv.cpp.opencv_core$IplImage.copyFrom
javacv 引起的jvm报错,怎么解决?
javacv 中的人脸识别图片训练方法train(),程序一运行,jvm就崩溃了 JRE version: Java(TM) SE Runtime Environment (8.0_121-b13) (build 1.8.0_121-b13) # Java VM: Java HotSpot(TM) 64-Bit Server VM (25.121-b13 mixed mode windows-amd64 compressed oops) # Problematic frame: # C [ntdll.dll+0x4f7e7] 该怎么解决呢?
求助 JavaCV 的 grabber.stop() 问题
以下是代码: grabber.start(); CanvasFrame canvasFrame = new CanvasFrame("Camera"); canvasFrame.setVisible(false); IplImage image; image = grabber.grab(); int width = image.width(); int height = image.height(); canvasFrame.setCanvasSize(width, height); final BufferedImage bImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB); Graphics2D bGraphics = bImage.createGraphics(); TimerAction timerAction = new TimerAction(canvasFrame); final Timer timer=new Timer(10, timerAction); timerAction.setTimer(timer); int checkPictureContextIsNull = 1; while(checkPictureContextIsNull == 1){ if((image=grabber.grab()) == null){ continue; }else{ if(!timer.isRunning()) { // canvasFrame.showImage(image); bGraphics.drawImage(image.getBufferedImage(),null,0,0); timer.start(); // changePicturesNameType = Integer.toString(changePicturesName); try { ImageIO.write(bImage, "jpg", new File("d:\\pictures.jpg")); // changePicturesName++; } catch (IOException e1) { e1.printStackTrace(); } checkPictureContextIsNull = 0; } } } cvReleaseImage(image); grabber.stop(); canvasFrame.dispose(); 以下是main方法 public static void main(String[] args) throws InterruptedException, com.googlecode.javacv.FrameGrabber.Exception { System.out.println("11111111111111111111111111111111111111111"); getPictures(); System.out.println("22222222222222222222222222222222222222222"); } 我每次执行都只能打印出 111111111 语句 因为一执行到 getPictures()这个方法的时候就直接中断了,后来DEBUG调试发现程序运行到 getPictures()方法的 grabber.stop(); 语句时 程序就中断了,在网上查了好多 都没有查到,希望CSDN的牛人可以帮忙解决一下 不胜感激
有人有arm64-v8a下的javacv的so文件吗
![图片说明](https://img-ask.csdn.net/upload/201904/21/1555835490_323492.png) arm64-v8a下的so文件,类似于![图片说明](https://img-ask.csdn.net/upload/201904/21/1555835605_385869.png) 这种的
使用javacv来实现灰度直方图的绘制,calchist函数运行出错
//绘制灰度直方图 public static void drawHistImage() { IntPointer channels = new IntPointer(0); IntPointer histSize = new IntPointer(256); FloatPointer histRange = new FloatPointer(0,256); Mat hist = new Mat(); //计算直方图 calcHist((grayContour.get())[0], 1,channels, new Mat(), hist, 1,histSize, histRange); //按行归一化 normalize(hist, hist, 0, hist.rows() ,NORM_MINMAX, -1, new Mat()); ... } 代码在calchist处出错:(-215:Assertion failed) j < nimages in function 'cv::histPrepareImages',请问如何解决,感谢回答!
图像全局特征GIST的java代码
在hadoop平台上做图像分类标注,求提取图像GIST特征的java代码,现在的代码都是用javacv写的
android studio 图片合成视频
图片如何合成视频,能否提供源码或方法 网上查了很多,但都无法使用 ffmpeg还是javacv、opencv??
java FFmpegFrameGrabber 流媒体实时播放问题
``` FrameGrabber grabber = new FFmpegFrameGrabber(cacheFile); grabber.start();// 开启抓取器 ``` 报错: org.bytedeco.javacv.FrameGrabber$Exception: avformat_open_input() error -1094995529: Could not open input "/tmp/D-DT0056-6". (Has setFormat() been called?) 怎么解决
eclipse环境下的opencv使用问题
我的eclipse版本是4.5.2 opencv是3.1 我是按照这个博客中的指导进行的处理 http://blog.sina.com.cn/s/blog_7b4a5b550101ifi7.html 但是我在运行测试程序的时候,总是出现下面的错误 Exception in thread "main" java.lang.UnsatisfiedLinkError: C:\Users\John\AppData\Local\Temp\javacpp62144455200083\jniopencv_core.dll: Can't find dependent libraries at java.lang.ClassLoader$NativeLibrary.load(Native Method) at java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1938) at java.lang.ClassLoader.loadLibrary(ClassLoader.java:1821) at java.lang.Runtime.load0(Runtime.java:809) at java.lang.System.load(System.java:1086) at com.googlecode.javacpp.Loader.loadLibrary(Loader.java:418) at com.googlecode.javacpp.Loader.load(Loader.java:368) at com.googlecode.javacpp.Loader.load(Loader.java:315) at com.googlecode.javacv.cpp.opencv_core.<clinit>(opencv_core.java:131) at java.lang.Class.forName0(Native Method) at java.lang.Class.forName(Class.java:348) at com.googlecode.javacpp.Loader.load(Loader.java:334) at com.googlecode.javacv.cpp.opencv_imgproc.<clinit>(opencv_imgproc.java:96) at java.lang.Class.forName0(Native Method) at java.lang.Class.forName(Class.java:348) at com.googlecode.javacpp.Loader.load(Loader.java:334) at com.googlecode.javacv.cpp.opencv_highgui.<clinit>(opencv_highgui.java:91) at test2.Opencv1.smooth(Opencv1.java:11) at test2.Opencv1.main(Opencv1.java:25) 求指导,急需,跪求!!! p.s.当我在执行上面的那个博客中的下面那个官网测试代码时是没有问题的,但执行第一段测试程序时就出问题了
从网上下载的代码,eclipse:1.8;配置opencv-2.4.9,总如下报错,大神求解决,谢谢
Exception in thread "main" java.lang.UnsatisfiedLinkError: C:\Users\Li\AppData\Local\Temp\javacpp500049768210061\jniopencv_core.dll: Can't find dependent libraries at java.lang.ClassLoader$NativeLibrary.load(Native Method) at java.lang.ClassLoader.loadLibrary0(Unknown Source) at java.lang.ClassLoader.loadLibrary(Unknown Source) at java.lang.Runtime.load0(Unknown Source) at java.lang.System.load(Unknown Source) at com.googlecode.javacpp.Loader.loadLibrary(Loader.java:566) at com.googlecode.javacpp.Loader.load(Loader.java:489) at com.googlecode.javacpp.Loader.load(Loader.java:431) at com.googlecode.javacv.cpp.opencv_core.<clinit>(opencv_core.java:136) at java.lang.Class.forName0(Native Method) at java.lang.Class.forName(Unknown Source) at com.googlecode.javacpp.Loader.load(Loader.java:453) at com.googlecode.javacv.cpp.opencv_imgproc.<clinit>(opencv_imgproc.java:97) at java.lang.Class.forName0(Native Method) at java.lang.Class.forName(Unknown Source) at com.googlecode.javacpp.Loader.load(Loader.java:453) at com.googlecode.javacv.cpp.opencv_objdetect.<clinit>(opencv_objdetect.java:97) at java.lang.Class.forName0(Native Method) at java.lang.Class.forName(Unknown Source) at com.googlecode.javacpp.Loader.load(Loader.java:453) at com.googlecode.javacpp.Loader.load(Loader.java:431) at com.googlecode.javacv.cpp.opencv_objdetect$CvHaarClassifierCascade.<clinit>(opencv_objdetect.java:176) at FaceRecognizer.<init>(FaceRecognizer.java:103) at LoginShell$3.widgetSelected(LoginShell.java:113) at org.eclipse.swt.widgets.TypedListener.handleEvent(TypedListener.java:228) at org.eclipse.swt.widgets.EventTable.sendEvent(EventTable.java:84) at org.eclipse.swt.widgets.Widget.sendEvent(Widget.java:1003) at org.eclipse.swt.widgets.Display.runDeferredEvents(Display.java:3910) at org.eclipse.swt.widgets.Display.readAndDispatch(Display.java:3503) at LoginShell.main(LoginShell.java:49) Caused by: java.lang.UnsatisfiedLinkError: no opencv_core245 in java.library.path at java.lang.ClassLoader.loadLibrary(Unknown Source) at java.lang.Runtime.loadLibrary0(Unknown Source) at java.lang.System.loadLibrary(Unknown Source) at com.googlecode.javacpp.Loader.loadLibrary(Loader.java:593) at com.googlecode.javacpp.Loader.load(Loader.java:481) ... 23 more
Java使用opencv技术监控路由器信号灯,判断是否断网等异常情况,请问大体步骤如何?
如题,新人入行,之前没有使用过opencv,只知道是一个图形处理的库,本身是C/C++写的. 老大交代了任务,让先搭建Java开发opencv的环境,我在网上看的时候,有直接使用JavaCV的, 也有直接导入opencv的jar包的,对了,老大交代IDE用IDEA. 现在想请问各位前辈,我要完成我的需求,需要用到opencv中的哪些方法,至少能有大体方法, 这两天看了一下opencv手册,方法有好几百个,茫茫而不知取舍. 最好是有前辈给出类似的代码,这种需求肯定不是我第一个遇到,比如有人做过信号灯的监控等, 这都是类似的,只是我没有找到代码,只有几句干巴巴的文字,没什么帮助啊, 请各位前辈赐教!感激不尽!
谁来帮帮我运行android的时候出现这个问题怎么解决呢,回答有重赏。。。。。大神
05-20 05:07:15.757: W/dalvikvm(668): threadid=1: thread exiting with uncaught exception (group=0x409c01f8) 05-20 05:07:15.788: E/AndroidRuntime(668): FATAL EXCEPTION: main 05-20 05:07:15.788: E/AndroidRuntime(668): java.lang.NullPointerException 05-20 05:07:15.788: E/AndroidRuntime(668): at com.just.javacv.FaceDecetionForTest.loadTrainImageData(Androidbs2Activity.java:111) 05-20 05:07:15.788: E/AndroidRuntime(668): at com.just.javacv.Androidbs2Activity$1.onClick(Androidbs2Activity.java:42) 05-20 05:07:15.788: E/AndroidRuntime(668): at android.view.View.performClick(View.java:3511) 05-20 05:07:15.788: E/AndroidRuntime(668): at android.view.View$PerformClick.run(View.java:14105) 05-20 05:07:15.788: E/AndroidRuntime(668): at android.os.Handler.handleCallback(Handler.java:605) 05-20 05:07:15.788: E/AndroidRuntime(668): at android.os.Handler.dispatchMessage(Handler.java:92) 05-20 05:07:15.788: E/AndroidRuntime(668): at android.os.Looper.loop(Looper.java:137) 05-20 05:07:15.788: E/AndroidRuntime(668): at android.app.ActivityThread.main(ActivityThread.java:4424) 05-20 05:07:15.788: E/AndroidRuntime(668): at java.lang.reflect.Method.invokeNative(Native Method) 05-20 05:07:15.788: E/AndroidRuntime(668): at java.lang.reflect.Method.invoke(Method.java:511) 05-20 05:07:15.788: E/AndroidRuntime(668): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 05-20 05:07:15.788: E/AndroidRuntime(668): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 05-20 05:07:15.788: E/AndroidRuntime(668): at dalvik.system.NativeStart.main(Native Method) package com.just.javacv; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.widget.Button; import java.io.FileNotFoundException; import java.util.ArrayList; import java.util.Arrays; import com.googlecode.javacv.cpp.opencv_core.CvMat; import com.googlecode.javacv.cpp.opencv_core.CvScalar; import com.googlecode.javacv.cpp.opencv_core.IplImage; import com.just.util.FileUtil; import static com.googlecode.javacv.cpp.opencv_core.*; import static com.googlecode.javacv.cpp.opencv_highgui.*; public class Androidbs2Activity extends Activity { private Button button; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); button=(Button)this.findViewById(R.id.button1); button.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // TODO Auto-generated method stub FaceDecetionForTest faceDecetion = new FaceDecetionForTest(); //项目根目录下的train文件夹中,保存有训练样本orl图像文件200张 String str1 = ".//train"; String[] photos = FileUtil.readImageFromDir(str1); //加载训练样本 faceDecetion.loadTrainImageData(photos); faceDecetion.doPCA(); System.out.println("特征矩阵的大小为:rows="+faceDecetion.result.rows()+",cols="+faceDecetion.result.cols()); String testImage = ".//test//orl_022_007.bmp"; faceDecetion.loadTestImageData(testImage); //显示识别结果 // faceDecetion.showResult(faceDecetion.photos, testImage); System.out.println("识别结果文件路径:"+faceDecetion.getResultPhotoPath()); //将训练样本的特征矩阵写入文本文件中 try { FileUtil.writeMatToFile(faceDecetion.getResult(), ".//data//cvMat.txt"); } catch (FileNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } // CvMat mat = FileUtil.readerMatFromFile(".//data//cvMat.txt"); } }); } } /** * 人脸识别图像PCA降维处理类,该类可加载某一文件夹中的图像,进行PCA降维生成特征矩阵 * @author Administrator * */ class FaceDecetionForTest{ //待训练的数据 private CvMat trainImagesRow; //待识别的数据 private CvMat testImagesRow; //降维后的特征矩阵 CvMat result; //测试样本得到的特征向量 private CvMat result2; private CvMat avg; private CvMat eigenVectors; //训练样本图像路径的集合 private ArrayList<String> photos; public FaceDecetionForTest() { //初始化数据 this.trainImagesRow = null; this.testImagesRow = null; this.result = new CvMat(); this.result2 = new CvMat(); this.avg = new CvMat(); this.eigenVectors = new CvMat(); this.photos = new ArrayList<String>(); } /** * 加载训练图片 * @param imageList */ public void loadTrainImageData(String[] photoArray) { //将读取到的图像路径保存在photos中,一边识别时按序号找到文件路径 for (int i = 0; i < photoArray.length; i++) { photos.add(photoArray[i]); } //按照图像文件路径,将图像加载为IplImage数据,并按顺序保存至faces中 ArrayList<IplImage> faces = new ArrayList<IplImage>(); for (int i = 0; i < photoArray.length; i++) { IplImage tempImage = cvLoadImage(photoArray[i],0); faces.add(tempImage); } //获取训练样本的大小rows*cols int rows = faces.size(); int cols = faces.get(0).width()*faces.get(0).height(); //设定训练样本的矩阵的大小和数据类型 trainImagesRow = cvCreateMat(rows,cols,CV_32FC1); //在控制台输出训练样本的大小 System.out.println("训练样本库的大小为:rows="+rows+",cols="+cols); //输出训练样本的个数 System.out.println("训练样本的个数为facesSize="+faces.size()); System.out.println("单个训练样本的大小为:rows="+faces.get(0).height()+",cols="+faces.get(0).width()); //循环获取faces中的数据,将IplImage转换为CvMat后加载至训练样本矩阵中 for (int i = 0; i < faces.size(); i++) { IplImage image = faces.get(i); //根据图像的大小生成同样大小的矩阵 CvMat mat = cvCreateMat(image.height(), image.width(), CV_32FC1); //将图像数据转换为矩阵保存 cvConvert(image, mat); int index = 0; //将一幅图像图像转换为 训练矩阵中的一行 保存 for (int j2 = 0; j2 < mat.rows(); j2++) { for (int k = 0; k < mat.cols(); k++) { trainImagesRow.put(i, index, mat.get(j2, k)); index++; } } } } /** * 加载测试样本 * @param imagePath 测试样本图像文件的路径 */ public void loadTestImageData(String imagePath) { //根据图像文件的路径,将文件加载为IplImage类型 IplImage image = cvLoadImage(imagePath,0); //根据image生成同样大小的测试样本矩阵 testImagesRow = cvCreateMat(1, image.width()*image.height(), CV_32FC1); //将图像数据保存为CvMat后加载至测试样本矩阵中 CvMat mat = cvCreateMat(image.height(), image.width(), CV_32FC1); cvConvert(image, mat); int index = 0; for (int i = 0; i < mat.rows(); i++) { for (int j = 0; j < mat.cols(); j++) { testImagesRow.put(0,index,mat.get(i,j)); index++; } } //按照测试样本的大小,生成测试样本特征向量的大小 () result2 = cvCreateMat(testImagesRow.rows(), result.cols(), CV_32FC1); System.out.println("测试样本特征向量的大小rows="+result2.rows()+",cols="+result2.cols()); //生成测试样本特征向量 cvProjectPCA(testImagesRow, avg, eigenVectors, result2); } public void doPCA(){ System.out.println("doPCA……start"); avg = cvCreateMat(1, trainImagesRow.cols(), CV_32FC1); //训练特征向量 CvMat eigenValues = cvCreateMat(1, Math.min(trainImagesRow.rows(), trainImagesRow.cols()), CV_32FC1); eigenVectors = cvCreateMat(Math.min(trainImagesRow.rows(), trainImagesRow.cols()), trainImagesRow.cols(), CV_32FC1); //取特征向量的前P个特征值,作为比较结果 result = cvCreateMat(trainImagesRow.rows(), Math.min(trainImagesRow.rows(), trainImagesRow.cols()), CV_32FC1); cvCalcPCA(trainImagesRow, avg, eigenValues, eigenVectors, CV_PCA_DATA_AS_ROW); //生成训练样本特征矩阵 cvProjectPCA(trainImagesRow, avg, eigenVectors, result); System.out.println("doPCA……over"); } /** * 显示识别结果 * @param photos 保存训练样本图像的list集合 * @param testImage 测试样本图像的路径 */ public void showResult(ArrayList<String> photos,String testImage) { //取得是被结果的类序号 int num = euclideanDistance(result, result2); //按类序号乘以类中图片的数量,获取识别结果的图像路径,显示图像 cvShowImage("result", cvLoadImage(photos.get(num*5))); //根据测试样本图像的路径,显示图像 cvShowImage("src", cvLoadImage(testImage)); cvWaitKey(5000); } /** * 获取欧式距离 * @param trainData * @param testData * @return */ public int euclideanDistance(CvMat trainData,CvMat testData) { double[] num = new double[trainData.rows()]; //获取测试样本特征向量与训练样本特征矩阵每一行的欧式距离 for (int i = 0; i < trainData.rows(); i++) { double sum = 0; for (int j = 0; j < trainData.cols(); j++) { sum += Math.pow(Math.abs(trainData.get(i, j))-Math.abs(testData.get(0, j)), 2); } num[i] = Math.sqrt(sum); } //获取欧氏距离的和中最小的类的序号 return minArrayElement(num); } private int minArrayElement(double[] array) { //将欧氏距离按类相加 double classifyArray[] = new double[array.length/5]; int count = 0; for (int i = 0; i < array.length; i++) { if (i%5==0&&i!=0) { count++; }else { classifyArray[count]+= array[i]; } } //求类间欧氏距离和的最小值,index为该类的序号 int index = 0; double min = classifyArray[0]; for (int i = 0; i < classifyArray.length; i++) { if (min>classifyArray[i]) { min = classifyArray[i]; index = i; } } return index; } /** * 获取识别结果的文件路径 * @return */ public String getResultPhotoPath() { int num = euclideanDistance(result, result2); return photos.get(num*5); } public CvMat getResult() { return result; } public void setResult(CvMat result) { this.result = result; } }
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
此博客仅为我业余记录文章所用,发布到此,仅供网友阅读参考,如有侵权,请通知我,我会删掉。 补充 有不少读者留言说本文章没有用,因为天气预报直接打开手机就可以收到了,为何要多此一举发送到邮箱呢!!!那我在这里只能说:因为你没用,所以你没用!!! 这里主要介绍的是思路,不是天气预报!不是天气预报!!不是天气预报!!!天气预报只是用于举例。请各位不要再刚了!!! 下面是我会用到的两个场景: 每日下
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
死磕YOLO系列,YOLOv1 的大脑、躯干和手脚
YOLO 是我非常喜欢的目标检测算法,堪称工业级的目标检测,能够达到实时的要求,它帮我解决了许多实际问题。 这就是 YOLO 的目标检测效果。它定位了图像中物体的位置,当然,也能预测物体的类别。 之前我有写博文介绍过它,但是每次重新读它的论文,我都有新的收获,为此我准备写一个系列的文章来详尽分析它。这是第一篇,从它的起始 YOLOv1 讲起。 YOLOv1 的论文地址:https://www.c
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
记一次腾讯面试:进程之间究竟有哪些通信方式?如何通信? ---- 告别死记硬背
有一次面试的时候,被问到进程之间有哪些通信方式,不过由于之前没深入思考且整理过,说的并不好。想必大家也都知道进程有哪些通信方式,可是我猜很多人都是靠着”背“来记忆的,所以今天的这篇文章,讲给大家详细着讲解他们是如何通信的,让大家尽量能够理解他们之间的区别、优缺点等,这样的话,以后面试官让你举例子,你也能够顺手拈来。 1、管道 我们来看一条 Linux 的语句 netstat -tulnp | gr...
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
网络(8)-HTTP、Socket、TCP、UDP的区别和联系
TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。 一、TCP与UDP的不同 1. 是否需要建立连接。 UDP在传送数据之前不需要先建立连接;TCP则提供面向连接的服务; 2. 是否需要给出确认 对方的传输层在收到UDP报文后,不需要给出任何确认,而 TCP需要给出确认报文,要提供可靠的、面向连接的传输服务。 3.虽然UDP不提供可靠交...
简明易理解的@SpringBootApplication注解源码解析(包含面试提问)
欢迎关注文章系列 ,关注我 《提升能力,涨薪可待》 《面试知识,工作可待》 《实战演练,拒绝996》 欢迎关注我博客,原创技术文章第一时间推出 也欢迎关注公 众 号【Ccww笔记】,同时推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《提升能力,涨薪可待篇》- @SpringBootApplication注解源码解析 一、@SpringBootApplication 的作用是什
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
开挂的人生!那些当选院士,又是ACM/IEEE 双料Fellow的华人学者们
昨日,2019年两院院士正式官宣,一时间抢占了各大媒体头条。 朋友圈也是一片沸腾,奔走相告,赶脚比自己中了大奖还嗨皮! 谁叫咱家导师就是这么厉害呢!!! 而就在最近,新一年度的IEEE/ACM Fellow也将正式公布。 作为学术届的顶级荣誉,不自然地就会将院士与Fellow作比较,到底哪个含金量更高呢? 学术君认为,同样是专业机构对学者的认可,考量标准不一,自然不能一概而论。 但...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
Python语言高频重点汇总
Python语言高频重点汇总 GitHub面试宝典仓库——点这里跳转 文章目录Python语言高频重点汇总**GitHub面试宝典仓库——点这里跳转**1. 函数-传参2. 元类3. @staticmethod和@classmethod两个装饰器4. 类属性和实例属性5. Python的自省6. 列表、集合、字典推导式7. Python中单下划线和双下划线8. 格式化字符串中的%和format9.
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观
代码详解:如何用Python快速制作美观、炫酷且有深度的图表
全文共12231字,预计学习时长35分钟生活阶梯(幸福指数)与人均GDP(金钱)正相关的正则图本文将探讨三种用Python可视化数据的不同方法。以可视化《2019年世界幸福报告》的数据为例,本文用Gapminder和Wikipedia的信息丰富了《世界幸福报告》数据,以探索新的数据关系和可视化方法。《世界幸福报告》试图回答世界范围内影响幸福的因素。报告根据对“坎特里尔阶梯问题”的回答来确定幸...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外
(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
今年正式步入了大四,离毕业也只剩半年多的时间,回想一下大学四年,感觉自己走了不少弯路,今天就来分享一下自己大学的学习经历,也希望其他人能不要走我走错的路。 (一)初进校园 刚进入大学的时候自己完全就相信了高中老师的话:“进入大学你们就轻松了”。因此在大一的时候自己学习的激情早就被抛地一干二净,每天不是在寝室里玩游戏就是出门游玩,不过好在自己大学时买的第一台笔记本性能并不是很好,也没让我彻底沉...
如何写一篇技术博客,谈谈我的看法
前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 我一直推崇学技术可以写技术博客去沉淀自己的知识,因为知识点实在是太多太多了,通过自己的博客可以帮助自己快速回顾自己学过的东西。 我最开始的时候也是只记笔记,认为自己能看得懂就好。但如果想验证自己是不是懂了,可以写成技术博客。在写技术博客的...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【设计模式】单例模式的八种写法分析
网上泛滥流传单例模式的写法种类,有说7种的,也有说6种的,当然也不排除说5种的,他们说的有错吗?其实没有对与错,刨根问底,写法终究是写法,其本质精髓大体一致!因此完全没必要去追究写法的多少,有这个时间还不如跟着宜春去网吧偷耳机、去田里抓青蛙得了,一天天的....
《面试宝典》:检验是否为合格的初中级程序员的面试知识点,你都知道了吗?查漏补缺
欢迎关注文章系列,一起学习 《提升能力,涨薪可待篇》 《面试知识,工作可待篇》 《实战演练,拒绝996篇》 也欢迎关注公 众 号【Ccww笔记】,原创技术文章第一时间推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《面试知识,工作可待篇》-Java笔试面试基础知识大全 前言 是不是感觉找工作面试是那么难呢? 在找工作面试应在学习的基础进行总结面试知识点,工作也指日可待,欢...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
微博推荐算法简述
在介绍微博推荐算法之前,我们先聊一聊推荐系统和推荐算法。有这样一些问题:推荐系统适用哪些场景?用来解决什么问题、具有怎样的价值?效果如何衡量? 推荐系统诞生很早,但真正被大家所重视,缘起于以”facebook”为代表的社会化网络的兴起和以“淘宝“为代表的电商的繁荣,”选择“的时代已经来临,信息和物品的极大丰富,让用户如浩瀚宇宙中的小点,无所适从。推荐系统迎来爆发的机会,变得离用户更近: 快...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
Python爬虫爬取淘宝,京东商品信息
小编是一个理科生,不善长说一些废话。简单介绍下原理然后直接上代码。 使用的工具(Python+pycharm2019.3+selenium+xpath+chromedriver)其中要使用pycharm也可以私聊我selenium是一个框架可以通过pip下载 pip install selenium -i https://pypi.tuna.tsinghua.edu.cn/simple/ 
相关热词 c# id读写器 c#俄罗斯方块源码 c# linq原理 c# 装箱有什么用 c#集合 复制 c# 一个字符串分组 c++和c#哪个就业率高 c# 批量动态创建控件 c# 模块和程序集的区别 c# gmap 截图
立即提问