alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 1 | package com.savoirfairelinux.sflphone.model; |
| 2 | |
| 3 | import android.content.Context; |
| 4 | import android.graphics.Bitmap; |
| 5 | import android.graphics.BitmapFactory; |
| 6 | import android.graphics.Canvas; |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 7 | import android.graphics.Color; |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 8 | import android.graphics.Paint; |
Adrien Béraud | 25fc409 | 2013-05-06 15:28:39 +1000 | [diff] [blame] | 9 | import android.graphics.PointF; |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 10 | import android.graphics.PorterDuff.Mode; |
| 11 | import android.graphics.PorterDuffXfermode; |
| 12 | import android.graphics.RectF; |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 13 | import android.util.Log; |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 14 | |
| 15 | import com.savoirfairelinux.sflphone.R; |
Alexandre Lision | 6e8931e | 2013-09-19 16:49:34 -0400 | [diff] [blame] | 16 | import com.savoirfairelinux.sflphone.adapters.ContactPictureTask; |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 17 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 18 | public class Bubble { |
alision | 806e18e | 2013-06-21 15:30:17 -0400 | [diff] [blame] | 19 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 20 | // A Bitmap object that is going to be passed to the BitmapShader |
| 21 | private Bitmap internalBMP, externalBMP; |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 22 | |
alision | 806e18e | 2013-06-21 15:30:17 -0400 | [diff] [blame] | 23 | public SipCall associated_call; |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 24 | private PointF pos = new PointF(); |
| 25 | private RectF bounds; |
| 26 | public float target_scale = 1.f; |
| 27 | private float radius; |
| 28 | private float scale = 1.f; |
| 29 | private float density = 1.f; |
| 30 | public PointF speed = new PointF(0, 0); |
| 31 | public PointF last_speed = new PointF(); |
| 32 | public PointF attractor = null; |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 33 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 34 | public boolean dragged = false; |
Alexandre Lision | 0edf18c | 2013-09-23 17:35:50 -0400 | [diff] [blame] | 35 | |
| 36 | public boolean markedToDie = false; |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 37 | public long last_drag; |
| 38 | public boolean expanded; // determine if we draw the buttons around the bubble |
| 39 | private Bitmap saved_photo; |
alision | 729b0a2 | 2013-07-02 11:57:33 -0400 | [diff] [blame] | 40 | private float expanded_radius; |
alision | 4a0eb09 | 2013-05-07 13:52:03 -0400 | [diff] [blame] | 41 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 42 | public void setAttractor(PointF attractor) { |
| 43 | this.attractor = attractor; |
| 44 | } |
Adrien Béraud | e0ef0c2 | 2013-05-18 01:56:27 +1000 | [diff] [blame] | 45 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 46 | public Bubble(Context context, SipCall call, float x, float y, float size) { |
| 47 | |
| 48 | Bitmap photo = null; |
| 49 | if (call.getContact().getPhoto_id() > 0) { |
Alexandre Lision | 6e8931e | 2013-09-19 16:49:34 -0400 | [diff] [blame] | 50 | photo = ContactPictureTask.loadContactPhoto(context.getContentResolver(), call.getContact().getId()); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 51 | } else { |
| 52 | photo = BitmapFactory.decodeResource(context.getResources(), R.drawable.ic_contact_picture); |
| 53 | } |
| 54 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 55 | saved_photo = photo; |
| 56 | internalBMP = Bitmap.createScaledBitmap(photo, (int) size, (int) size, false); |
alision | 91d2859 | 2013-07-02 14:33:53 -0400 | [diff] [blame] | 57 | internalBMP.setHasAlpha(true); |
alision | 806e18e | 2013-06-21 15:30:17 -0400 | [diff] [blame] | 58 | associated_call = call; |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 59 | pos.set(x, y); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 60 | radius = internalBMP.getWidth() / 2; |
alision | 729b0a2 | 2013-07-02 11:57:33 -0400 | [diff] [blame] | 61 | expanded_radius = (float) (size * 1.5); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 62 | bounds = new RectF(pos.x - radius, pos.y - radius, pos.x + radius, pos.y + radius); |
| 63 | attractor = new PointF(x, y); |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 64 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 65 | Paint circlePaint = new Paint(Paint.ANTI_ALIAS_FLAG); |
| 66 | circlePaint.setStyle(Paint.Style.FILL); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 67 | Bitmap circle = Bitmap.createBitmap(internalBMP.getWidth(), internalBMP.getHeight(), Bitmap.Config.ARGB_8888); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 68 | Canvas circle_drawer = new Canvas(circle); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 69 | circle_drawer.drawOval(new RectF(0, 0, internalBMP.getWidth(), internalBMP.getHeight()), circlePaint); |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 70 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 71 | externalBMP = Bitmap.createBitmap(internalBMP.getWidth(), internalBMP.getHeight(), Bitmap.Config.ARGB_8888); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 72 | Canvas canvas = new Canvas(externalBMP); |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 73 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 74 | circlePaint.setFilterBitmap(false); |
| 75 | canvas.drawBitmap(internalBMP, 0, 0, circlePaint); |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 76 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 77 | circlePaint.setXfermode(new PorterDuffXfermode(Mode.DST_IN)); |
| 78 | canvas.drawBitmap(circle, 0, 0, circlePaint); |
| 79 | } |
Adrien Béraud | 25fc409 | 2013-05-06 15:28:39 +1000 | [diff] [blame] | 80 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 81 | public Bitmap getBitmap() { |
| 82 | return externalBMP; |
| 83 | } |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 84 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 85 | public RectF getBounds() { |
| 86 | return bounds; |
| 87 | } |
Adrien Béraud | 3326888 | 2013-05-18 03:41:15 +1000 | [diff] [blame] | 88 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 89 | public void set(float x, float y, float s) { |
| 90 | scale = s; |
| 91 | pos.x = x; |
| 92 | pos.y = y; |
| 93 | float rad = scale * getRadius() * density; |
| 94 | bounds.set(pos.x - rad, pos.y - rad, pos.x + rad, pos.y + rad); |
| 95 | } |
Adrien Béraud | 25fc409 | 2013-05-06 15:28:39 +1000 | [diff] [blame] | 96 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 97 | public float getPosX() { |
| 98 | return pos.x; |
| 99 | } |
Adrien Béraud | 25fc409 | 2013-05-06 15:28:39 +1000 | [diff] [blame] | 100 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 101 | public float getPosY() { |
| 102 | return pos.y; |
| 103 | } |
Adrien Béraud | 6bbce91 | 2013-05-24 00:48:13 +1000 | [diff] [blame] | 104 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 105 | public void setPos(float x, float y) { |
| 106 | set(x, y, scale); |
| 107 | } |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 108 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 109 | public PointF getPos() { |
| 110 | return pos; |
| 111 | } |
Adrien Béraud | 25fc409 | 2013-05-06 15:28:39 +1000 | [diff] [blame] | 112 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 113 | public float getScale() { |
| 114 | return scale; |
| 115 | } |
Adrien Béraud | 25fc409 | 2013-05-06 15:28:39 +1000 | [diff] [blame] | 116 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 117 | public void setScale(float s) { |
| 118 | set(pos.x, pos.y, s); |
| 119 | } |
Adrien Béraud | 25fc409 | 2013-05-06 15:28:39 +1000 | [diff] [blame] | 120 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 121 | public float getRadius() { |
| 122 | return expanded ? expanded_radius : radius; |
| 123 | } |
Adrien Béraud | 6bbce91 | 2013-05-24 00:48:13 +1000 | [diff] [blame] | 124 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 125 | /** |
| 126 | * Point intersection test. |
| 127 | */ |
| 128 | boolean intersects(float x, float y) { |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 129 | float dx = x - pos.x; |
| 130 | float dy = y - pos.y; |
alision | 50fa072 | 2013-06-25 17:29:44 -0400 | [diff] [blame] | 131 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 132 | return dx * dx + dy * dy < getRadius() * density * getRadius() * density; |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 133 | } |
Adrien Béraud | 6bbce91 | 2013-05-24 00:48:13 +1000 | [diff] [blame] | 134 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 135 | /** |
| 136 | * Other circle intersection test. |
| 137 | */ |
| 138 | boolean intersects(float x, float y, float radius) { |
| 139 | float dx = x - pos.x, dy = y - pos.y; |
| 140 | float tot_radius = getRadius() + radius; |
| 141 | return dx * dx + dy * dy < tot_radius * tot_radius; |
| 142 | } |
Adrien Béraud | 6bbce91 | 2013-05-24 00:48:13 +1000 | [diff] [blame] | 143 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 144 | public void setDensity(float density) { |
| 145 | this.density = density; |
| 146 | } |
Adrien Béraud | 25fc409 | 2013-05-06 15:28:39 +1000 | [diff] [blame] | 147 | |
alision | 729b0a2 | 2013-07-02 11:57:33 -0400 | [diff] [blame] | 148 | public void expand() { |
Adrien Béraud | 0c9bd8f | 2013-05-30 16:16:57 +1000 | [diff] [blame] | 149 | |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 150 | expanded = true; |
| 151 | internalBMP = Bitmap.createScaledBitmap(saved_photo, (int) (2 * radius), (int) (2 * radius), false); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 152 | |
| 153 | bounds = new RectF(pos.x - getRadius(), pos.y - getRadius(), pos.x + getRadius(), pos.y + getRadius()); |
| 154 | |
| 155 | Paint circlePaint = new Paint(Paint.ANTI_ALIAS_FLAG); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 156 | circlePaint.setAntiAlias(true); |
| 157 | circlePaint.setDither(true); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 158 | circlePaint.setStyle(Paint.Style.FILL); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 159 | circlePaint.setColor(Color.RED); |
| 160 | |
| 161 | Bitmap circle = Bitmap.createBitmap(internalBMP.getWidth(), internalBMP.getHeight(), Bitmap.Config.ARGB_8888); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 162 | Canvas circle_drawer = new Canvas(circle); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 163 | circle_drawer.drawOval(new RectF(0, 0, internalBMP.getWidth(), internalBMP.getHeight()), circlePaint); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 164 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 165 | Canvas canvas = new Canvas(internalBMP); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 166 | circlePaint.setFilterBitmap(false); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 167 | canvas.drawBitmap(internalBMP, 0, 0, circlePaint); |
| 168 | |
| 169 | circlePaint.setXfermode(new PorterDuffXfermode(Mode.DST_IN)); |
| 170 | canvas.drawBitmap(circle, 0, 0, circlePaint); |
| 171 | circle_drawer.drawOval(new RectF(0, 0, internalBMP.getWidth(), internalBMP.getHeight()), circlePaint); |
| 172 | |
| 173 | externalBMP = Bitmap.createBitmap((int) (getRadius() * 2), (int) (getRadius() * 2), Bitmap.Config.ARGB_8888); |
| 174 | Canvas canvasf = new Canvas(externalBMP); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 175 | |
| 176 | Paint mPaintPath = new Paint(Paint.ANTI_ALIAS_FLAG); |
| 177 | mPaintPath.setStyle(Paint.Style.FILL); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 178 | mPaintPath.setColor(0xAA000000); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 179 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 180 | Paint fatality = new Paint(Paint.ANTI_ALIAS_FLAG); |
| 181 | fatality.setAntiAlias(true); |
| 182 | fatality.setDither(true); |
| 183 | fatality.setStyle(Paint.Style.FILL); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 184 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 185 | canvasf.drawOval(new RectF(0, 0, getRadius() * 2, getRadius() * 2), mPaintPath); // background with buttons |
Alexandre Lision | 0edf18c | 2013-09-23 17:35:50 -0400 | [diff] [blame] | 186 | |
alision | 465ceba | 2013-07-04 09:24:30 -0400 | [diff] [blame] | 187 | int[] allpixels = new int[internalBMP.getHeight() * internalBMP.getWidth()]; |
| 188 | |
| 189 | internalBMP.getPixels(allpixels, 0, internalBMP.getWidth(), 0, 0, internalBMP.getWidth(), internalBMP.getHeight()); |
| 190 | for (int i = 0; i < internalBMP.getHeight() * internalBMP.getWidth(); i++) { |
| 191 | // Log.i("Bubble", "allpixels[i]:"+allpixels[i]); |
| 192 | if (allpixels[i] == Color.BLACK) { |
alision | 465ceba | 2013-07-04 09:24:30 -0400 | [diff] [blame] | 193 | allpixels[i] = 0xAA000000; |
| 194 | } |
| 195 | } |
| 196 | internalBMP.setPixels(allpixels, 0, internalBMP.getWidth(), 0, 0, internalBMP.getWidth(), internalBMP.getHeight()); |
Alexandre Lision | 0edf18c | 2013-09-23 17:35:50 -0400 | [diff] [blame] | 197 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 198 | canvasf.drawBitmap(internalBMP, (float) (getRadius() - radius), (float) (getRadius() - radius), fatality); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 199 | |
| 200 | } |
| 201 | |
| 202 | public void retract() { |
| 203 | expanded = false; |
| 204 | internalBMP = Bitmap.createScaledBitmap(saved_photo, (int) (2 * radius), (int) (2 * radius), false); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 205 | |
| 206 | bounds = new RectF(pos.x - getRadius(), pos.y - getRadius(), pos.x + getRadius(), pos.y + getRadius()); |
| 207 | |
| 208 | Paint circlePaint = new Paint(Paint.ANTI_ALIAS_FLAG); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 209 | circlePaint.setAntiAlias(true); |
| 210 | circlePaint.setDither(true); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 211 | circlePaint.setStyle(Paint.Style.FILL); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 212 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 213 | Bitmap circle = Bitmap.createBitmap(internalBMP.getWidth(), internalBMP.getHeight(), Bitmap.Config.ARGB_8888); |
| 214 | Canvas circle_drawer = new Canvas(circle); |
| 215 | circle_drawer.drawOval(new RectF(0, 0, internalBMP.getWidth(), internalBMP.getHeight()), circlePaint); |
| 216 | |
| 217 | externalBMP = Bitmap.createBitmap(internalBMP.getWidth(), internalBMP.getHeight(), Bitmap.Config.ARGB_8888); |
alision | 2ec64f9 | 2013-06-17 17:28:58 -0400 | [diff] [blame] | 218 | Canvas canvas = new Canvas(externalBMP); |
| 219 | |
| 220 | circlePaint.setFilterBitmap(false); |
| 221 | canvas.drawBitmap(internalBMP, 0, 0, circlePaint); |
| 222 | |
| 223 | circlePaint.setXfermode(new PorterDuffXfermode(Mode.DST_IN)); |
| 224 | canvas.drawBitmap(circle, 0, 0, circlePaint); |
| 225 | |
| 226 | } |
alision | df1dac9 | 2013-06-27 17:35:53 -0400 | [diff] [blame] | 227 | |
| 228 | /** |
| 229 | * Compare bubbles based on call ID |
| 230 | */ |
| 231 | @Override |
| 232 | public boolean equals(Object c) { |
| 233 | if (c instanceof Bubble && ((Bubble) c).associated_call.getCallId().contentEquals(associated_call.getCallId())) { |
| 234 | return true; |
| 235 | } |
| 236 | return false; |
| 237 | |
| 238 | } |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 239 | |
| 240 | /** |
Alexandre Lision | c51ccb1 | 2013-09-11 16:00:30 -0400 | [diff] [blame] | 241 | * When the bubble is expanded we need to check on wich action button the user tap |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 242 | * |
| 243 | * @param x |
| 244 | * @param y |
| 245 | * @return |
| 246 | */ |
| 247 | public int getAction(float x, float y) { |
| 248 | float relativeX = x - pos.x + externalBMP.getWidth() / 2; |
| 249 | float relativeY = y - pos.y + externalBMP.getHeight() / 2; |
alision | 91d2859 | 2013-07-02 14:33:53 -0400 | [diff] [blame] | 250 | |
| 251 | Log.i("Bubble", "relativeX:" + relativeX); |
| 252 | Log.i("Bubble", "relativeY:" + relativeY); |
| 253 | |
| 254 | Log.i("Bubble", "pos.x:" + pos.x); |
| 255 | Log.i("Bubble", "pos.y:" + pos.y); |
| 256 | |
| 257 | Log.i("Bubble", "externalBMP.getWidth():" + externalBMP.getWidth()); |
| 258 | Log.i("Bubble", "externalBMP.getHeight():" + externalBMP.getHeight()); |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 259 | |
| 260 | // Hold - Left |
| 261 | if (relativeX < externalBMP.getWidth() / 3 && relativeY > externalBMP.getHeight() / 3) { |
| 262 | return 1; |
| 263 | } |
alision | 91d2859 | 2013-07-02 14:33:53 -0400 | [diff] [blame] | 264 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 265 | // Record - Right |
| 266 | if (relativeX > externalBMP.getWidth() * 2 / 3 && relativeY > externalBMP.getHeight() / 3) { |
| 267 | return 2; |
| 268 | } |
alision | 91d2859 | 2013-07-02 14:33:53 -0400 | [diff] [blame] | 269 | |
alision | 34673e6 | 2013-06-25 14:40:07 -0400 | [diff] [blame] | 270 | // Transfer - Bottom |
| 271 | if (relativeY > externalBMP.getHeight() * 2 / 3) { |
| 272 | return 3; |
| 273 | } |
| 274 | return 0; |
| 275 | } |
alision | 729b0a2 | 2013-07-02 11:57:33 -0400 | [diff] [blame] | 276 | |
Alexandre Lision | 0edf18c | 2013-09-23 17:35:50 -0400 | [diff] [blame] | 277 | public boolean isOnBorder(float w, float h) { |
| 278 | return (bounds.left < 0 || bounds.right > w || bounds.top < 0 || bounds.bottom > h); |
| 279 | } |
| 280 | |
alision | 729b0a2 | 2013-07-02 11:57:33 -0400 | [diff] [blame] | 281 | /** |
| 282 | * Always return the normal radius of the bubble |
alision | 91d2859 | 2013-07-02 14:33:53 -0400 | [diff] [blame] | 283 | * |
alision | 729b0a2 | 2013-07-02 11:57:33 -0400 | [diff] [blame] | 284 | * @return |
| 285 | */ |
| 286 | public float getRetractedRadius() { |
| 287 | return radius; |
| 288 | } |
| 289 | |
| 290 | public int getHoldStatus() { |
alision | 91d2859 | 2013-07-02 14:33:53 -0400 | [diff] [blame] | 291 | if (associated_call.isOnHold()) |
alision | 729b0a2 | 2013-07-02 11:57:33 -0400 | [diff] [blame] | 292 | return R.string.action_call_unhold; |
| 293 | else |
| 294 | return R.string.action_call_hold; |
| 295 | } |
| 296 | |
| 297 | public int getRecordStatus() { |
alision | 91d2859 | 2013-07-02 14:33:53 -0400 | [diff] [blame] | 298 | if (associated_call.isRecording()) |
alision | 729b0a2 | 2013-07-02 11:57:33 -0400 | [diff] [blame] | 299 | return R.string.action_call_stop_record; |
| 300 | else |
| 301 | return R.string.action_call_record; |
| 302 | } |
alision | fe9cf71 | 2013-05-03 17:26:08 -0400 | [diff] [blame] | 303 | } |