summaryrefslogtreecommitdiffstats
path: root/src/android/jar/src/org/qtproject/qt/android/QtSurface.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/android/jar/src/org/qtproject/qt/android/QtSurface.java')
-rw-r--r--src/android/jar/src/org/qtproject/qt/android/QtSurface.java53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/android/jar/src/org/qtproject/qt/android/QtSurface.java b/src/android/jar/src/org/qtproject/qt/android/QtSurface.java
new file mode 100644
index 0000000000..3165de4811
--- /dev/null
+++ b/src/android/jar/src/org/qtproject/qt/android/QtSurface.java
@@ -0,0 +1,53 @@
+// Copyright (C) 2014 BogDan Vatra <bogdan@kde.org>
+// Copyright (C) 2016 The Qt Company Ltd.
+// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
+
+package org.qtproject.qt.android;
+
+import android.annotation.SuppressLint;
+import android.content.Context;
+import android.graphics.PixelFormat;
+import android.view.Surface;
+import android.view.SurfaceHolder;
+import android.view.SurfaceView;
+
+@SuppressLint("ViewConstructor")
+class QtSurface extends SurfaceView implements SurfaceHolder.Callback
+{
+ private QtSurfaceInterface m_surfaceCallback;
+
+ public QtSurface(Context context, QtSurfaceInterface surfaceCallback, boolean onTop, int imageDepth)
+ {
+ super(context);
+ setFocusable(false);
+ setFocusableInTouchMode(false);
+ setZOrderMediaOverlay(onTop);
+ m_surfaceCallback = surfaceCallback;
+ getHolder().addCallback(this);
+ if (imageDepth == 16)
+ getHolder().setFormat(PixelFormat.RGB_565);
+ else
+ getHolder().setFormat(PixelFormat.RGBA_8888);
+ }
+
+ @Override
+ public void surfaceCreated(SurfaceHolder holder)
+ {
+ }
+
+ @Override
+ public void surfaceChanged(SurfaceHolder holder, int format, int width, int height)
+ {
+ if (width < 1 || height < 1)
+ return;
+ if (m_surfaceCallback != null)
+ m_surfaceCallback.onSurfaceChanged(holder.getSurface());
+ }
+
+ @Override
+ public void surfaceDestroyed(SurfaceHolder holder)
+ {
+ if (m_surfaceCallback != null)
+ m_surfaceCallback.onSurfaceChanged(null);
+ }
+}