Soft volume. Forced for galaxy S. Pref. access mgr.

This commit is contained in:
Guillaume Beraudo 2011-04-18 15:18:00 +02:00
parent f4a65ba623
commit 5fb71717cb
9 changed files with 118 additions and 48 deletions

View file

@ -34,7 +34,6 @@ import org.linphone.ui.HangCallButton;
import org.linphone.ui.MuteMicButton; import org.linphone.ui.MuteMicButton;
import org.linphone.ui.SpeakerButton; import org.linphone.ui.SpeakerButton;
import android.app.Activity;
import android.app.AlertDialog; import android.app.AlertDialog;
import android.app.Dialog; import android.app.Dialog;
import android.content.Context; import android.content.Context;
@ -45,7 +44,6 @@ import android.os.Bundle;
import android.os.PowerManager; import android.os.PowerManager;
import android.preference.PreferenceManager; import android.preference.PreferenceManager;
import android.util.Log; import android.util.Log;
import android.view.KeyEvent;
import android.view.View; import android.view.View;
import android.view.View.OnClickListener; import android.view.View.OnClickListener;
import android.widget.TextView; import android.widget.TextView;
@ -63,7 +61,7 @@ import android.widget.Toast;
* </ul> * </ul>
* *
*/ */
public class DialerActivity extends Activity implements LinphoneGuiListener, NewOutgoingCallUiListener { public class DialerActivity extends SoftVolumeActivity implements LinphoneGuiListener, NewOutgoingCallUiListener {
private TextView mStatus; private TextView mStatus;
private View mHangup; private View mHangup;
@ -85,7 +83,6 @@ public class DialerActivity extends Activity implements LinphoneGuiListener, New
private SharedPreferences mPref; private SharedPreferences mPref;
private boolean useIncallActivity; private boolean useIncallActivity;
private boolean useVideoActivity; private boolean useVideoActivity;
private SoftVolume softVolume;
private static final String CURRENT_ADDRESS = "org.linphone.current-address"; private static final String CURRENT_ADDRESS = "org.linphone.current-address";
private static final String CURRENT_DISPLAYNAME = "org.linphone.current-displayname"; private static final String CURRENT_DISPLAYNAME = "org.linphone.current-displayname";
@ -104,8 +101,6 @@ public class DialerActivity extends Activity implements LinphoneGuiListener, New
super.onCreate(savedInstanceState); super.onCreate(savedInstanceState);
setContentView(R.layout.dialer); setContentView(R.layout.dialer);
softVolume = new SoftVolume(this);
useIncallActivity = getResources().getBoolean(R.bool.use_incall_activity); useIncallActivity = getResources().getBoolean(R.bool.use_incall_activity);
useVideoActivity = getResources().getBoolean(R.bool.use_video_activity); useVideoActivity = getResources().getBoolean(R.bool.use_video_activity);
// Don't use Linphone Manager in the onCreate as it takes time in LinphoneService to initialize it. // Don't use Linphone Manager in the onCreate as it takes time in LinphoneService to initialize it.
@ -422,10 +417,4 @@ public class DialerActivity extends Activity implements LinphoneGuiListener, New
} }
} }
@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
if (softVolume.onKeyDown(keyCode, event)) return true;
return super.onKeyDown(keyCode, event);
}
} }

View file

@ -23,7 +23,6 @@ import java.util.TimerTask;
import org.linphone.ui.HangCallButton; import org.linphone.ui.HangCallButton;
import android.app.Activity;
import android.content.Intent; import android.content.Intent;
import android.os.Bundle; import android.os.Bundle;
import android.os.Handler; import android.os.Handler;
@ -33,7 +32,7 @@ import android.view.View;
import android.view.View.OnClickListener; import android.view.View.OnClickListener;
import android.widget.TextView; import android.widget.TextView;
public class IncallActivity extends Activity implements OnClickListener { public class IncallActivity extends SoftVolumeActivity implements OnClickListener {
public static final String CONTACT_KEY = "contact"; public static final String CONTACT_KEY = "contact";
private View numpadClose; private View numpadClose;

View file

@ -111,6 +111,7 @@ public class LinphoneActivity extends TabActivity {
instance = this; instance = this;
setContentView(R.layout.main); setContentView(R.layout.main);
LinphonePreferenceManager.setContext(this);
useFirstLoginActivity = getResources().getBoolean(R.bool.useFirstLoginActivity); useFirstLoginActivity = getResources().getBoolean(R.bool.useFirstLoginActivity);
useMenuSettings = getResources().getBoolean(R.bool.useMenuSettings); useMenuSettings = getResources().getBoolean(R.bool.useMenuSettings);
useMenuAbout = getResources().getBoolean(R.bool.useMenuAbout); useMenuAbout = getResources().getBoolean(R.bool.useMenuAbout);

View file

@ -156,6 +156,8 @@ public final class LinphoneManager implements LinphoneCoreListener {
} }
public static final String TAG="Linphone"; public static final String TAG="Linphone";
private static final int LINPHONE_VOLUME_STREAM = STREAM_VOICE_CALL;
private static final int dbStep = 4;
/** Called when the activity is first created. */ /** Called when the activity is first created. */
private final String linphoneInitialConfigFile; private final String linphoneInitialConfigFile;
private final String linphoneConfigFile; private final String linphoneConfigFile;
@ -331,9 +333,6 @@ public final class LinphoneManager implements LinphoneCoreListener {
this, linphoneConfigFile, linphoneInitialConfigFile, null); this, linphoneConfigFile, linphoneInitialConfigFile, null);
mLc.enableIpv6(mPref.getBoolean(getString(R.string.pref_ipv6_key), false)); mLc.enableIpv6(mPref.getBoolean(getString(R.string.pref_ipv6_key), false));
if (mPref.getBoolean(getString(R.string.pref_audio_soft_volume_key), false)) {
adjustSoftwareVolume(0); // Set maximum
}
mLc.setPlaybackGain(3); mLc.setPlaybackGain(3);
mLc.setRing(null); mLc.setRing(null);
@ -696,6 +695,12 @@ public final class LinphoneManager implements LinphoneCoreListener {
mAudioManager.setMode(MODE_NORMAL); mAudioManager.setMode(MODE_NORMAL);
} }
if (state == State.Connected) {
if (Hacks.needSoftvolume() || LinphonePreferenceManager.getInstance().useSoftvolume()) {
adjustSoftwareVolume(0); // Synchronize
}
}
mCurrentCallState=state; mCurrentCallState=state;
serviceListener.onCallStateChanged(call, state, message); serviceListener.onCallStateChanged(call, state, message);
} }
@ -861,7 +866,14 @@ public final class LinphoneManager implements LinphoneCoreListener {
} }
public void adjustSoftwareVolume(int i) { public void adjustSoftwareVolume(int i) {
mLc.adjustSoftwareVolume(i); int oldVolume = mAudioManager.getStreamVolume(LINPHONE_VOLUME_STREAM);
int maxVolume = mAudioManager.getStreamMaxVolume(LINPHONE_VOLUME_STREAM);
int nextVolume = oldVolume +i;
if (nextVolume > maxVolume) nextVolume = maxVolume;
if (nextVolume < 0) nextVolume = 0;
mLc.adjustSoftwareVolume((nextVolume - maxVolume)* dbStep);
} }
} }

View file

@ -0,0 +1,54 @@
/*
PreferenceManager.java
Copyright (C) 2011 Belledonne Communications, Grenoble, France
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 2
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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
package org.linphone;
import android.content.Context;
import android.content.SharedPreferences;
import android.preference.PreferenceManager;
public class LinphonePreferenceManager {
private static LinphonePreferenceManager instance;
private static Context c;
private static SharedPreferences p;
public LinphonePreferenceManager() {
p = PreferenceManager.getDefaultSharedPreferences(c);
}
private String getString(int key) {
return c.getString(key);
}
public static final synchronized LinphonePreferenceManager getInstance() {
if (c == null) throw new RuntimeException("need a context");
if (instance == null) instance = new LinphonePreferenceManager();
return instance;
}
public static final void setContext(Context context) {
c = context.getApplicationContext();
}
public boolean useSoftvolume() {
return p.getBoolean(
getString(R.string.pref_audio_soft_volume_key), false);
}
}

View file

@ -32,6 +32,7 @@ import java.util.Arrays;
import java.util.List; import java.util.List;
import org.linphone.LinphoneManager.EcCalibrationListener; import org.linphone.LinphoneManager.EcCalibrationListener;
import org.linphone.core.Hacks;
import org.linphone.core.LinphoneCoreException; import org.linphone.core.LinphoneCoreException;
import org.linphone.core.Version; import org.linphone.core.Version;
import org.linphone.core.LinphoneCore.EcCalibratorStatus; import org.linphone.core.LinphoneCore.EcCalibratorStatus;
@ -96,7 +97,7 @@ public class LinphonePreferencesActivity extends PreferenceActivity implements E
// No video // No video
if (Version.sdkStrictlyBelow(5) || !fastCpu || !LinphoneManager.getInstance().hasCamera()) { if (Version.sdkStrictlyBelow(5) || !fastCpu || !LinphoneManager.getInstance().hasCamera()) {
disableCheckbox(pref_video_enable_key); uncheckAndDisableCheckbox(pref_video_enable_key);
} }
if (prefs().getBoolean(LinphoneActivity.PREF_FIRST_LAUNCH,true)) { if (prefs().getBoolean(LinphoneActivity.PREF_FIRST_LAUNCH,true)) {
if (fastCpu) { if (fastCpu) {
@ -110,8 +111,10 @@ public class LinphonePreferencesActivity extends PreferenceActivity implements E
detectVideoCodec(R.string.pref_video_codec_h264_key, "H264"); detectVideoCodec(R.string.pref_video_codec_h264_key, "H264");
if (!AndroidCameraRecordManager.getInstance().hasFrontCamera()) { if (!AndroidCameraRecordManager.getInstance().hasFrontCamera()) {
disableAndHideCheckbox(R.string.pref_video_use_front_camera_key); uncheckDisableAndHideCheckbox(R.string.pref_video_use_front_camera_key);
} }
if (Hacks.needSoftvolume()) checkAndDisableCheckbox(R.string.pref_audio_soft_volume_key);
} }
@ -194,19 +197,22 @@ public class LinphonePreferencesActivity extends PreferenceActivity implements E
}); });
} }
private void disableAndHideCheckbox(int key) { private void uncheckDisableAndHideCheckbox(int key) {
writeBoolean(key, false); manageCheckbox(key, false, false, true);
CheckBoxPreference box = (CheckBoxPreference) findPreference(key);
box.setEnabled(false);
box.setChecked(false);
box.setLayoutResource(R.layout.hidden);
} }
private void disableCheckbox(int key) { private void uncheckAndDisableCheckbox(int key) {
writeBoolean(key, false); manageCheckbox(key, false, false, false);
}
private void checkAndDisableCheckbox(int key) {
manageCheckbox(key, true, false, false);
}
private void manageCheckbox(int key, boolean value, boolean enabled, boolean hidden) {
CheckBoxPreference box = (CheckBoxPreference) findPreference(key); CheckBoxPreference box = (CheckBoxPreference) findPreference(key);
box.setEnabled(false); box.setEnabled(enabled);
box.setChecked(false); box.setChecked(value);
writeBoolean(key, value);
if (hidden) box.setLayoutResource(R.layout.hidden);
} }
private Preference findPreference(int key) { private Preference findPreference(int key) {

View file

@ -18,32 +18,39 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/ */
package org.linphone; package org.linphone;
import android.content.Context; import org.linphone.core.Hacks;
import android.preference.PreferenceManager;
import android.app.Activity;
import android.view.KeyEvent; import android.view.KeyEvent;
public class SoftVolume { /**
* Activity which handles softvolume.
* @author Guillaume Beraudo
*
*/
public class SoftVolumeActivity extends Activity {
private Context c; private static boolean preventVolumeBarToDisplay = false;
public SoftVolume(Context context) {
c = context.getApplicationContext();
}
public boolean onKeyDown(int keyCode, KeyEvent event) { public boolean onKeyDown(int keyCode, KeyEvent event) {
if (!PreferenceManager.getDefaultSharedPreferences(c).getBoolean( if (keyCode != KeyEvent.KEYCODE_VOLUME_UP && keyCode != KeyEvent.KEYCODE_VOLUME_DOWN) {
c.getString(R.string.pref_audio_soft_volume_key), false))
return false; return false;
if (keyCode == KeyEvent.KEYCODE_VOLUME_UP) {
LinphoneManager.getInstance().adjustSoftwareVolume(6);
return true;
} else if (keyCode == KeyEvent.KEYCODE_VOLUME_DOWN) {
LinphoneManager.getInstance().adjustSoftwareVolume(-6);
return true;
} }
return false; if (!Hacks.needSoftvolume() && !LinphonePreferenceManager.getInstance().useSoftvolume())
return false;
if (keyCode == KeyEvent.KEYCODE_VOLUME_UP) {
LinphoneManager.getInstance().adjustSoftwareVolume(1);
} else if (keyCode == KeyEvent.KEYCODE_VOLUME_DOWN) {
LinphoneManager.getInstance().adjustSoftwareVolume(-1);
}
return preventVolumeBarToDisplay;
} }
} }

View file

@ -25,7 +25,6 @@ import org.linphone.core.Version;
import org.linphone.core.VideoSize; import org.linphone.core.VideoSize;
import org.linphone.core.video.AndroidCameraRecordManager; import org.linphone.core.video.AndroidCameraRecordManager;
import android.app.Activity;
import android.content.Context; import android.content.Context;
import android.content.pm.ActivityInfo; import android.content.pm.ActivityInfo;
import android.os.Bundle; import android.os.Bundle;
@ -43,7 +42,7 @@ import android.view.ViewGroup.LayoutParams;
* @author Guillaume Beraudo * @author Guillaume Beraudo
* *
*/ */
public class VideoCallActivity extends Activity { public class VideoCallActivity extends SoftVolumeActivity {
private SurfaceView mVideoView; private SurfaceView mVideoView;
private SurfaceView mVideoCaptureView; private SurfaceView mVideoCaptureView;
private AndroidCameraRecordManager recordManager; private AndroidCameraRecordManager recordManager;
@ -207,5 +206,4 @@ public class VideoCallActivity extends Activity {
super.onPause(); super.onPause();
} }
} }

View file

@ -97,4 +97,8 @@ public final class Hacks {
Log.d(LinphoneManager.TAG, sb.toString()); Log.d(LinphoneManager.TAG, sb.toString());
} }
public static boolean needSoftvolume() {
return isGalaxySOrTab();
}
} }