Removed chat fragment caching.

This commit is contained in:
Felix Ableitner 2014-10-30 20:59:33 +02:00
parent cbcc0802dd
commit 137f337cfe
2 changed files with 14 additions and 33 deletions

View file

@ -1,10 +1,6 @@
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/primary"
android:layout_width="fill_parent" android:layout_width="fill_parent"
android:layout_height="fill_parent"> android:layout_height="fill_parent">
<fragment class="com.nutomic.ensichat.fragments.ContactsFragment"
android:id="@android:id/primary"
android:layout_width="match_parent"
android:layout_height="match_parent" />
</FrameLayout> </FrameLayout>

View file

@ -10,8 +10,6 @@ import com.nutomic.ensichat.R
import com.nutomic.ensichat.bluetooth.{ChatService, Device} import com.nutomic.ensichat.bluetooth.{ChatService, Device}
import com.nutomic.ensichat.fragments.{ChatFragment, ContactsFragment} import com.nutomic.ensichat.fragments.{ChatFragment, ContactsFragment}
import scala.collection.mutable.HashMap
/** /**
* Main activity, entry point for app start. * Main activity, entry point for app start.
*/ */
@ -21,8 +19,6 @@ class MainActivity extends Activity {
private var ContactsFragment: ContactsFragment = _ private var ContactsFragment: ContactsFragment = _
private val ChatFragments = new HashMap[Device.ID, ChatFragment]()
private var currentChat: Option[Device.ID] = None private var currentChat: Option[Device.ID] = None
/** /**
@ -37,24 +33,22 @@ class MainActivity extends Activity {
Intent(BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE) Intent(BluetoothAdapter.ACTION_REQUEST_DISCOVERABLE)
intent.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION, 0) intent.putExtra(BluetoothAdapter.EXTRA_DISCOVERABLE_DURATION, 0)
startActivityForResult(intent, RequestSetDiscoverable) startActivityForResult(intent, RequestSetDiscoverable)
val fm = getFragmentManager val fm = getFragmentManager
if (savedInstanceState != null) { if (savedInstanceState != null) {
ContactsFragment = fm.getFragment(savedInstanceState, classOf[ContactsFragment].getName) ContactsFragment = fm.getFragment(savedInstanceState, classOf[ContactsFragment].getName)
.asInstanceOf[ContactsFragment] .asInstanceOf[ContactsFragment]
for (i <- 0 until savedInstanceState.getInt("chat_fragments_count", 0)) { if (savedInstanceState.containsKey("current_chat")) {
val key = classOf[ChatFragment].getName + i currentChat = Option(new Device.ID(savedInstanceState.getString("current_chat")))
val cf = fm.getFragment(savedInstanceState, key).asInstanceOf[ChatFragment] openChat(currentChat.get)
ChatFragments += (cf.getDevice -> cf)
} }
currentChat = Some(new Device.ID(savedInstanceState.getString("current_chat")))
currentChat.collect{case c => openChat(c) }
} else { } else {
ContactsFragment = new ContactsFragment() ContactsFragment = new ContactsFragment()
}
fm.beginTransaction() fm.beginTransaction()
.add(android.R.id.content, ContactsFragment) .add(android.R.id.content, ContactsFragment)
.commit() .commit()
} }
}
/** /**
* Saves all fragment state. * Saves all fragment state.
@ -62,13 +56,7 @@ class MainActivity extends Activity {
override def onSaveInstanceState(outState: Bundle): Unit = { override def onSaveInstanceState(outState: Bundle): Unit = {
super.onSaveInstanceState(outState) super.onSaveInstanceState(outState)
getFragmentManager.putFragment(outState, classOf[ContactsFragment].getName, ContactsFragment) getFragmentManager.putFragment(outState, classOf[ContactsFragment].getName, ContactsFragment)
outState.putInt("chat_fragments_count", ChatFragments.size) currentChat.collect{case c => outState.putString("current_chat", c.toString)}
var i: Int = 0
ChatFragments.foreach(cf => {
getFragmentManager.putFragment(outState, classOf[ChatFragment].getName + i, cf._2)
i += 1
})
outState.putString("current_chat", currentChat.toString)
} }
override def onCreateOptionsMenu(menu: Menu): Boolean = { override def onCreateOptionsMenu(menu: Menu): Boolean = {
@ -105,13 +93,10 @@ class MainActivity extends Activity {
*/ */
def openChat(device: Device.ID): Unit = { def openChat(device: Device.ID): Unit = {
currentChat = Some(device) currentChat = Some(device)
val ft = getFragmentManager.beginTransaction() getFragmentManager
if (!ChatFragments.keySet.contains(device)) { .beginTransaction()
ChatFragments += (device -> new ChatFragment(device)) .detach(ContactsFragment)
ft.add(android.R.id.content, ChatFragments.apply(device)) .add(android.R.id.content, new ChatFragment(device))
}
ft.detach(ContactsFragment)
.attach(ChatFragments.apply(device))
.commit() .commit()
} }
@ -122,7 +107,7 @@ class MainActivity extends Activity {
if (currentChat != None) { if (currentChat != None) {
getFragmentManager getFragmentManager
.beginTransaction() .beginTransaction()
.detach(ChatFragments.apply(currentChat.get)) .remove(getFragmentManager().findFragmentById(android.R.id.content))
.attach(ContactsFragment) .attach(ContactsFragment)
.commit() .commit()
currentChat = None currentChat = None