mirror of
https://github.com/SFML/SFML.git
synced 2024-11-24 20:31:05 +08:00
Reduce pointer usage
This commit is contained in:
parent
55f0918c62
commit
4b1751321a
@ -98,9 +98,9 @@ void onStart(ANativeActivity* /* activity */)
|
|||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
int getAndroidApiLevel(ANativeActivity* activity)
|
int getAndroidApiLevel(ANativeActivity& activity)
|
||||||
{
|
{
|
||||||
JNIEnv* lJNIEnv = activity->env;
|
JNIEnv* lJNIEnv = activity.env;
|
||||||
|
|
||||||
jclass versionClass = lJNIEnv->FindClass("android/os/Build$VERSION");
|
jclass versionClass = lJNIEnv->FindClass("android/os/Build$VERSION");
|
||||||
if (versionClass == nullptr)
|
if (versionClass == nullptr)
|
||||||
@ -117,27 +117,25 @@ int getAndroidApiLevel(ANativeActivity* activity)
|
|||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
sf::priv::ActivityStates* retrieveStates(ANativeActivity* activity)
|
sf::priv::ActivityStates& retrieveStates(ANativeActivity& activity)
|
||||||
{
|
{
|
||||||
assert(activity != nullptr && "Activity cannot be null");
|
|
||||||
|
|
||||||
// Hide the ugly cast we find in each callback function
|
// Hide the ugly cast we find in each callback function
|
||||||
return static_cast<sf::priv::ActivityStates*>(activity->instance);
|
return *static_cast<sf::priv::ActivityStates*>(activity.instance);
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void goToFullscreenMode(ANativeActivity* activity)
|
void goToFullscreenMode(ANativeActivity& activity)
|
||||||
{
|
{
|
||||||
// Get the current Android API level.
|
// Get the current Android API level.
|
||||||
const int apiLevel = getAndroidApiLevel(activity);
|
const int apiLevel = getAndroidApiLevel(activity);
|
||||||
|
|
||||||
// Hide the status bar
|
// Hide the status bar
|
||||||
ANativeActivity_setWindowFlags(activity, AWINDOW_FLAG_FULLSCREEN, AWINDOW_FLAG_FULLSCREEN);
|
ANativeActivity_setWindowFlags(&activity, AWINDOW_FLAG_FULLSCREEN, AWINDOW_FLAG_FULLSCREEN);
|
||||||
|
|
||||||
// Hide the navigation bar
|
// Hide the navigation bar
|
||||||
JNIEnv* lJNIEnv = activity->env;
|
JNIEnv* lJNIEnv = activity.env;
|
||||||
|
|
||||||
jobject objectActivity = activity->clazz;
|
jobject objectActivity = activity.clazz;
|
||||||
jclass classActivity = lJNIEnv->GetObjectClass(objectActivity);
|
jclass classActivity = lJNIEnv->GetObjectClass(objectActivity);
|
||||||
|
|
||||||
jmethodID methodGetWindow = lJNIEnv->GetMethodID(classActivity, "getWindow", "()Landroid/view/Window;");
|
jmethodID methodGetWindow = lJNIEnv->GetMethodID(classActivity, "getWindow", "()Landroid/view/Window;");
|
||||||
@ -185,16 +183,16 @@ void goToFullscreenMode(ANativeActivity* activity)
|
|||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void getScreenSizeInPixels(ANativeActivity* activity, int* width, int* height)
|
void getScreenSizeInPixels(ANativeActivity& activity, int& width, int& height)
|
||||||
{
|
{
|
||||||
// Perform the following Java code:
|
// Perform the following Java code:
|
||||||
//
|
//
|
||||||
// DisplayMetrics dm = new DisplayMetrics();
|
// DisplayMetrics dm = new DisplayMetrics();
|
||||||
// getWindowManager().getDefaultDisplay().getMetrics(dm);
|
// getWindowManager().getDefaultDisplay().getMetrics(dm);
|
||||||
|
|
||||||
JNIEnv* lJNIEnv = activity->env;
|
JNIEnv* lJNIEnv = activity.env;
|
||||||
|
|
||||||
jobject objectActivity = activity->clazz;
|
jobject objectActivity = activity.clazz;
|
||||||
jclass classActivity = lJNIEnv->GetObjectClass(objectActivity);
|
jclass classActivity = lJNIEnv->GetObjectClass(objectActivity);
|
||||||
|
|
||||||
jclass classDisplayMetrics = lJNIEnv->FindClass("android/util/DisplayMetrics");
|
jclass classDisplayMetrics = lJNIEnv->FindClass("android/util/DisplayMetrics");
|
||||||
@ -219,33 +217,33 @@ void getScreenSizeInPixels(ANativeActivity* activity, int* width, int* height)
|
|||||||
jfieldID fieldWidthPixels = lJNIEnv->GetFieldID(classDisplayMetrics, "widthPixels", "I");
|
jfieldID fieldWidthPixels = lJNIEnv->GetFieldID(classDisplayMetrics, "widthPixels", "I");
|
||||||
jfieldID fieldHeightPixels = lJNIEnv->GetFieldID(classDisplayMetrics, "heightPixels", "I");
|
jfieldID fieldHeightPixels = lJNIEnv->GetFieldID(classDisplayMetrics, "heightPixels", "I");
|
||||||
|
|
||||||
*width = lJNIEnv->GetIntField(objectDisplayMetrics, fieldWidthPixels);
|
width = lJNIEnv->GetIntField(objectDisplayMetrics, fieldWidthPixels);
|
||||||
*height = lJNIEnv->GetIntField(objectDisplayMetrics, fieldHeightPixels);
|
height = lJNIEnv->GetIntField(objectDisplayMetrics, fieldHeightPixels);
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void onResume(ANativeActivity* activity)
|
void onResume(ANativeActivity* activity)
|
||||||
{
|
{
|
||||||
// Retrieve our activity states from the activity instance
|
// Retrieve our activity states from the activity instance
|
||||||
sf::priv::ActivityStates* states = retrieveStates(activity);
|
sf::priv::ActivityStates& states = retrieveStates(*activity);
|
||||||
const std::lock_guard lock(states->mutex);
|
const std::lock_guard lock(states.mutex);
|
||||||
|
|
||||||
if (states->fullscreen)
|
if (states.fullscreen)
|
||||||
goToFullscreenMode(activity);
|
goToFullscreenMode(*activity);
|
||||||
|
|
||||||
// Send an event to warn people the activity has been resumed
|
// Send an event to warn people the activity has been resumed
|
||||||
states->forwardEvent(sf::Event::MouseEntered{});
|
states.forwardEvent(sf::Event::MouseEntered{});
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void onPause(ANativeActivity* activity)
|
void onPause(ANativeActivity* activity)
|
||||||
{
|
{
|
||||||
// Retrieve our activity states from the activity instance
|
// Retrieve our activity states from the activity instance
|
||||||
sf::priv::ActivityStates* states = retrieveStates(activity);
|
sf::priv::ActivityStates& states = retrieveStates(*activity);
|
||||||
const std::lock_guard lock(states->mutex);
|
const std::lock_guard lock(states.mutex);
|
||||||
|
|
||||||
// Send an event to warn people the activity has been paused
|
// Send an event to warn people the activity has been paused
|
||||||
states->forwardEvent(sf::Event::MouseLeft{});
|
states.forwardEvent(sf::Event::MouseLeft{});
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
@ -257,35 +255,35 @@ void onStop(ANativeActivity* /* activity */)
|
|||||||
void onDestroy(ANativeActivity* activity)
|
void onDestroy(ANativeActivity* activity)
|
||||||
{
|
{
|
||||||
// Retrieve our activity states from the activity instance
|
// Retrieve our activity states from the activity instance
|
||||||
sf::priv::ActivityStates* states = retrieveStates(activity);
|
sf::priv::ActivityStates& states = retrieveStates(*activity);
|
||||||
|
|
||||||
// Send an event to warn people the activity is being destroyed
|
// Send an event to warn people the activity is being destroyed
|
||||||
{
|
{
|
||||||
const std::lock_guard lock(states->mutex);
|
const std::lock_guard lock(states.mutex);
|
||||||
|
|
||||||
// If the main thread hasn't yet finished, send the event and wait for
|
// If the main thread hasn't yet finished, send the event and wait for
|
||||||
// it to finish.
|
// it to finish.
|
||||||
if (!states->mainOver)
|
if (!states.mainOver)
|
||||||
states->forwardEvent(sf::Event::Closed{});
|
states.forwardEvent(sf::Event::Closed{});
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wait for the main thread to be terminated
|
// Wait for the main thread to be terminated
|
||||||
states->mutex.lock();
|
states.mutex.lock();
|
||||||
|
|
||||||
while (!states->terminated)
|
while (!states.terminated)
|
||||||
{
|
{
|
||||||
states->mutex.unlock();
|
states.mutex.unlock();
|
||||||
sf::sleep(sf::milliseconds(20));
|
sf::sleep(sf::milliseconds(20));
|
||||||
states->mutex.lock();
|
states.mutex.lock();
|
||||||
}
|
}
|
||||||
|
|
||||||
states->mutex.unlock();
|
states.mutex.unlock();
|
||||||
|
|
||||||
// Terminate EGL display
|
// Terminate EGL display
|
||||||
eglTerminate(states->display);
|
eglTerminate(states.display);
|
||||||
|
|
||||||
// Delete our allocated states
|
// Delete our allocated states
|
||||||
delete states;
|
delete &states;
|
||||||
|
|
||||||
// Reset the activity pointer for all modules
|
// Reset the activity pointer for all modules
|
||||||
sf::priv::resetActivity(nullptr);
|
sf::priv::resetActivity(nullptr);
|
||||||
@ -296,44 +294,44 @@ void onDestroy(ANativeActivity* activity)
|
|||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void onNativeWindowCreated(ANativeActivity* activity, ANativeWindow* window)
|
void onNativeWindowCreated(ANativeActivity* activity, ANativeWindow* window)
|
||||||
{
|
{
|
||||||
sf::priv::ActivityStates* states = retrieveStates(activity);
|
sf::priv::ActivityStates& states = retrieveStates(*activity);
|
||||||
const std::lock_guard lock(states->mutex);
|
const std::lock_guard lock(states.mutex);
|
||||||
|
|
||||||
// Update the activity states
|
// Update the activity states
|
||||||
states->window = window;
|
states.window = window;
|
||||||
|
|
||||||
// Notify SFML mechanism
|
// Notify SFML mechanism
|
||||||
states->forwardEvent(sf::Event::FocusGained{});
|
states.forwardEvent(sf::Event::FocusGained{});
|
||||||
|
|
||||||
// Wait for the event to be taken into account by SFML
|
// Wait for the event to be taken into account by SFML
|
||||||
states->updated = false;
|
states.updated = false;
|
||||||
while (!(states->updated | states->terminated))
|
while (!(states.updated | states.terminated))
|
||||||
{
|
{
|
||||||
states->mutex.unlock();
|
states.mutex.unlock();
|
||||||
sf::sleep(sf::milliseconds(10));
|
sf::sleep(sf::milliseconds(10));
|
||||||
states->mutex.lock();
|
states.mutex.lock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
////////////////////////////////////////////////////////////
|
////////////////////////////////////////////////////////////
|
||||||
void onNativeWindowDestroyed(ANativeActivity* activity, ANativeWindow* /* window */)
|
void onNativeWindowDestroyed(ANativeActivity* activity, ANativeWindow* /* window */)
|
||||||
{
|
{
|
||||||
sf::priv::ActivityStates* states = retrieveStates(activity);
|
sf::priv::ActivityStates& states = retrieveStates(*activity);
|
||||||
const std::lock_guard lock(states->mutex);
|
const std::lock_guard lock(states.mutex);
|
||||||
|
|
||||||
// Update the activity states
|
// Update the activity states
|
||||||
states->window = nullptr;
|
states.window = nullptr;
|
||||||
|
|
||||||
// Notify SFML mechanism
|
// Notify SFML mechanism
|
||||||
states->forwardEvent(sf::Event::FocusLost{});
|
states.forwardEvent(sf::Event::FocusLost{});
|
||||||
|
|
||||||
// Wait for the event to be taken into account by SFML
|
// Wait for the event to be taken into account by SFML
|
||||||
states->updated = false;
|
states.updated = false;
|
||||||
while (!(states->updated | states->terminated))
|
while (!(states.updated | states.terminated))
|
||||||
{
|
{
|
||||||
states->mutex.unlock();
|
states.mutex.unlock();
|
||||||
sf::sleep(sf::milliseconds(10));
|
sf::sleep(sf::milliseconds(10));
|
||||||
states->mutex.lock();
|
states.mutex.lock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -351,14 +349,14 @@ void onNativeWindowResized(ANativeActivity* /* activity */, ANativeWindow* /* wi
|
|||||||
void onInputQueueCreated(ANativeActivity* activity, AInputQueue* queue)
|
void onInputQueueCreated(ANativeActivity* activity, AInputQueue* queue)
|
||||||
{
|
{
|
||||||
// Retrieve our activity states from the activity instance
|
// Retrieve our activity states from the activity instance
|
||||||
sf::priv::ActivityStates* states = retrieveStates(activity);
|
sf::priv::ActivityStates& states = retrieveStates(*activity);
|
||||||
|
|
||||||
// Attach the input queue
|
// Attach the input queue
|
||||||
{
|
{
|
||||||
const std::lock_guard lock(states->mutex);
|
const std::lock_guard lock(states.mutex);
|
||||||
|
|
||||||
AInputQueue_attachLooper(queue, states->looper, 1, states->processEvent, nullptr);
|
AInputQueue_attachLooper(queue, states.looper, 1, states.processEvent, nullptr);
|
||||||
states->inputQueue = queue;
|
states.inputQueue = queue;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -366,16 +364,16 @@ void onInputQueueCreated(ANativeActivity* activity, AInputQueue* queue)
|
|||||||
void onInputQueueDestroyed(ANativeActivity* activity, AInputQueue* queue)
|
void onInputQueueDestroyed(ANativeActivity* activity, AInputQueue* queue)
|
||||||
{
|
{
|
||||||
// Retrieve our activity states from the activity instance
|
// Retrieve our activity states from the activity instance
|
||||||
sf::priv::ActivityStates* states = retrieveStates(activity);
|
sf::priv::ActivityStates& states = retrieveStates(*activity);
|
||||||
|
|
||||||
// Detach the input queue
|
// Detach the input queue
|
||||||
{
|
{
|
||||||
const std::lock_guard lock(states->mutex);
|
const std::lock_guard lock(states.mutex);
|
||||||
|
|
||||||
AInputQueue_detachLooper(queue);
|
AInputQueue_detachLooper(queue);
|
||||||
states->inputQueue = nullptr;
|
states.inputQueue = nullptr;
|
||||||
|
|
||||||
ALooper_release(states->looper);
|
ALooper_release(states.looper);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -388,16 +386,16 @@ void onWindowFocusChanged(ANativeActivity* /* activity */, int /* focused */)
|
|||||||
void onContentRectChanged(ANativeActivity* activity, const ARect* /* rect */)
|
void onContentRectChanged(ANativeActivity* activity, const ARect* /* rect */)
|
||||||
{
|
{
|
||||||
// Retrieve our activity states from the activity instance
|
// Retrieve our activity states from the activity instance
|
||||||
sf::priv::ActivityStates* states = retrieveStates(activity);
|
sf::priv::ActivityStates& states = retrieveStates(*activity);
|
||||||
const std::lock_guard lock(states->mutex);
|
const std::lock_guard lock(states.mutex);
|
||||||
|
|
||||||
// Make sure the window still exists before we access the dimensions on it
|
// Make sure the window still exists before we access the dimensions on it
|
||||||
if (states->window != nullptr)
|
if (states.window != nullptr)
|
||||||
{
|
{
|
||||||
// Send an event to warn people about the window move/resize
|
// Send an event to warn people about the window move/resize
|
||||||
const sf::Event::Resized event{
|
const sf::Event::Resized event{
|
||||||
sf::Vector2u(sf::Vector2(ANativeWindow_getWidth(states->window), ANativeWindow_getHeight(states->window)))};
|
sf::Vector2u(sf::Vector2(ANativeWindow_getWidth(states.window), ANativeWindow_getHeight(states.window)))};
|
||||||
states->forwardEvent(event);
|
states.forwardEvent(event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -503,7 +501,7 @@ JNIEXPORT void ANativeActivity_onCreate(ANativeActivity* activity, void* savedSt
|
|||||||
// Initialize the display
|
// Initialize the display
|
||||||
eglInitialize(states->display, nullptr, nullptr);
|
eglInitialize(states->display, nullptr, nullptr);
|
||||||
|
|
||||||
getScreenSizeInPixels(activity, &states->screenSize.x, &states->screenSize.y);
|
getScreenSizeInPixels(*activity, states->screenSize.x, states->screenSize.y);
|
||||||
|
|
||||||
// Redirect error messages to logcat
|
// Redirect error messages to logcat
|
||||||
sf::err().rdbuf(&states->logcat);
|
sf::err().rdbuf(&states->logcat);
|
||||||
|
Loading…
Reference in New Issue
Block a user