19066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/*
29066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  Licensed to the Apache Software Foundation (ASF) under one or more
39066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  contributor license agreements.  See the NOTICE file distributed with
49066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  this work for additional information regarding copyright ownership.
59066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  The ASF licenses this file to You under the Apache License, Version 2.0
69066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  (the "License"); you may not use this file except in compliance with
79066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  the License.  You may obtain a copy of the License at
89066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
99066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *     http://www.apache.org/licenses/LICENSE-2.0
109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  Unless required by applicable law or agreed to in writing, software
129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  distributed under the License is distributed on an "AS IS" BASIS,
139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  See the License for the specific language governing permissions and
159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *  limitations under the License.
169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @author Alexey A. Petrenko
199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @version $Revision$
209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpackage java.awt;
239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project/**
259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * The BufferCapabilities class represents the capabilities and other properties
269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * of the image buffers.
279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project *
289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project * @since Android 1.0
299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project */
309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Projectpublic class BufferCapabilities implements Cloneable {
319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * The front buffer capabilities.
349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private final ImageCapabilities frontBufferCapabilities;
369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * The back buffer capabilities.
399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private final ImageCapabilities backBufferCapabilities;
419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * The flip contents.
449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    private final FlipContents flipContents;
469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Instantiates a new BufferCapabilities object.
499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param frontBufferCapabilities
519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            the front buffer capabilities, can not be null.
529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param backBufferCapabilities
539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            the the back and intermediate buffers capabilities, can not be
549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            null.
559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @param flipContents
569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            the back buffer contents after page flipping, null if page
579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *            flipping is not used.
589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public BufferCapabilities(ImageCapabilities frontBufferCapabilities,
609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            ImageCapabilities backBufferCapabilities, FlipContents flipContents) {
619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        if (frontBufferCapabilities == null || backBufferCapabilities == null) {
629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            throw new IllegalArgumentException();
639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        this.frontBufferCapabilities = frontBufferCapabilities;
669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        this.backBufferCapabilities = backBufferCapabilities;
679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        this.flipContents = flipContents;
689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Returns a copy of the BufferCapabilities object.
729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return a copy of the BufferCapabilities object.
749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    @Override
769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public Object clone() {
779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return new BufferCapabilities(frontBufferCapabilities, backBufferCapabilities, flipContents);
789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Gets the image capabilities of the front buffer.
829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return the ImageCapabilities object represented capabilities of the
849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         front buffer.
859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public ImageCapabilities getFrontBufferCapabilities() {
879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return frontBufferCapabilities;
889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Gets the image capabilities of the back buffer.
929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return the ImageCapabilities object represented capabilities of the back
949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         buffer.
959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
969066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public ImageCapabilities getBackBufferCapabilities() {
979066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return backBufferCapabilities;
989066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
999066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1009066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1019066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Gets the flip contents of the back buffer after page-flipping.
1029066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
1039066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return the FlipContents of the back buffer after page-flipping.
1049066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1059066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public FlipContents getFlipContents() {
1069066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return flipContents;
1079066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1089066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1099066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1109066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Checks if the buffer strategy uses page flipping.
1119066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
1129066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return true, if the buffer strategy uses page flipping, false otherwise.
1139066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1149066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean isPageFlipping() {
1159066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return flipContents != null;
1169066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1179066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1189066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1199066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Checks if page flipping is only available in full-screen mode.
1209066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
1219066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return true, if page flipping is only available in full-screen mode,
1229066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         false otherwise.
1239066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1249066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean isFullScreenRequired() {
1259066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return false;
1269066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1279066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1289066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1299066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * Checks if page flipping can be performed using more than two buffers.
1309066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
1319066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @return true, if page flipping can be performed using more than two
1329066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *         buffers, false otherwise.
1339066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1349066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public boolean isMultiBufferAvailable() {
1359066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        return false;
1369066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1379066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1389066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    /**
1399066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * The FlipContents class represents a set of possible back buffer contents
1409066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * after page-flipping.
1419066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     *
1429066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     * @since Android 1.0
1439066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project     */
1449066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    public static final class FlipContents {
1459066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1469066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1479066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * The back buffered contents are cleared with the background color
1489066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * after flipping.
1499066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1509066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public static final FlipContents BACKGROUND = new FlipContents();
1519066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1529066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1539066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * The back buffered contents are copied to the front buffer before
1549066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * flipping.
1559066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1569066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public static final FlipContents COPIED = new FlipContents();
1579066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1589066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1599066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * The back buffer contents are the prior contents of the front buffer.
1609066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1619066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public static final FlipContents PRIOR = new FlipContents();
1629066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1639066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1649066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * The back buffer contents are undefined after flipping
1659066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1669066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public static final FlipContents UNDEFINED = new FlipContents();
1679066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1689066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1699066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Instantiates a new flip contents.
1709066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1719066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        private FlipContents() {
1729066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1739066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1749066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1759066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1769066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Returns the hash code of the FlipContents object.
1779066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1789066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return the hash code of the FlipContents object.
1799066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1809066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
1819066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public int hashCode() {
1829066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return super.hashCode();
1839066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1849066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project
1859066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        /**
1869066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * Returns the String representation of the FlipContents object.
1879066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         *
1889066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         * @return the string
1899066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project         */
1909066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        @Override
1919066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        public String toString() {
1929066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project            return super.toString();
1939066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project        }
1949066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project    }
1959066cfe9886ac131c34d59ed0e2d287b0e3c0087The Android Open Source Project}
196