Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
O
opencv
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
opencv
Commits
3998b41d
Commit
3998b41d
authored
Jul 04, 2019
by
Alexander Alekhin
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
android: JavaCamera2View use calculateCameraFrameSize() method
from CameraBridgeViewBase (common base with JavaCameraView)
parent
57fae4a6
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
31 additions
and
18 deletions
+31
-18
JavaCamera2View.java
...r/android-21/java/org/opencv/android/JavaCamera2View.java
+22
-17
CameraBridgeViewBase.java
...android/java/org/opencv/android/CameraBridgeViewBase.java
+9
-1
No files found.
modules/java/generator/android-21/java/org/opencv/android/JavaCamera2View.java
View file @
3998b41d
...
...
@@ -2,6 +2,7 @@ package org.opencv.android;
import
java.nio.ByteBuffer
;
import
java.util.Arrays
;
import
java.util.List
;
import
android.annotation.TargetApi
;
import
android.content.Context
;
...
...
@@ -24,6 +25,7 @@ import android.view.ViewGroup.LayoutParams;
import
org.opencv.core.CvType
;
import
org.opencv.core.Mat
;
import
org.opencv.core.Size
;
import
org.opencv.imgproc.Imgproc
;
/**
...
...
@@ -248,6 +250,20 @@ public class JavaCamera2View extends CameraBridgeViewBase {
}
}
public
static
class
JavaCameraSizeAccessor
implements
ListItemAccessor
{
@Override
public
int
getWidth
(
Object
obj
)
{
android
.
util
.
Size
size
=
(
android
.
util
.
Size
)
obj
;
return
size
.
getWidth
();
}
@Override
public
int
getHeight
(
Object
obj
)
{
android
.
util
.
Size
size
=
(
android
.
util
.
Size
)
obj
;
return
size
.
getHeight
();
}
}
boolean
calcPreviewSize
(
final
int
width
,
final
int
height
)
{
Log
.
i
(
LOGTAG
,
"calcPreviewSize: "
+
width
+
"x"
+
height
);
if
(
mCameraID
==
null
)
{
...
...
@@ -258,26 +274,15 @@ public class JavaCamera2View extends CameraBridgeViewBase {
try
{
CameraCharacteristics
characteristics
=
manager
.
getCameraCharacteristics
(
mCameraID
);
StreamConfigurationMap
map
=
characteristics
.
get
(
CameraCharacteristics
.
SCALER_STREAM_CONFIGURATION_MAP
);
int
bestWidth
=
0
,
bestHeight
=
0
;
float
aspect
=
(
float
)
width
/
height
;
android
.
util
.
Size
[]
sizes
=
map
.
getOutputSizes
(
ImageReader
.
class
);
bestWidth
=
sizes
[
0
].
getWidth
();
bestHeight
=
sizes
[
0
].
getHeight
();
for
(
android
.
util
.
Size
sz
:
sizes
)
{
int
w
=
sz
.
getWidth
(),
h
=
sz
.
getHeight
();
Log
.
d
(
LOGTAG
,
"trying size: "
+
w
+
"x"
+
h
);
if
(
width
>=
w
&&
height
>=
h
&&
bestWidth
<=
w
&&
bestHeight
<=
h
&&
Math
.
abs
(
aspect
-
(
float
)
w
/
h
)
<
0.2
)
{
bestWidth
=
w
;
bestHeight
=
h
;
}
}
Log
.
i
(
LOGTAG
,
"best size: "
+
bestWidth
+
"x"
+
bestHeight
);
assert
(!(
bestWidth
==
0
||
bestHeight
==
0
));
if
(
mPreviewSize
.
getWidth
()
==
bestWidth
&&
mPreviewSize
.
getHeight
()
==
bestHeight
)
List
<
android
.
util
.
Size
>
sizes_list
=
Arrays
.
asList
(
sizes
);
Size
frameSize
=
calculateCameraFrameSize
(
sizes_list
,
new
JavaCameraSizeAccessor
(),
width
,
height
);
Log
.
i
(
LOGTAG
,
"Selected preview size to "
+
Integer
.
valueOf
((
int
)
frameSize
.
width
)
+
"x"
+
Integer
.
valueOf
((
int
)
frameSize
.
height
));
assert
(!(
frameSize
.
width
==
0
||
frameSize
.
height
==
0
));
if
(
mPreviewSize
.
getWidth
()
==
frameSize
.
width
&&
mPreviewSize
.
getHeight
()
==
frameSize
.
height
)
return
false
;
else
{
mPreviewSize
=
new
android
.
util
.
Size
(
bestWidth
,
bestH
eight
);
mPreviewSize
=
new
android
.
util
.
Size
(
(
int
)
frameSize
.
width
,
(
int
)
frameSize
.
h
eight
);
return
true
;
}
}
catch
(
CameraAccessException
e
)
{
...
...
modules/java/generator/android/java/org/opencv/android/CameraBridgeViewBase.java
View file @
3998b41d
...
...
@@ -30,7 +30,7 @@ import android.view.SurfaceView;
public
abstract
class
CameraBridgeViewBase
extends
SurfaceView
implements
SurfaceHolder
.
Callback
{
private
static
final
String
TAG
=
"CameraBridge"
;
pr
ivate
static
final
int
MAX_UNSPECIFIED
=
-
1
;
pr
otected
static
final
int
MAX_UNSPECIFIED
=
-
1
;
private
static
final
int
STOPPED
=
0
;
private
static
final
int
STARTED
=
1
;
...
...
@@ -481,6 +481,7 @@ public abstract class CameraBridgeViewBase extends SurfaceView implements Surfac
for
(
Object
size
:
supportedSizes
)
{
int
width
=
accessor
.
getWidth
(
size
);
int
height
=
accessor
.
getHeight
(
size
);
Log
.
d
(
TAG
,
"trying size: "
+
width
+
"x"
+
height
);
if
(
width
<=
maxAllowedWidth
&&
height
<=
maxAllowedHeight
)
{
if
(
width
>=
calcWidth
&&
height
>=
calcHeight
)
{
...
...
@@ -489,6 +490,13 @@ public abstract class CameraBridgeViewBase extends SurfaceView implements Surfac
}
}
}
if
((
calcWidth
==
0
||
calcHeight
==
0
)
&&
supportedSizes
.
size
()
>
0
)
{
Log
.
i
(
TAG
,
"fallback to the first frame size"
);
Object
size
=
supportedSizes
.
get
(
0
);
calcWidth
=
accessor
.
getWidth
(
size
);
calcHeight
=
accessor
.
getHeight
(
size
);
}
return
new
Size
(
calcWidth
,
calcHeight
);
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment