Форум программистов, компьютерный форум CyberForum.ru

OpenCV с изображениями - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Не работает IplImage* http://www.cyberforum.ru/cpp/thread1641369.html
Добрый день. Пытаюсь скомпилировать вот такой код: #include <cv.h> #include <highgui.h> #include <stdlib.h> #include <stdio.h> #include "stdafx.h" IplImage* image = 0; IplImage* src = 0;
C++ Неправильная работа Sleep(), в чём причина? Использую функцию Sleep() для создания задержки потока в миллисекундах. Написал тестовую программу, тестирующую эту функцию. Установил в цикле задержку в 1 миллисекунду (Sleep(1)). Высокоточным таймером проверял эту функцию и оказалось, что она странным образом работает неправильно, если в ОС у меня ничего не запущено. Задержка вместо 1 миллисекунды растягивается на 16 миллисекунд, но стоит... http://www.cyberforum.ru/cpp/thread1640139.html
C++ Анимациия персонажа
Доброго времени суток. Не так давно я решил создать простенькую игру-платформер, все продвигалось успешно, но я замел что при движении анимация замирает на спрайте к которому оно подходит, и мне интересно, как сделать так, что бы при окончании движения персонаж возвращался в начальное положение?
Ошибка с шаблонами C++
Возникла проблема. Пример: Создал шаблонный класс с двумя параметрами, один из которых задан по умолчанию. С одной стороны, все работает: #include <iostream> using namespace std; template <class A, class B = A> class MyClass{ A a;
C++ Dsd-master 1.7 для декодирования d-star http://www.cyberforum.ru/cpp/thread1639265.html
здравствуйте уважаемые форумчане, мне нужна помощь в запуске программы через bash в cygwin в windows но данная программа на данный момент хранится в не скомпилированном варианте. Кто то давно его компилировал под cygwin, но позже удалил теперь его нужно восстановить. данная программа позволяет при помощи обыкновенной радиостанции через динамик на частотах d-star, dmr и motorbo (цифровые...
C++ Исправить код базы данных Помогите решить задачу Особенности - условие задачи является внедрение трех функций - insert - вставить новую строку (запись) в системе со всей информацией, -find - указано количество столбцов, по которым она ищет -номера столбцов считаются от 0 - параметр функции является тип в соответствии с выбранной колонкой - возвращает список строк из системы (желательно ссылки... подробнее

Показать сообщение отдельно
The_Chernyshovs
0 / 0 / 0
Регистрация: 14.09.2014
Сообщений: 20
18.01.2016, 18:09     OpenCV с изображениями
Здравствуйте, приложил программу, картинка выходит за пределы окна, как это избежать? Итог должен получится такой, изображение должно поворачиваться под случайный угол не выходя за пределы окна. В лучшем случае если изображение поворачивается без фона, только объект(по бинарной маске)

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#define _CRT_SECURE_NO_WARNINGS
 
#include "stdafx.h"
#include <cv.h>
#include <highgui.h>
#include <time.h>
#include <stdlib.h>
#include <stdio.h>
 
IplImage* rotationimage(IplImage* image)
{
    IplImage* gray = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
    IplImage* smooth = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
    IplImage* bin = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
    IplImage* temp = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1); // Временное изображение для нахождения контура
    IplImage* contour = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);
    
    cvCvtColor(image, gray, CV_BGR2GRAY);
    cvSmooth(gray, smooth, CV_GAUSSIAN, 5);
    cvThreshold(smooth, bin, 0, 255, CV_THRESH_OTSU);
    cvNot(bin, temp);
 
    CvMemStorage* c_storage = cvCreateMemStorage(0);
    CvSeq* c_first;
    cvFindContours(temp, c_storage, &c_first, sizeof(CvContour), 0, CV_CHAIN_APPROX_NONE);
 
    cvSet(contour, cvScalar(255));
    cvDrawContours(contour, c_first, cvScalar(0), cvScalar(0), 0);
 
    CvBox2D box = cvMinAreaRect2(c_first);
 
    int rndangle = rand() % 360;
 
    CvMat* rot_mat = cvCreateMat(2, 3, CV_32FC1);
    cv2DRotationMatrix(box.center, rndangle, 1.0, rot_mat);
 
    IplImage *rotate = cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 3);
    cvWarpAffine(image, rotate, rot_mat, CV_INTER_LINEAR | CV_WARP_FILL_OUTLIERS, cvScalarAll(155));
    
    //cvShowImage("gray", gray);
    //cvShowImage("smooth", smooth);
    cvShowImage("bin", bin);
 
    cvReleaseImage(&gray);
    cvReleaseImage(&smooth);
    cvReleaseImage(&bin);
    cvReleaseImage(&temp);
    cvReleaseImage(&contour);
 
    return rotate;
}
 
 void main(int argc, char ** argv)
{
    srand(time(NULL));
 
    IplImage *image = cvLoadImage("D:/1.jpg");
    cvShowImage("image", image);
 
    while (true)
    {
        IplImage *rotate_im = rotationimage(image);
        cvShowImage("rotate_im", rotate_im);
 
        while (true)
        {
            int c = cvWaitKey();
        
            if ((char)c == 27)
                return;
            else
                break;
        }
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 04:43. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru