blob: c1097facee9ce4afe6022547bad6c1efa01867b0 [file] [log] [blame]
/*
* Copyright 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.example.android.recyclerview
import android.os.Bundle
import android.view.Menu
import android.view.MenuItem
import android.widget.ViewAnimator
import com.example.android.common.activities.SampleActivityBase
import com.example.android.common.logger.Log
import com.example.android.common.logger.LogFragment
import com.example.android.common.logger.LogWrapper
import com.example.android.common.logger.MessageOnlyLogFilter
/**
* A simple launcher activity containing a summary sample description, sample log and a custom
* [android.support.v4.app.Fragment] which can display a view.
*
*
* For devices with displays with a width of 720dp or greater, the sample log is always visible,
* on other devices it's visibility is controlled by an item on the Action Bar.
*/
class MainActivity : SampleActivityBase() {
// Whether the Log Fragment is currently shown
private var logShown = false
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
if (savedInstanceState == null) {
supportFragmentManager.beginTransaction().run {
replace(R.id.sample_content_fragment, RecyclerViewFragment())
commit()
}
}
}
override fun onCreateOptionsMenu(menu: Menu): Boolean {
menuInflater.inflate(R.menu.main, menu)
return true
}
override fun onPrepareOptionsMenu(menu: Menu): Boolean {
menu.findItem(R.id.menu_toggle_log).run {
isVisible = findViewById<ViewAnimator>(R.id.sample_output) is ViewAnimator
setTitle(if (logShown) R.string.sample_hide_log else R.string.sample_show_log)
}
return super.onPrepareOptionsMenu(menu)
}
override fun onOptionsItemSelected(item: MenuItem) = when (item.itemId) {
R.id.menu_toggle_log -> {
logShown = !logShown
val output = findViewById<ViewAnimator>(R.id.sample_output) as ViewAnimator
output.displayedChild = if (logShown) 1 else 0
invalidateOptionsMenu()
true
}
else -> super.onOptionsItemSelected(item)
}
/** Create a chain of targets that will receive log data */
override fun initializeLogging() {
// Wraps Android's native log framework.
val logWrapper = LogWrapper()
// Using Log, front-end to the logging chain, emulates android.util.log method signatures.
Log.logNode = logWrapper
// Filter strips out everything except the message text.
val msgFilter = MessageOnlyLogFilter()
logWrapper.next = msgFilter
// On screen logging via a fragment with a TextView.
val logFragment = supportFragmentManager.findFragmentById(R.id.log_fragment) as LogFragment
msgFilter.next = logFragment.logView
Log.i(TAG, "Ready")
}
companion object {
val TAG = "MainActivity"
}
}