Read contact picture. (not integrated in incall activity).

This commit is contained in:
Guillaume Beraudo 2011-06-01 11:33:31 +02:00
parent 6d530bd16f
commit cb0714bef7
8 changed files with 307 additions and 190 deletions

View file

@ -0,0 +1,172 @@
/*
ContactPickerActivity.java
Copyright (C) 2010 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 java.util.Collections;
import java.util.List;
import android.app.Activity;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.FilterQueryProvider;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;
/**
* Activity for retrieving a phone number / SIP address to call.
* <br />
*
* The cinematic is:
* <ul>
* <li>Select contact (either through native or custom way)</li>
* <li>Select phone number or SIP address
* <li>Back to dialer</li>
* </ul>
*
* @author Guillaume Beraudo
*
*/
public abstract class AbstractContactPickerActivity extends Activity implements FilterQueryProvider {
private ListView mContactList;
protected EditText mcontactFilter;
private SimpleCursorAdapter adapter;
protected boolean useNativePicker;
protected final String col_display_name = "display_name";
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
useNativePicker = getResources().getBoolean(R.bool.use_android_contact_picker);
if (!useNativePicker) {
setContentView(R.layout.contact_picker);
createCustomPicker();
}
}
protected void createCustomPicker() {
mContactList = (ListView) findViewById(R.id.contactList);
mcontactFilter = (EditText) findViewById(R.id.contactFilter);
mcontactFilter.addTextChangedListener(new TextWatcher() {
public void onTextChanged(CharSequence s, int start, int b, int c) {}
public void beforeTextChanged(CharSequence s, int st, int c, int a) {}
public void afterTextChanged(Editable s) {
adapter.runQueryOnBackgroundThread(s);
adapter.getFilter().filter(s.toString());
}
});
// Populate the contact list
String[] from = new String[] {col_display_name};
int[] to = new int[] {android.R.id.text1};
int layout = android.R.layout.simple_list_item_1;
adapter = new SimpleCursorAdapter(this, layout, runQuery(null), from, to);
adapter.setFilterQueryProvider(this);
mContactList.setAdapter(adapter);
mContactList.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
final CharSequence contactName = ((TextView) view.findViewById(android.R.id.text1)).getText();
choosePhoneNumberAndDial(contactName, String.valueOf(id));
}
});
}
protected void choosePhoneNumberAndDial(final CharSequence contactName, final String id) {
List<String> phones = extractPhones(id);
phones.addAll(extractSipNumbers(id));
switch (phones.size()) {
case 0:
String msg = String.format(getString(R.string.no_phone_numbers), contactName);
Toast.makeText(this, msg, Toast.LENGTH_LONG).show();
break;
case 1:
returnSelectedValues(phones.get(0), contactName.toString(), getPhotoUri(id));
break;
default:
AlertDialog.Builder builder = new AlertDialog.Builder(this);
final ArrayAdapter<String> pAdapter = new ArrayAdapter<String>(this,
android.R.layout.simple_dropdown_item_1line, phones);
builder.setTitle(String.format(getString(R.string.title_numbers_dialog),contactName));
builder.setAdapter(pAdapter, new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
returnSelectedValues(pAdapter.getItem(which), contactName.toString(),getPhotoUri(id));
}
});
builder.setCancelable(true);
builder.setNeutralButton("cancel", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
dialog.dismiss();
}
});
AlertDialog dialog = builder.create();
dialog.show();
}
}
private void returnSelectedValues(String number, String name, Uri photo) {
/* if (getCallingActivity() != null) {
setResult(RESULT_OK, new Intent()
.putExtra(Intent.EXTRA_PHONE_NUMBER, number)
.putExtra(EXTRA_CONTACT_NAME, name));
finish();
}*/
LinphoneActivity.setAddressAndGoToDialer(number, name, photo);
}
protected abstract List<String> extractPhones(String id);
protected abstract Uri getPhotoUri(String id);
// Hook
protected List<String> extractSipNumbers(String id) {
return Collections.emptyList();
}
public abstract Cursor runQuery(CharSequence constraint);
}

View file

@ -21,27 +21,13 @@ package org.linphone;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.List; import java.util.List;
import android.app.Activity; import android.content.ContentUris;
import android.app.AlertDialog;
import android.content.DialogInterface;
import android.content.Intent; import android.content.Intent;
import android.database.Cursor; import android.database.Cursor;
import android.net.Uri; import android.net.Uri;
import android.os.Bundle;
import android.provider.ContactsContract; import android.provider.ContactsContract;
import android.text.Editable; import android.provider.ContactsContract.Contacts;
import android.text.TextUtils; import android.text.TextUtils;
import android.text.TextWatcher;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ArrayAdapter;
import android.widget.EditText;
import android.widget.FilterQueryProvider;
import android.widget.ListView;
import android.widget.SimpleCursorAdapter;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.AdapterView.OnItemClickListener;
/** /**
@ -58,154 +44,80 @@ import android.widget.AdapterView.OnItemClickListener;
* @author Guillaume Beraudo * @author Guillaume Beraudo
* *
*/ */
public class ContactPickerActivityNew extends Activity implements FilterQueryProvider { public class ContactPickerActivityNew extends AbstractContactPickerActivity {
private ListView mContactList;
private EditText mcontactFilter;
private SimpleCursorAdapter adapter;
private boolean useNativePicker;
@Override @Override
public void onCreate(Bundle savedInstanceState) { public Uri getPhotoUri(String id) {
super.onCreate(savedInstanceState); Uri contactUri = ContentUris.withAppendedId(Contacts.CONTENT_URI, Long.parseLong(id));
Uri photoUri = Uri.withAppendedPath(contactUri, Contacts.Photo.CONTENT_DIRECTORY);
useNativePicker = getResources().getBoolean(R.bool.use_android_contact_picker); if (photoUri == null) {
return null;
if (!useNativePicker) { }
setContentView(R.layout.contact_picker); Cursor cursor = getContentResolver().query(photoUri,
createPicker(); new String[]{ContactsContract.CommonDataKinds.Photo.PHOTO}, null, null, null);
try {
if (cursor == null || !cursor.moveToNext()) {
return null;
}
byte[] data = cursor.getBlob(0);
if (data == null) {
return null;
}
return photoUri;
} finally {
if (cursor != null) {
cursor.close();
}
} }
} }
protected List<String> extractPhones(String id) {
private void createPicker() {
mContactList = (ListView) findViewById(R.id.contactList);
mcontactFilter = (EditText) findViewById(R.id.contactFilter);
mcontactFilter.addTextChangedListener(new TextWatcher() {
public void onTextChanged(CharSequence s, int start, int b, int c) {}
public void beforeTextChanged(CharSequence s, int st, int c, int a) {}
public void afterTextChanged(Editable s) {
adapter.runQueryOnBackgroundThread(s);
adapter.getFilter().filter(s.toString());
}
});
// Populate the contact list
String[] from = new String[] {ContactsContract.Data.DISPLAY_NAME};
int[] to = new int[] {android.R.id.text1};
int layout = android.R.layout.simple_list_item_1;
adapter = new SimpleCursorAdapter(this, layout, runQuery(null), from, to);
adapter.setFilterQueryProvider(this);
mContactList.setAdapter(adapter);
mContactList.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
final CharSequence contactName = ((TextView) view.findViewById(android.R.id.text1)).getText();
choosePhoneNumberAndDial(contactName, String.valueOf(id));
}
});
}
private void choosePhoneNumberAndDial(final CharSequence contactName, final String id) {
List<String> phones = extractPhones(id);
phones.addAll(extractSipNumbers(id));
switch (phones.size()) {
case 0:
String msg = String.format(getString(R.string.no_phone_numbers), contactName);
Toast.makeText(ContactPickerActivityNew.this, msg, Toast.LENGTH_LONG).show();
break;
case 1:
returnSelectedValues(phones.get(0), contactName.toString());
break;
default:
AlertDialog.Builder builder = new AlertDialog.Builder(ContactPickerActivityNew.this);
final ArrayAdapter<String> pAdapter = new ArrayAdapter<String>(ContactPickerActivityNew.this,
android.R.layout.simple_dropdown_item_1line, phones);
builder.setTitle(String.format(getString(R.string.title_numbers_dialog),contactName));
builder.setAdapter(pAdapter, new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
returnSelectedValues(pAdapter.getItem(which), contactName.toString());
}
});
builder.setCancelable(true);
builder.setNeutralButton("cancel", new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog, int which) {
dialog.dismiss();
}
});
AlertDialog dialog = builder.create();
dialog.show();
}
}
private void returnSelectedValues(String number, String name) {
/* if (getCallingActivity() != null) {
setResult(RESULT_OK, new Intent()
.putExtra(Intent.EXTRA_PHONE_NUMBER, number)
.putExtra(EXTRA_CONTACT_NAME, name));
finish();
}*/
LinphoneActivity.setAddressAndGoToDialer(number, name);
}
private List<String> extractPhones(String id) {
List<String> list = new ArrayList<String>(); List<String> list = new ArrayList<String>();
Uri uri = ContactsContract.CommonDataKinds.Phone.CONTENT_URI; Uri uri = ContactsContract.CommonDataKinds.Phone.CONTENT_URI;
String selection = ContactsContract.CommonDataKinds.Phone.CONTACT_ID + " = ?"; String selection = ContactsContract.CommonDataKinds.Phone.CONTACT_ID + " = ?";
String[] selArgs = new String[] {id}; String[] selArgs = new String[] {id};
Cursor c = this.getContentResolver().query(uri, null, selection, selArgs, null); Cursor c = this.getContentResolver().query(uri, null, selection, selArgs, null);
int nbId = c.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER); int nbId = c.getColumnIndex(ContactsContract.CommonDataKinds.Phone.NUMBER);
while (c.moveToNext()) { while (c.moveToNext()) {
list.add(c.getString(nbId)); list.add(c.getString(nbId));
} }
c.close(); c.close();
return list; return list;
} }
private List<String> extractSipNumbers(String id) { protected List<String> extractSipNumbers(String id) {
List<String> list = new ArrayList<String>(); List<String> list = new ArrayList<String>();
Uri uri = ContactsContract.Data.CONTENT_URI; Uri uri = ContactsContract.Data.CONTENT_URI;
String selection = new StringBuilder() String selection = new StringBuilder()
.append(ContactsContract.Data.CONTACT_ID).append(" = ? AND ") .append(ContactsContract.Data.CONTACT_ID).append(" = ? AND ")
.append(ContactsContract.Data.MIMETYPE).append(" = ? ") .append(ContactsContract.Data.MIMETYPE).append(" = ? ")
.append(" AND lower(") .append(" AND lower(")
.append(ContactsContract.CommonDataKinds.Im.CUSTOM_PROTOCOL) .append(ContactsContract.CommonDataKinds.Im.CUSTOM_PROTOCOL)
.append(") = 'sip'").toString(); .append(") = 'sip'").toString();
String[] selArgs = new String[] {id, ContactsContract.CommonDataKinds.Im.CONTENT_ITEM_TYPE}; String[] selArgs = new String[] {id, ContactsContract.CommonDataKinds.Im.CONTENT_ITEM_TYPE};
Cursor c = this.getContentResolver().query(uri, null, selection, selArgs, null); Cursor c = this.getContentResolver().query(uri, null, selection, selArgs, null);
int nbId = c.getColumnIndex(ContactsContract.CommonDataKinds.Im.DATA); int nbId = c.getColumnIndex(ContactsContract.CommonDataKinds.Im.DATA);
while (c.moveToNext()) { while (c.moveToNext()) {
list.add("sip:" + c.getString(nbId)); list.add("sip:" + c.getString(nbId));
} }
c.close(); c.close();
return list; return list;
} }
@Override @Override
protected void onResume() { protected void onResume() {
super.onResume(); super.onResume();
if (useNativePicker) { if (useNativePicker) {
Uri uri = ContactsContract.Contacts.CONTENT_URI; Uri uri = ContactsContract.Contacts.CONTENT_URI;
//ContactsContract.CommonDataKinds.Phone.CONTENT_URI //ContactsContract.CommonDataKinds.Phone.CONTENT_URI
@ -217,14 +129,14 @@ public class ContactPickerActivityNew extends Activity implements FilterQueryPro
// If using native picker // If using native picker
if (reqCode == 0) { if (reqCode == 0) {
if (resultCode == RESULT_OK) { if (resultCode == RESULT_OK) {
String id = intent.getData().getLastPathSegment(); String id = intent.getData().getLastPathSegment();
String contactName = intent.getStringExtra(Intent.EXTRA_SHORTCUT_NAME); String contactName = intent.getStringExtra(Intent.EXTRA_SHORTCUT_NAME);
if (contactName == null) if (contactName == null)
contactName = retrieveContactName(id); contactName = retrieveContactName(id);
choosePhoneNumberAndDial(contactName, id); choosePhoneNumberAndDial(contactName, id);
} }
} }
LinphoneActivity.instance().getTabHost().setCurrentTabByTag(LinphoneActivity.DIALER_TAB); LinphoneActivity.instance().getTabHost().setCurrentTabByTag(LinphoneActivity.DIALER_TAB);
} }
@ -233,39 +145,39 @@ public class ContactPickerActivityNew extends Activity implements FilterQueryPro
Uri uri = ContactsContract.CommonDataKinds.Phone.CONTENT_URI; Uri uri = ContactsContract.CommonDataKinds.Phone.CONTENT_URI;
String selection = ContactsContract.CommonDataKinds.Phone._ID + " = ?"; String selection = ContactsContract.CommonDataKinds.Phone._ID + " = ?";
String[] selArgs = new String[] {id}; String[] selArgs = new String[] {id};
Cursor c = this.getContentResolver().query(uri, null, selection, selArgs, null); Cursor c = this.getContentResolver().query(uri, null, selection, selArgs, null);
String name = ""; String name = "";
if (c.moveToFirst()) { if (c.moveToFirst()) {
name = c.getString(c.getColumnIndex(ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME)); name = c.getString(c.getColumnIndex(ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME));
} }
c.close(); c.close();
return name; return name;
} }
public Cursor runQuery(CharSequence constraint) { public Cursor runQuery(CharSequence constraint) {
// Run query // Run query
Uri uri = ContactsContract.Contacts.CONTENT_URI; Uri uri = ContactsContract.Contacts.CONTENT_URI;
String[] projection = new String[] { String[] projection = new String[] {
ContactsContract.Contacts._ID, ContactsContract.Contacts._ID,
ContactsContract.Contacts.DISPLAY_NAME ContactsContract.Contacts.DISPLAY_NAME
}; };
String selection = String selection =
ContactsContract.Contacts.IN_VISIBLE_GROUP + " = '1' and " ContactsContract.Contacts.IN_VISIBLE_GROUP + " = '1' and "
+ ContactsContract.Contacts.HAS_PHONE_NUMBER + " = '1'"; + ContactsContract.Contacts.HAS_PHONE_NUMBER + " = '1'";
String[] selectionArgs = null; String[] selectionArgs = null;
if (!TextUtils.isEmpty(constraint)) { if (!TextUtils.isEmpty(constraint)) {
// FIXME absolutely unsecure // FIXME SQL injection - Android doesn't accept '?' in like queries
selection += " and " + ContactsContract.Contacts.DISPLAY_NAME + " ilike '%"+mcontactFilter.getText()+"%'"; selection += " and " + ContactsContract.Contacts.DISPLAY_NAME + " like '%"+mcontactFilter.getText()+"%'";
} }
String sortOrder = ContactsContract.Contacts.DISPLAY_NAME + " COLLATE LOCALIZED ASC";
return managedQuery(uri, projection, selection, selectionArgs, sortOrder); String sortOrder = ContactsContract.Contacts.DISPLAY_NAME + " COLLATE LOCALIZED ASC";
return managedQuery(uri, projection, selection, selectionArgs, sortOrder);
} }
} }

View file

@ -19,11 +19,14 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
package org.linphone; package org.linphone;
import android.app.Activity; import android.app.Activity;
import android.content.ContentUris;
import android.content.Intent; import android.content.Intent;
import android.database.Cursor; import android.database.Cursor;
import android.net.Uri;
import android.os.Bundle; import android.os.Bundle;
import android.provider.Contacts; import android.provider.Contacts;
import android.provider.Contacts.People; import android.provider.Contacts.People;
import android.provider.Contacts.Photos;
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
public class ContactPickerActivityOld extends Activity { public class ContactPickerActivityOld extends Activity {
@ -45,11 +48,27 @@ public class ContactPickerActivityOld extends Activity {
} }
private Uri getPhotoUri(Uri photoUri) {
Cursor cursor = getContentResolver().query(photoUri, new String[]{Photos.DATA}, null, null, null);
try {
if (cursor == null || !cursor.moveToNext()) {
return null;
}
byte[] data = cursor.getBlob(0);
if (data == null) {
return null;
}
return photoUri;
} finally {
if (cursor != null) cursor.close();
}
}
protected void onActivityResult(int requestCode, int resultCode, protected void onActivityResult(int requestCode, int resultCode,
Intent data) { Intent data) {
if (requestCode == PICK_CONTACT_REQUEST) { if (requestCode == PICK_CONTACT_REQUEST) {
if (resultCode == RESULT_OK) { if (resultCode == RESULT_OK) {
String lColumns[] = new String[] { People.NAME, People.NUMBER }; String lColumns[] = new String[] { People._ID, People.NAME, People.NUMBER };
Cursor lCur = managedQuery(data.getData(), lColumns, // Which columns to return Cursor lCur = managedQuery(data.getData(), lColumns, // Which columns to return
null, // WHERE clause; which rows to return(all rows) null, // WHERE clause; which rows to return(all rows)
@ -58,12 +77,14 @@ public class ContactPickerActivityOld extends Activity {
); );
if (lCur.moveToFirst()) { if (lCur.moveToFirst()) {
String lName = null; String lName = lCur.getString(lCur.getColumnIndex(People.NAME));
String lPhoneNo = null; String lPhoneNo = lCur.getString(lCur.getColumnIndex(People.NUMBER));
// Get the field values long id = lCur.getLong(lCur.getColumnIndex(People._ID));
lName = lCur.getString(lCur.getColumnIndex(People.NAME)); Uri personUri = ContentUris.withAppendedId(People.CONTENT_URI, id);
lPhoneNo = lCur.getString(lCur.getColumnIndex(People.NUMBER)); Uri potentialPictureUri = Uri.withAppendedPath(personUri, Contacts.Photos.CONTENT_DIRECTORY);
DialerActivity.instance().setContactAddress(lPhoneNo, lName); Uri pictureUri = getPhotoUri(potentialPictureUri);
// FIXME surprisingly all this picture stuff doesn't seem to work
DialerActivity.instance().setContactAddress(lPhoneNo, lName, pictureUri);
} }
} }

View file

@ -40,6 +40,7 @@ import android.content.Context;
import android.content.Intent; import android.content.Intent;
import android.content.SharedPreferences; import android.content.SharedPreferences;
import android.media.AudioManager; import android.media.AudioManager;
import android.net.Uri;
import android.os.Bundle; import android.os.Bundle;
import android.os.PowerManager; import android.os.PowerManager;
import android.preference.PreferenceManager; import android.preference.PreferenceManager;
@ -220,7 +221,8 @@ public class DialerActivity extends SoftVolumeActivity implements LinphoneGuiLis
if (!mWakeLock.isHeld()) mWakeLock.acquire(); if (!mWakeLock.isHeld()) mWakeLock.acquire();
if (useIncallActivity) { if (useIncallActivity) {
LinphoneActivity.instance().startIncallActivity(mDisplayNameView.getText()); LinphoneActivity.instance().startIncallActivity(
mDisplayNameView.getText(), mAddress.getPictureUri());
} else { } else {
loadMicAndSpeakerUiStateFromManager(); loadMicAndSpeakerUiStateFromManager();
mCallControlRow.setVisibility(View.GONE); mCallControlRow.setVisibility(View.GONE);
@ -346,9 +348,10 @@ public class DialerActivity extends SoftVolumeActivity implements LinphoneGuiLis
} }
public void setContactAddress(String aContact,String aDisplayName) { public void setContactAddress(String aContact,String aDisplayName, Uri photo) {
mAddress.setText(aContact); mAddress.setText(aContact);
mAddress.setDisplayedName(aDisplayName); mAddress.setDisplayedName(aDisplayName);
mAddress.setPictureUri(photo);
} }

View file

@ -59,11 +59,12 @@ public class HistoryActivity extends ListActivity {
TextView lSecondLineView = (TextView) v.findViewById(R.id.history_cell_second_line); TextView lSecondLineView = (TextView) v.findViewById(R.id.history_cell_second_line);
if (lSecondLineView.getVisibility() == View.GONE) { if (lSecondLineView.getVisibility() == View.GONE) {
// no display name // no display name
LinphoneActivity.setAddressAndGoToDialer(lFirstLineView.getText().toString(), null); LinphoneActivity.setAddressAndGoToDialer(lFirstLineView.getText().toString(), null, null);
} else { } else {
LinphoneActivity.setAddressAndGoToDialer( LinphoneActivity.setAddressAndGoToDialer(
lSecondLineView.getText().toString(), lSecondLineView.getText().toString(),
lFirstLineView.getText().toString()); lFirstLineView.getText().toString(),
null);
} }
} }

View file

@ -35,6 +35,7 @@ import android.widget.TextView;
public class IncallActivity extends SoftVolumeActivity implements OnClickListener { public class IncallActivity extends SoftVolumeActivity implements OnClickListener {
public static final String CONTACT_KEY = "contact"; public static final String CONTACT_KEY = "contact";
public static final String PICTURE_URI_KEY = "picture_uri";
private View numpadClose; private View numpadClose;
private View numpadShow; private View numpadShow;
private View numpad; private View numpad;

View file

@ -41,6 +41,7 @@ import android.hardware.Sensor;
import android.hardware.SensorEvent; import android.hardware.SensorEvent;
import android.hardware.SensorEventListener; import android.hardware.SensorEventListener;
import android.hardware.SensorManager; import android.hardware.SensorManager;
import android.net.Uri;
import android.os.Bundle; import android.os.Bundle;
import android.os.Handler; import android.os.Handler;
import android.preference.PreferenceManager; import android.preference.PreferenceManager;
@ -214,7 +215,7 @@ public class LinphoneActivity extends TabActivity {
gotToDialer(); gotToDialer();
} else { } else {
if (getResources().getBoolean(R.bool.use_incall_activity)) { if (getResources().getBoolean(R.bool.use_incall_activity)) {
startIncallActivity(LinphoneManager.getInstance().extractADisplayName()); startIncallActivity(LinphoneManager.getInstance().extractADisplayName(), null);
} else { } else {
// TODO // TODO
Log.e(TAG, "Not handled case: recreation while in call and not using incall activity"); Log.e(TAG, "Not handled case: recreation while in call and not using incall activity");
@ -423,8 +424,8 @@ public class LinphoneActivity extends TabActivity {
builder.create().show(); builder.create().show();
} }
static void setAddressAndGoToDialer(String number, String name) { static void setAddressAndGoToDialer(String number, String name, Uri photo) {
DialerActivity.instance().setContactAddress(number, name); DialerActivity.instance().setContactAddress(number, name, photo);
instance.gotToDialer(); instance.gotToDialer();
} }
@ -441,11 +442,12 @@ public class LinphoneActivity extends TabActivity {
getTabHost().addTab(spec); getTabHost().addTab(spec);
} }
public void startIncallActivity(CharSequence callerName) { public void startIncallActivity(CharSequence callerName, Uri pictureUri) {
startActivityForResult( Intent intent = new Intent().setClass(this, IncallActivity.class)
new Intent().setClass(this, IncallActivity.class) .putExtra(IncallActivity.CONTACT_KEY, callerName);
.putExtra(IncallActivity.CONTACT_KEY, callerName), if (pictureUri != null)
INCALL_ACTIVITY); intent.putExtra(IncallActivity.PICTURE_URI_KEY, pictureUri.toString());
startActivityForResult(intent, INCALL_ACTIVITY);
} }
public void closeIncallActivity() { public void closeIncallActivity() {

View file

@ -21,6 +21,7 @@ package org.linphone.ui;
import org.linphone.LinphoneManager.AddressType; import org.linphone.LinphoneManager.AddressType;
import android.content.Context; import android.content.Context;
import android.net.Uri;
import android.util.AttributeSet; import android.util.AttributeSet;
import android.widget.EditText; import android.widget.EditText;
@ -31,6 +32,10 @@ import android.widget.EditText;
public class AddressText extends EditText implements AddressType { public class AddressText extends EditText implements AddressType {
private String displayedName; private String displayedName;
private Uri pictureUri;
public void setPictureUri(Uri uri) {pictureUri = uri;}
public Uri getPictureUri() {return pictureUri;}
public AddressText(Context context, AttributeSet attrs) { public AddressText(Context context, AttributeSet attrs) {
super(context, attrs); super(context, attrs);
@ -57,8 +62,8 @@ public class AddressText extends EditText implements AddressType {
protected void onTextChanged(CharSequence text, int start, int before, protected void onTextChanged(CharSequence text, int start, int before,
int after) { int after) {
clearDisplayedName(); clearDisplayedName();
pictureUri=null;
super.onTextChanged(text, start, before, after); super.onTextChanged(text, start, before, after);
} }
} }