Path: blob/aarch64-shenandoah-jdk8u272-b10/jdk/src/solaris/classes/sun/java2d/UnixSurfaceManagerFactory.java
32287 views
/*1* Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.2* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.3*4* This code is free software; you can redistribute it and/or modify it5* under the terms of the GNU General Public License version 2 only, as6* published by the Free Software Foundation. Oracle designates this7* particular file as subject to the "Classpath" exception as provided8* by Oracle in the LICENSE file that accompanied this code.9*10* This code is distributed in the hope that it will be useful, but WITHOUT11* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or12* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License13* version 2 for more details (a copy is included in the LICENSE file that14* accompanied this code).15*16* You should have received a copy of the GNU General Public License version17* 2 along with this work; if not, write to the Free Software Foundation,18* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.19*20* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA21* or visit www.oracle.com if you need additional information or have any22* questions.23*/242526package sun.java2d;2728import java.awt.GraphicsConfiguration;2930import sun.awt.image.SunVolatileImage;31import sun.awt.image.VolatileSurfaceManager;32import sun.java2d.opengl.GLXGraphicsConfig;33import sun.java2d.opengl.GLXVolatileSurfaceManager;34import sun.java2d.x11.X11VolatileSurfaceManager;35import sun.java2d.xr.*;3637/**38* The SurfaceManagerFactory that creates VolatileSurfaceManager39* implementations for the Unix volatile images.40*/41public class UnixSurfaceManagerFactory extends SurfaceManagerFactory {4243/**44* Creates a new instance of a VolatileSurfaceManager given any45* arbitrary SunVolatileImage. An optional context Object can be supplied46* as a way for the caller to pass pipeline-specific context data to47* the VolatileSurfaceManager (such as a backbuffer handle, for example).48*49* For Unix platforms, this method returns either an X11- or a GLX-50* specific VolatileSurfaceManager based on the GraphicsConfiguration51* under which the SunVolatileImage was created.52*/53public VolatileSurfaceManager createVolatileManager(SunVolatileImage vImg,54Object context)55{56GraphicsConfiguration gc = vImg.getGraphicsConfig();5758if (gc instanceof GLXGraphicsConfig) {59return new GLXVolatileSurfaceManager(vImg, context);60} else if(gc instanceof XRGraphicsConfig) {61return new XRVolatileSurfaceManager(vImg, context);62}else {63return new X11VolatileSurfaceManager(vImg, context);64}65}6667}686970