2012-06-15 23:22:43 +00:00
|
|
|
/*
|
|
|
|
**
|
|
|
|
** Copyright 2012, 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 android.opengl;
|
|
|
|
|
|
|
|
/**
|
2012-07-12 22:54:56 +00:00
|
|
|
* Base class for wrapped EGL objects.
|
|
|
|
*
|
2012-06-15 23:22:43 +00:00
|
|
|
*/
|
|
|
|
public abstract class EGLObjectHandle {
|
2014-02-13 09:47:18 +00:00
|
|
|
private final long mHandle;
|
2012-06-15 23:22:43 +00:00
|
|
|
|
2014-02-27 14:12:55 +00:00
|
|
|
/**
|
2014-02-28 14:05:21 +00:00
|
|
|
* @deprecated Use {@link #EGLObjectHandle(long)} instead. Handles
|
2014-02-27 14:12:55 +00:00
|
|
|
* on 64 bit platforms will be wider than java ints.
|
|
|
|
*/
|
|
|
|
@Deprecated
|
2012-07-12 22:54:56 +00:00
|
|
|
protected EGLObjectHandle(int handle) {
|
2012-06-15 23:22:43 +00:00
|
|
|
mHandle = handle;
|
|
|
|
}
|
2014-02-13 09:47:18 +00:00
|
|
|
protected EGLObjectHandle(long handle) {
|
|
|
|
mHandle = handle;
|
|
|
|
}
|
2012-07-12 22:54:56 +00:00
|
|
|
/**
|
2014-02-27 14:12:55 +00:00
|
|
|
* @deprecated Use {@link #getNativeHandle()} instead. Handles on
|
|
|
|
* 64 bit platforms will be wider than java ints.
|
2012-07-12 22:54:56 +00:00
|
|
|
*/
|
2014-02-27 14:12:55 +00:00
|
|
|
@Deprecated
|
2012-06-15 23:22:43 +00:00
|
|
|
public int getHandle() {
|
2014-02-13 09:47:18 +00:00
|
|
|
if ((mHandle & 0xffffffffL) != mHandle) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
|
|
|
return (int)mHandle;
|
2012-06-15 23:22:43 +00:00
|
|
|
}
|
2014-02-13 09:47:18 +00:00
|
|
|
/**
|
2014-02-27 14:12:55 +00:00
|
|
|
* Returns the native handle of the wrapped EGL object. This handle can be
|
|
|
|
* cast to the corresponding native type on the native side.
|
|
|
|
*
|
|
|
|
* For example, EGLDisplay dpy = (EGLDisplay)handle;
|
|
|
|
*
|
|
|
|
* @return the native handle of the wrapped EGL object.
|
2014-02-13 09:47:18 +00:00
|
|
|
*/
|
|
|
|
public long getNativeHandle() {
|
|
|
|
return mHandle;
|
|
|
|
}
|
2012-07-12 22:54:56 +00:00
|
|
|
@Override
|
|
|
|
public int hashCode() {
|
2014-02-13 09:47:18 +00:00
|
|
|
/*
|
|
|
|
* Based on the algorithm suggested in
|
|
|
|
* http://developer.android.com/reference/java/lang/Object.html
|
|
|
|
*/
|
|
|
|
int result = 17;
|
|
|
|
result = 31 * result + (int) (mHandle ^ (mHandle >>> 32));
|
|
|
|
return result;
|
2012-07-12 22:54:56 +00:00
|
|
|
}
|
2012-06-15 23:22:43 +00:00
|
|
|
}
|