summaryrefslogtreecommitdiffstats
path: root/src/com/android/gallery3d/filtershow/filters/FilterRedEyeRepresentation.java
blob: 3f823ea1e462b58969a83faf8d3635213923b2f9 (plain)
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
/*
 * Copyright (C) 2013 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.gallery3d.filtershow.filters;

import android.graphics.RectF;

import com.android.gallery3d.R;
import com.android.gallery3d.filtershow.editors.EditorRedEye;

import java.util.Vector;

public class FilterRedEyeRepresentation extends FilterPointRepresentation {
    private static final String LOGTAG = "FilterRedEyeRepresentation";

    public FilterRedEyeRepresentation() {
        super("RedEye",R.string.redeye,EditorRedEye.ID);
        setFilterClass(ImageFilterRedEye.class);
        setOverlayId(R.drawable.photoeditor_effect_redeye);
        setOverlayOnly(true);
    }

    public void addRect(RectF rect, RectF bounds) {
        Vector<RedEyeCandidate> intersects = new Vector<RedEyeCandidate>();
        for (int i = 0; i < getCandidates().size(); i++) {
            RedEyeCandidate r = (RedEyeCandidate) getCandidate(i);
            if (r.intersect(rect)) {
                intersects.add(r);
            }
        }
        for (int i = 0; i < intersects.size(); i++) {
            RedEyeCandidate r = intersects.elementAt(i);
            rect.union(r.mRect);
            bounds.union(r.mBounds);
            removeCandidate(r);
        }
        addCandidate(new RedEyeCandidate(rect, bounds));
    }

}