Notice
Link
- Today
- Total
Recent Posts
Recent Comments
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- kill -9
- Activity 전체화면
- reactnative
- MFC
- 스크롤적용
- 파티션 빠른 삭제
- view 획득
- 코드로 서버 재실행
- pid 찾아 kill
- springboot
- sql exception
- 텍스트컬러
- 터치좌표 view
- DB 계정생성
- Back 키 클릭 감지
- 피쉬랜드
- MySQL
- SQL 마지막날
- SQL 첫날
- c언어
- CSS
- mybatis exception
- springboot 재가동
- CentOS
- vc++
- 가변영역 스크롤
- MariaDB
- ffmpeg
- rn
- 말줌임 CSS
Archives
개발은 하는건가..
카메라 영상 동영상 파일로 저장 본문
반응형
안드로이드에서 MediaRecorder 를 이용하여 카메라 영상을 동영상 파일로 저장하는 것이 겁나게 간단하다~
설명이 필요 없을 듯...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
|
public class VideoRecordActivity extends Activity implements Callback {
private Camera cam;
private MediaRecorder mediaRecorder;
private SurfaceView sv;
private SurfaceHolder sh;
private boolean recording = false;
private Button btnRec = null;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_video_record);
btnRec = (Button) findViewById(R.id.btnRec);
btnRec.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (recording) {
Toast.makeText(VideoRecordActivity.this, "stop", Toast.LENGTH_LONG).show();
mediaRecorder.stop();
mediaRecorder.release();
cam.lock();
recording = false;
btnRec.setText("레코딩");
}
else {
Toast.makeText(VideoRecordActivity.this, "succeed", Toast.LENGTH_LONG).show();
try {
mediaRecorder = new MediaRecorder();
cam.unlock();
mediaRecorder.setCamera(cam);
mediaRecorder.setAudioSource(MediaRecorder.AudioSource.MIC);
mediaRecorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);
mediaRecorder.setOutputFormat(MediaRecorder.OutputFormat.MPEG_4);
mediaRecorder.setAudioEncoder(MediaRecorder.AudioEncoder.AAC);
// mediaRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.MPEG_4_SP);
mediaRecorder.setVideoEncoder(MediaRecorder.VideoEncoder.H264);
mediaRecorder.setVideoEncodingBitRate(1024 * 1024);
mediaRecorder.setVideoSize(640, 480);
mediaRecorder.setVideoFrameRate(15);
// 최대 녹화시간 설정
// mediaRecorder.setMaxDuration(max_duration_ms);
// 최대 파일 사이즈 설정
// mediaRecorder.setMaxFileSize(max_filesize_bytes);
// mediaRecorder.setOrientationHint(90);
mediaRecorder.setOutputFile("/storage/sdcard0/rec.mp4");
// mediaRecorder.setPreviewDisplay(sh.getSurface());
mediaRecorder.prepare();
mediaRecorder.start();
recording = true;
Toast.makeText(VideoRecordActivity.this,
"start",
Toast.LENGTH_LONG).show();
btnRec.setText("중단");
}
catch (Exception ex) {
ex.printStackTrace();
mediaRecorder.release();
Toast.makeText(VideoRecordActivity.this,
"error:" + ex.getMessage(),
Toast.LENGTH_LONG).show();
return;
}
}
}
});
}
@Override
protected void onStart() {
super.onStart();
setting();
}
private void setting() {
cam = Camera.open(0);
// cam.setDisplayOrientation(90);
sv = (SurfaceView) findViewById(R.id.surfaceView);
sh = sv.getHolder();
sh.addCallback(this);
sh.setType(SurfaceHolder.SURFACE_TYPE_PUSH_BUFFERS);
}
@Override
public void surfaceCreated(SurfaceHolder holder) {
try {
if (cam != null) {
cam.setPreviewDisplay(holder);
cam.startPreview();
}
} catch (IOException e) {
}
}
@Override
public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
refreshCamera(cam);
}
@Override
public void surfaceDestroyed(SurfaceHolder holder) {
cam.stopPreview();
cam.release();
}
public void refreshCamera(Camera camera) {
if (sh.getSurface() == null) {
return;
}
try {
cam.stopPreview();
} catch (Exception e) {
// ignore: tried to stop a non-existent preview
}
setCamera(camera);
try {
cam.setPreviewDisplay(sh);
cam.startPreview();
} catch (Exception e) {
}
}
public void setCamera(Camera camera) {
cam = camera;
}
}
|
cs |
'Java, Android' 카테고리의 다른 글
Android ListView Divider 없에기 (0) | 2022.06.15 |
---|---|
Android 애니메이션 drawable (0) | 2022.06.14 |
[Java] DB 에서 BLOB (바이너리 데이터) 읽어오기 (0) | 2022.03.08 |
컬러 이모지 아이콘이 지원되지 않는 4.x 버젼 이하에서 이모지 지원하기 (0) | 2018.11.02 |
파일 사이즈가 큰 Gif 파일에서 Preview 용 Bmp 추출하기 (1) | 2018.11.02 |
Comments