Рассчитать размер текста - PullRequest
0 голосов
/ 15 мая 2018

Примечание : Этот вопрос Как поместить текст в ограничивающий прямоугольник в OpenCV? чем-то похож на этот, но это не тот же вопрос.ОП вопросов пытался распространить текст на весь размер его изображения, а код в ответе, который ставит точку, просто изменяет размер текста с помощью маски.

Я использую openCV в сочетании с C++ для обнаружения и манипуляции с изображениями.

Поэтому я хочу выровнять текст с неизвестной длины при конкретном происхождении.Масштаб шрифта должен быть рассчитан, потому что я хотел бы указать коэффициент ширины для максимальной ширины текста, как вы можете видеть на рисунке ниже:

![enter image description here

Это код, который я получил до сих пор:

int fontFace = cv::FONT_HERSHEY_DUPLEX,
    fontScale = myTextString.size() / 10;

cv::Size textSize = getTextSize(image, fontFace, fontScale, 0, 0);
putText(image, myTextString, cv::Point( (origin.x + textSize.width)/2, (origin.y + textSize.height)/2 ), fontFace, fontScale, Scalar(255, 0, 0));

1 Ответ

0 голосов
/ 15 мая 2018

Что-то вроде этого должно сделать это. Вы можете изменить способ расчета полей для изменения горизонтального / вертикального выравнивания шрифта.

Если высота не имеет значения, вы можете просто оставить target.height большое число.

void drawtorect(cv::Mat & mat, cv::Rect target, int face, int thickness, cv::Scalar color, const std::string & str)
{
    cv::Size rect = cv::getTextSize(str, face, 1.0, thickness, 0);
    double scalex = (double)target.width / (double)rect.width;
    double scaley = (double)target.height / (double)rect.height;
    double scale = std::min(scalex, scaley);
    int marginx = scale == scalex ? 0 : (int)((double)target.width * (scalex - scale) / scalex * 0.5);
    int marginy = scale == scaley ? 0 : (int)((double)target.height * (scaley - scale) / scaley * 0.5);
    cv::putText(mat, str, cv::Point(target.x + marginx, target.y + target.height - marginy), face, scale, color, thickness, 8, false);
}

* редактировать *

// Sample code
int L = 80; // width and height per square
int M = 60;
cv::Mat m( 5*M, 7*L,CV_8UC3,cv::Scalar(0,0,0) );
// create checkerboard
for ( int y=0,ymax=m.rows-M;y<=ymax; y+=M)
{
    int c = (y/M)%2 == 0 ? 0 : 1;
    for ( int x=0,xmax=m.cols-L;x<=xmax;x+=L)
    {
        if ( (c++)%2!=0 )
            continue; // skip odd squares
        // convenient way to do this
        m( cv::Rect(x,y,L,M) ).setTo( cv::Scalar(64,64,64) );
    }
}
// fill checkerboard ROIs by some text
int64 id=1;
for ( int y=0,ymax=m.rows-M;y<=ymax; y+=M)
{
    for ( int x=0,xmax=m.cols-L;x<=xmax;x+=L)
    {
        std::stringstream ss;
        ss<<(id<<=1); // some increasing text input
        drawtorect( m, cv::Rect(x,y,L,M), cv::FONT_HERSHEY_PLAIN,1,cv::Scalar(255,255,255),ss.str() );
    }
}

enter image description here

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...