Поместите изображение в изображение

Python 2.x, 220C del> 213C del> 207C del> 204C del> 201C del> 198C del> 196C del> 188C

Особая благодарность gnibbler за некоторые подсказки в #stackoverflow на Freenode . Вывод включает в себя начальную и конечную новую строку.

import math
v=input()*2
w=v-1
a=['\n']*w*v
p=w*v/2
for c in range(1,w*w):a[p]=' *'[(c>1)*all(c%d for d in range(2,c))];x=int(math.sqrt(c-1));p+=(-1)**x*((x*x

(совместимость с Python 3 потребует дополнительных символов; для этого используются input , оператор print и / для целых чисел] разделение.)

7
задан evotopid 29 January 2012 в 21:01
поделиться

3 ответа

Вам придется копировать пиксель за пикселем из источника в место назначения. Код ниже делает именно это, смещая координаты x и y . На самом деле я этого не пробовал, но уверен, что это должно работать более или менее так, как вы ожидали.

Просто убедитесь, что размер целевого изображения не меньше исходного плюс смещение!

void drawImage(IplImage* target, IplImage* source, int x, int y) {
    for (int ix=0; x<source->width; x++) {
        for (int iy=0; y<source->height; y++) {
            int r = cvGet2D(source, iy, ix).val[2];
            int g = cvGet2D(source, iy, ix).val[1];
            int b = cvGet2D(source, iy, ix).val[0];
            CvScalar bgr = cvScalar(b, g, r);
            cvSet2D(target, iy+y, ix+x, bgr);
        }
    }
}
0
ответ дан 6 December 2019 в 19:38
поделиться

Я сделал это некоторое время назад с помощью SetRoi, это было примерно так. У меня есть два изображения, одно - это миниатюра под названием thumb_frame, маленькое изображение, которое я включу в большое изображение show_frame

//I set the ROI to the same size as the thumb_frame
cvSetImageROI(show_frame.image, cvRect(thumbnail_x_pos,
                    thumbnail_y_pos, thumb_frame->width, thumb_frame->height));

//I add the image to the designated ROI
cvAddWeighted(thumb_frame, alpha, show_frame, beta, 0, show_frame);

Вот и все.

7
ответ дан 6 December 2019 в 19:38
поделиться
void cvOverlayImage(IplImage* src, IplImage* overlay, CvPoint location, CvScalar S, CvScalar D)
{
 int x,y,i;

  for(x=0;x < overlay->width -10;x++)     
//replace '-10' by whatever x position you want your overlay image to begin. 
//say '-varX'
    {
        if(x+location.x>=src->width) continue;
        for(y=0;y < overlay->height -10;y++)  
//replace '-10' by whatever y position you want your overlay image to begin.
//say '-varY'
        {
            if(y+location.y>=src->height) continue;
            CvScalar source = cvGet2D(src, y+location.y, x+location.x);
            CvScalar over = cvGet2D(overlay, y, x);
            CvScalar merged;
            for(i=0;i<4;i++)
            merged.val[i] = (S.val[i]*source.val[i]+D.val[i]*over.val[i]);
            cvSet2D(src, y+location.y, x+location.x, merged);
        }
    }
}

Чтобы использовать

cvOverlayImage(largerimage, overlayimage, cvPoint(10, 10), cvScalar(0.5,0.5,0.5,0.5), cvScalar(0.5,0.5,0.5,0.5)); 
//The cvPoint(10,10) can be the cvPoint(varX,varY) depending on how you write the function 
//and how you want to use it. 
//You cannot choose values less than 'varX' and 'varY' in this case
//else you would see a runtime error.
6
ответ дан 6 December 2019 в 19:38
поделиться
Другие вопросы по тегам:

Похожие вопросы: