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
|
/*
* Copyright (C) 2011 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.android.camera.ui;
import com.android.camera.R;
import com.android.camera.Util;
import android.content.Context;
import android.util.AttributeSet;
import android.view.MotionEvent;
import android.view.View;
/**
* A view that contains camera zoom control and its layout.
*/
public class ZoomControlBar extends ZoomControl {
private static final String TAG = "ZoomControlBar";
private static final int STOP_ZOOM_BUFFER = Util.dpToPixel(30);
private View mBar;
public ZoomControlBar(Context context, AttributeSet attrs) {
super(context, attrs);
mBar = new View(context);
mBar.setBackgroundResource(R.drawable.ic_zoom_big);
addView(mBar);
}
@Override
public boolean dispatchTouchEvent(MotionEvent event) {
if (!onFilterTouchEventForSecurity(event)) return false;
int action = event.getAction();
if (!isEnabled()) return false;
double y = (double) event.getY();
int offset = getHeight() / 2;
// For left-hand users, as the device is rotated for 180 degree for
// landscape mode, the zoom-in bottom should be on the top, so the
// position should be reversed.
int delta;
if (mDegree == 180) {
delta = offset - (int) y;
} else {
delta = (int) y - offset;
}
// We need some space to stop zooming.
mSliderPosition = (Math.abs(delta) < STOP_ZOOM_BUFFER) ? 0 : delta;
// TODO: add fast zoom change here
switch (action) {
case MotionEvent.ACTION_OUTSIDE:
case MotionEvent.ACTION_UP:
case MotionEvent.ACTION_CANCEL:
closeZoomControl();
break;
default:
requestLayout();
}
return true;
}
@Override
public void setDegree(int degree) {
// layout for the left-hand camera control
if ((degree == 180) || (mDegree == 180)) requestLayout();
super.setDegree(degree);
}
@Override
protected void onLayout(
boolean changed, int left, int top, int right, int bottom) {
int width = right - left;
int height = bottom - top;
int h = height / 2;
int pos;
// For left-hand users, as the device is rotated for 180 degree,
// the zoom-in button should be on the top.
if (mDegree == 180) {
pos = h - mSliderPosition - width / 2;
mZoomOut.layout(0, top, width, top + width);
mZoomIn.layout(0, bottom - width, width, bottom);
} else {
pos = h + mSliderPosition - width / 2;
mZoomIn.layout(0, top, width, top + width);
mZoomOut.layout(0, bottom - width, width, bottom);
}
mBar.layout(0, top + width, width, bottom - width);
// TODO: fix the pos once we have correct zoom_big asset.
if (pos < 3 * width / 4) {
pos = 3 * width / 4;
} else if (pos > (height - (7 * width / 4))) {
pos = height - (7 * width / 4);
}
mZoomSlider.layout(0, pos, width, pos + width);
}
}
|