You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							35 lines
						
					
					
						
							973 B
						
					
					
				
			
		
		
	
	
							35 lines
						
					
					
						
							973 B
						
					
					
				#!/usr/bin/env python
 | 
						|
import numpy as np
 | 
						|
 | 
						|
# copied from common.transformations/camera.py
 | 
						|
eon_dcam_focal_length = 860.0 # pixels
 | 
						|
webcam_focal_length = 908.0 # pixels
 | 
						|
 | 
						|
eon_dcam_intrinsics = np.array([
 | 
						|
  [eon_dcam_focal_length,   0,   1152/2.],
 | 
						|
  [  0,  eon_dcam_focal_length,  864/2.],
 | 
						|
  [  0,    0,     1]])
 | 
						|
 | 
						|
webcam_intrinsics = np.array([
 | 
						|
  [webcam_focal_length,   0.,   1280/2.],
 | 
						|
  [  0.,  webcam_focal_length,  720/2.],
 | 
						|
  [  0.,    0.,     1.]])
 | 
						|
 | 
						|
cam_id = 2
 | 
						|
 | 
						|
if __name__ == "__main__":
 | 
						|
  import cv2
 | 
						|
 | 
						|
  trans_webcam_to_eon_front = np.dot(eon_dcam_intrinsics,np.linalg.inv(webcam_intrinsics))
 | 
						|
 | 
						|
  cap = cv2.VideoCapture(cam_id)
 | 
						|
  cap.set(cv2.CAP_PROP_FRAME_WIDTH, 1280)
 | 
						|
  cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 720)
 | 
						|
 | 
						|
  while (True):
 | 
						|
    ret, img = cap.read()
 | 
						|
    if ret:
 | 
						|
      img = cv2.warpPerspective(img, trans_webcam_to_eon_front, (1152,864), borderMode=cv2.BORDER_CONSTANT, borderValue=0)
 | 
						|
      img = img[:,-864//2:,:]
 | 
						|
      cv2.imshow('preview', img)
 | 
						|
      cv2.waitKey(10) |