我想建立一個應用程序在native android中着色圖像,它具有圖像,我想知道如何檢測圖像邊框,以及如何檢測不同的形狀並在其中填充顏色? 示例應用程序的鏈接:https://play.google.com/store/apps/details?id=kidgames.coloring.pages&hl=en如何識別不同的形狀並在android中填充它們的顏色?
1
A
回答
2
你可以用顏色填充算法。
見鏈接:
Flood Fill Algorithm
private void FloodFill(Bitmap bmp, Point pt, int targetColor, int replacementColor){
Queue<Point> q = new LinkedList<Point>();
q.add(pt);
while (q.size() > 0) {
Point n = q.poll();
if (bmp.getPixel(n.x, n.y) != targetColor)
continue;
Point w = n, e = new Point(n.x + 1, n.y);
while ((w.x > 0) && (bmp.getPixel(w.x, w.y) == targetColor)) {
bmp.setPixel(w.x, w.y, replacementColor);
if ((w.y > 0) && (bmp.getPixel(w.x, w.y - 1) == targetColor))
q.add(new Point(w.x, w.y - 1));
if ((w.y < bmp.getHeight() - 1)
&& (bmp.getPixel(w.x, w.y + 1) == targetColor))
q.add(new Point(w.x, w.y + 1));
w.x--;
}
while ((e.x < bmp.getWidth() - 1)
&& (bmp.getPixel(e.x, e.y) == targetColor)) {
bmp.setPixel(e.x, e.y, replacementColor);
if ((e.y > 0) && (bmp.getPixel(e.x, e.y - 1) == targetColor))
q.add(new Point(e.x, e.y - 1));
if ((e.y < bmp.getHeight() - 1)
&& (bmp.getPixel(e.x, e.y + 1) == targetColor))
q.add(new Point(e.x, e.y + 1));
e.x++;
}
}}
+0
謝謝Chetan先生,但是你能否澄清一下,它是否會填滿一個點擊的形狀,或者它將不得不通過觸摸屏來填充它? –
+0
它將填滿邊界下的全部區域。點擊任何形狀後。 –
+0
謝謝..將盡力實施 –
相關問題
- 1. 如何用顏色填充形狀
- 2. Opengl不規則形狀顏色填充
- 3. 填充顏色的形狀像Paper.io
- 4. Android Opengl 2形狀不同的顏色
- 5. 填充顏色和線條顏色的填充和空心形狀
- 6. 如何使用顏色填充自由繪製的形狀
- 7. 如何在多個多邊形Google地圖V3中填充不同的顏色?
- 8. 具有不同填充顏色的geom_area
- 9. Matlab填充白色形狀
- 10. 更改ggplot中點的顏色填充和形狀
- 11. 爲圖像添加填充以使它們形狀相同
- 12. 多邊形不顯示填充顏色
- 13. 如何計數。 MS Excell中的單元取決於它們的填充顏色
- 14. 如何在UIBezierPath中填充顏色?
- 15. 在android中繪製填充形狀mapview
- 16. 如何合併顏色和形狀?
- 17. 如何綁定多個顏色來填充WPF中的矩形?
- 18. 在Swift中填充顏色
- 19. 顏色填充在柱中
- 20. 色彩柱系列在x軸的不同間隔上填充不同的顏色填充同一系列?
- 21. 如何繪製不同筆畫和填充顏色的文字?
- 22. iphone更改在上下文中繪製的形狀的填充顏色
- 23. 如何識別畫布中的形狀?
- 24. SVG/CSS - 用不同的顏色填充不同的路徑
- 25. itunes中的顏色識別
- 26. 如何填充顏色只在在iPhone
- 27. 在javaCV中識別顏色
- 28. html canvas不填充顏色
- 29. 如何設置TextRange的填充顏色?
- 30. 誰可以使用JQuery動畫以顏色填充此形狀?
退房這個答案https://stackoverflow.com/a/9748429/2556660。 – RameshJaga