- OpenCV 4 with Python Blueprints
- Dr. Menua Gevorgyan Arsen Mamikonyan Michael Beyeler
- 421字
- 2021-06-24 16:50:01
Drafting a custom filter layout
Now we are almost done! If we want to use the BaseLayout class, we need to provide code for the two methods that were previously left blank, which are as follows:
- augment_layout: This is where we can make task-specific modifications to the GUI layout.
- process_frame: This is where we perform task-specific processing on each captured frame of the camera feed.
We also need to change the constructor to initialize any parameters we will need—in this case, the canvas background for the pencil sketch:
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
color_canvas = load_img_resized('pencilsketch_bg.jpg',
(self.imgWidth, self.imgHeight))
self.canvas = cv2.cvtColor(color_canvas, cv2.COLOR_RGB2GRAY)
To customize the layout, we arrange a number of radio buttons horizontally—one button per image effect mode. Here, the style=wx.RB_GROUP option makes sure that only one of radio buttons can be selected at a time. And to make these changes visible, pnl needs to be added to a list of existing panels—self.panels_vertical:
def augment_layout(self):
""" Add a row of radio buttons below the camera feed. """
# create a horizontal layout with all filter modes as radio buttons
pnl = wx.Panel(self, -1)
self.mode_warm = wx.RadioButton(pnl, -1, 'Warming Filter', (10, 10),
style=wx.RB_GROUP)
self.mode_cool = wx.RadioButton(pnl, -1, 'Cooling Filter', (10, 10))
self.mode_sketch = wx.RadioButton(pnl, -1, 'Pencil Sketch', (10, 10))
self.mode_cartoon = wx.RadioButton(pnl, -1, 'Cartoon', (10, 10))
hbox = wx.BoxSizer(wx.HORIZONTAL)
hbox.Add(self.mode_warm, 1)
hbox.Add(self.mode_cool, 1)
hbox.Add(self.mode_sketch, 1)
hbox.Add(self.mode_cartoon, 1)
pnl.SetSizer(hbox)
# add panel with radio buttons to existing panels in a vertical
# arrangement
self.panels_vertical.Add(pnl, flag=wx.EXPAND | wx.BOTTOM | wx.TOP,
border=1
The last method to be specified is process_frame. Recall that this method is triggered whenever a new camera frame is received. All that we need to do is pick the right image effect to be applied, which depends on the radio button configuration. We simply check which of the buttons is currently selected and call the corresponding render method:
def process_frame(self, frame_rgb: np.ndarray) -> np.ndarray:
"""Process the frame of the camera (or other capture device)
Choose a filter effect based on the which of the radio buttons
was clicked.
:param frame_rgb: Image to process in rgb format, of shape (H, W, 3)
:return: Processed image in rgb format, of shape (H, W, 3)
"""
if self.mode_warm.GetValue():
return self._render_warm(frame_rgb)
elif self.mode_cool.GetValue():
return self._render_cool(frame_rgb)
elif self.mode_sketch.GetValue():
return pencil_sketch_on_canvas(frame_rgb, canvas=self.canvas)
elif self.mode_cartoon.GetValue():
return cartoonize(frame_rgb)
else:
raise NotImplementedError()
And we're done! The following screenshot shows us the output pictures with different filters:
The preceding screenshot shows all of the four filters that we created applied to a single image.
- Python自然語言處理實戰:核心技術與算法
- 單片機應用技術
- Python:Master the Art of Design Patterns
- Jupyter數據科學實戰
- 精通Linux(第2版)
- 愛上micro:bit
- Python Data Science Cookbook
- Python Machine Learning Blueprints:Intuitive data projects you can relate to
- Learning Unreal Engine Game Development
- Sitecore Cookbook for Developers
- Responsive Web Design with jQuery
- Flask開發Web搜索引擎入門與實戰
- Web開發新體驗
- Python高性能編程(第2版)
- Mastering Unity 2017 Game Development with C#(Second Edition)