Blame | Last modification | View Log | RSS feed
/*
* Copyright (C) 2022 by Andreas Theofilu <andreas@theosys.at>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
package org.qtproject.theosys;
import java.util.*;
import android.os.Bundle;
import android.app.Activity;
import android.content.Intent;
import androidx.appcompat.app.AppCompatActivity;
import org.qtproject.theosys.SettingsActivity;
import org.qtproject.theosys.Logger;
public class Settings extends Logger
{
static private Activity m_ActivityInstance = null;
static private Intent m_intent = null;
static private List<String> mSurfaces = null;
static private boolean mLogInfo = false;
static private boolean mLogWarning = false;
static private boolean mLogError = false;
static private boolean mLogDebug = false;
static private boolean mLogTrace = false;
static private boolean mLogFileEnabled = false;
static private String mLogPath;
static private String mPassword1;
static private String mPassword2;
static private String mPassword3;
static private String mPassword4;
static public void callSettings(Activity act)
{
m_ActivityInstance = act;
m_intent = new Intent(act, SettingsActivity.class);
if (m_intent == null)
{
log(HLOG_ERROR, "Settings.callSettings: Couldn't initialize a new Intent!");
return;
}
act.setTheme(R.style.Theme_Tpanel_settings);
deploySurfaces();
act.startActivity(m_intent);
}
static public void addSurface(String sf)
{
if (mSurfaces == null)
mSurfaces = new ArrayList<String>();
log(HLOG_DEBUG, "Settings.addSurface: String: " + sf);
mSurfaces.add(sf);
}
static public void setLogEnableFile(int s)
{
mLogFileEnabled = (s == 1 ? true : false);
}
static public void setLogLevel(int level)
{
mLogInfo = (level & HLOG_INFO) == HLOG_INFO;
mLogWarning = (level & HLOG_WARNING) == HLOG_WARNING;
mLogError = (level & HLOG_ERROR) == HLOG_ERROR;
mLogTrace = (level & HLOG_TRACE) == HLOG_TRACE;
mLogDebug = (level & HLOG_DEBUG) == HLOG_DEBUG;
}
static public void setLogPath(String path)
{
mLogPath = path;
}
static public void setPassword(int idx, String pw)
{
switch(idx)
{
case 1: mPassword1 = pw; break;
case 2: mPassword2 = pw; break;
case 3: mPassword3 = pw; break;
case 4: mPassword4 = pw; break;
}
}
static public void deploySurfaces()
{
if (m_ActivityInstance == null || m_intent == null)
return;
if (m_ActivityInstance.isDestroyed())
return;
m_intent.putExtra("log_info", mLogInfo);
m_intent.putExtra("log_warning", mLogWarning);
m_intent.putExtra("log_error", mLogError);
m_intent.putExtra("log_trace", mLogTrace);
m_intent.putExtra("log_debug", mLogDebug);
m_intent.putExtra("log_path", mLogPath);
m_intent.putExtra("log_file_enabled", mLogFileEnabled);
m_intent.putExtra("password_1", mPassword1);
m_intent.putExtra("password_2", mPassword2);
m_intent.putExtra("password_3", mPassword3);
m_intent.putExtra("password_4", mPassword4);
if (mSurfaces == null || mSurfaces.isEmpty())
return;
// Transfer list
log(HLOG_DEBUG, "Settings.deploySurfaces: Deploy surfaces to instance ...");
CharSequence[] entries = mSurfaces.toArray(new CharSequence[mSurfaces.size()]);
m_intent.putExtra("surfaces", entries);
}
static public void clearSurfaces()
{
if (mSurfaces == null || mSurfaces.isEmpty())
return;
mSurfaces.clear();
}
}