59、微信-我-设置SettingActivity

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
android:gravity="center_horizontal"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
xmlns:android="http://schemas.android.com/apk/res/android">

<include layout="@layout/layout_title" />


<ScrollView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:scrollbars="none">
<LinearLayout
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
<TextView
android:id="@+id/txt_usersafe"
style="@style/TxtTitle"
android:textSize="16sp"
android:gravity="center_vertical"
android:background="@drawable/setting_item_selector"
android:layout_width="fill_parent"
android:layout_height="50dp"
android:paddingLeft="16dp"
android:paddingRight="10dp"
android:layout_marginTop="20dp"
android:drawableRight="@drawable/right"
android:text="账号安全" />
<View
android:background="@color/black2"
android:layout_width="fill_parent"
android:layout_height="1.0dip" />




<TextView
android:id="@+id/txt_msgtip"
style="@style/TxtTitle"
android:textSize="16sp"
android:layout_marginTop="20dp"
android:gravity="center_vertical"
android:background="@drawable/setting_item_selector"
android:layout_width="fill_parent"
android:layout_height="50dp"
android:paddingLeft="16dp"
android:paddingRight="10dp"
android:drawableRight="@drawable/right"
android:text="新消息通知" />
<View
android:background="@color/black2"
android:layout_width="fill_parent"
android:layout_height="1.0dip" />




<TextView
android:id="@+id/txt_yinsi"
style="@style/TxtTitle"
android:textSize="16sp"
android:gravity="center_vertical"
android:background="@drawable/setting_item_selector"
android:layout_width="fill_parent"
android:layout_height="50dp"
android:paddingLeft="16dp"
android:paddingRight="10dp"
android:drawableRight="@drawable/right"
android:text="隐私" />
<View
android:background="@color/black2"
android:layout_width="fill_parent"
android:layout_height="1.0dip" />
<TextView
android:id="@+id/txt_tongyong"
style="@style/TxtTitle"
android:textSize="16sp"
android:gravity="center_vertical"
android:background="@drawable/setting_item_selector"
android:layout_width="fill_parent"
android:layout_height="50dp"
android:paddingLeft="16dp"
android:paddingRight="10dp"
android:drawableRight="@drawable/right"
android:text="通用" />
<View
android:background="@color/black2"
android:layout_width="fill_parent"
android:layout_height="1.0dip" />

<TextView
android:id="@+id/txt_about"
style="@style/TxtTitle"
android:textSize="16sp"
android:layout_marginTop="20dp"
android:gravity="center_vertical"
android:background="@drawable/setting_item_selector"
android:layout_width="fill_parent"
android:layout_height="50dp"
android:paddingLeft="16dp"
android:paddingRight="10dp"
android:drawableRight="@drawable/right"
android:text="关于微信" />
<View
android:background="@color/black2"
android:layout_width="fill_parent"
android:layout_height="1.0dip" />

<LinearLayout
android:gravity="center"
android:padding="20.0dip"
android:layout_width="fill_parent"
android:layout_height="80.0dip">
<Button
android:textColor="@color/white"
android:id="@+id/btnexit"
android:background="@drawable/btn_bg_red2"
android:padding="10.0dip"
android:layout_width="fill_parent"
android:layout_height="40.0dip"
android:text="退出登录" />
</LinearLayout>
</LinearLayout>
</ScrollView>
</LinearLayout>

布局设计可以借鉴,代码比较简单:
public class SettingActivity extends BaseActivity implements View.OnClickListener {

private TextView txt_title, txt_tip;

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_setting);
findViewById();
initViews();
setOnListener();
}

@Override
protected void onResume() {
super.onResume();
}

@Override
protected void onDestroy() {
super.onDestroy();
}

private void findViewById() {
findViewById(R.id.img_back).setVisibility(View.VISIBLE);
findViewById(R.id.txt_right).setVisibility(View.GONE);
txt_title = (TextView) findViewById(R.id.txt_title);
txt_title.setText("设置");
}

private void initViews() {
}

private void setOnListener() {
findViewById(R.id.img_back).setOnClickListener(this);
findViewById(R.id.btnexit).setOnClickListener(this);
findViewById(R.id.txt_msgtip).setOnClickListener(this);
findViewById(R.id.txt_usersafe).setOnClickListener(this);
findViewById(R.id.txt_yinsi).setOnClickListener(this);
findViewById(R.id.txt_about).setOnClickListener(this);
}

@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.img_back:
Utils.finish(SettingActivity.this);
break;
case R.id.txt_about:
Utils.start_Activity(SettingActivity.this, WebViewActivity.class,
new BasicNameValuePair(Constants.Title, "关于微信"),
new BasicNameValuePair(Constants.URL,
"https://github.com/motianhuo/wechat"));
break;

case R.id.btnexit:
EMChatManager.getInstance().logout();// 退出环信聊天
Utils.RemoveValue(context, Constants.LoginState);
Utils.RemoveValue(context, Constants.UserInfo);
Utils.RemoveValue(context, Constants.NAME);
Utils.RemoveValue(context, Constants.PWD);
App.getInstance2().exit();
Utils.start_Activity(this, LoginActivity.class);
break;
default:
break;
}
}

@Override
protected void initControl() {
// TODO Auto-generated method stub
}

@Override
protected void initView() {
// TODO Auto-generated method stub
}

@Override
protected void initData() {
// TODO Auto-generated method stub
}

@Override
protected void setListener() {
// TODO Auto-generated method stub
}

}

### 回答1: 下面是用 Kotlin 编写的一个示例代码,可以在设置 activity 中打开通知并显示正在运行的代码: ```kotlin import android.app.NotificationManager import android.content.Context import android.os.Bundle import androidx.appcompat.app.AppCompatActivity import androidx.core.app.NotificationCompat class SettingsActivity : AppCompatActivity() { // 通知 ID private val NOTIFICATION_ID = 1 override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_settings) // 打开通知 val notificationManager = getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager val notificationBuilder = NotificationCompat.Builder(this, "default") .setSmallIcon(R.drawable.notification_icon) .setContentTitle("My App") .setContentText("正在运行中...") .setPriority(NotificationCompat.PRIORITY_DEFAULT) // 显示通知 notificationManager.notify(NOTIFICATION_ID, notificationBuilder.build()) } } ``` 在 `onCreate()` 方法中,我们创建了一个 `NotificationCompat.Builder` 对象,并设置了通知的小图标、标题、内容和优先级。然后,我们通过 `NotificationManager` 的 `notify()` 方法来显示通知。 请注意,我们将 `NOTIFICATION_ID` 设置为 1,这是为了确保我们的应用程序可以在以后更新或删除此通知。如果您在应用程序中使用多个通知,每个通知都应该有唯一的 ID。 同时,您需要在 AndroidManifest.xml 文件中声明一个通知渠道。可以在 `<application>` 标签内添加以下代码: ```xml <application> ... <meta-data android:name="android.app.notification.channel.default" android:importance="default" android:allowBubbles="false" android:description="@string/notification_channel_description" /> ... </application> ``` 这将创建一个名为 "default" 的通知渠道,并设置其重要性为默认。您还可以设置其他属性,例如是否允许气泡通知,通知的描述等。 希望这可以帮助您实现您的需求! ### 回答2: 使用Kotlin编写一个设置Activity打开,并在通知中显示正在运行的代码的示例代码如下: 首先,创建一个名为SettingActivity.kt的Kotlin类文件,包含以下代码: ```kotlin import android.content.Intent import android.os.Bundle import androidx.appcompat.app.AppCompatActivity import androidx.core.app.NotificationCompat import androidx.core.app.NotificationManagerCompat class SettingActivity : AppCompatActivity() { private val notificationId = 1 override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_setting) // 在通知中显示正在运行的代码 val notification = NotificationCompat.Builder(this, "channel_id") .setContentTitle("正在运行的代码") .setContentText("这里是正在运行的代码...") .setSmallIcon(R.drawable.ic_notification) .setPriority(NotificationCompat.PRIORITY_DEFAULT) .build() // 显示通知 val notificationManager = NotificationManagerCompat.from(this) notificationManager.notify(notificationId, notification) } } ``` 然后,创建一个名为MainActivity.kt的Kotlin类文件,包含以下代码: ```kotlin import android.content.Intent import android.os.Bundle import androidx.appcompat.app.AppCompatActivity class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) // 设置按钮点击事件,打开SettingActivity val settingButton = findViewById<Button>(R.id.button_setting) settingButton.setOnClickListener { val intent = Intent(this, SettingActivity::class.java) startActivity(intent) } } } ``` 在AndroidManifest.xml文件中注册SettingActivity: ```xml <activity android:name=".SettingActivity" /> ``` 在res文件夹中创建一个名为ic_notification的图标资源文件,用于通知的小图标。 最后,在你的布局文件(例如activity_main.xml)中添加一个按钮(例如Button),用于打开SettingActivity。 这样,当用户点击按钮时,将打开SettingActivity,并在通知中显示正在运行的代码。 ### 回答3: 使用Kotlin编写一个实现在Activity打开时,显示运行的代码的通知的方法如下: 1. 首先,在AndroidManifest.xml文件中,为你的Activity添加一个Intent过滤器: ```xml <activity android:name=".YourActivityName"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" /> </intent-filter> </activity> ``` 以上代码将为你的Activity设置了一个启动器,使其成为你的应用程序的入口点。 2. 在你的Activity类中,调用NotificationManager创建通知: ```kotlin val CHANNEL_ID = "MyChannelId" // 通知渠道ID val notificationBuilder = NotificationCompat.Builder(this, CHANNEL_ID) .setSmallIcon(R.drawable.ic_launcher) .setContentTitle("正在运行") .setContentText("你的代码正在运行中...") .setPriority(NotificationCompat.PRIORITY_DEFAULT) val notificationManager = getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) { val channel = NotificationChannel( CHANNEL_ID, "My Channel", NotificationManager.IMPORTANCE_DEFAULT ) notificationManager.createNotificationChannel(channel) } notificationManager.notify(1, notificationBuilder.build()) ``` 以上代码会创建一则通知,其中包含一个标题“正在运行”和内容“你的代码正在运行中...”,并且使用了一个合适的小图标。通知渠道ID用来标识通知所属的通知渠道,这里我们创建了一个名为"My Channel"的通知渠道。 3. 最后,在你的Activity的合适位置取消通知: ```kotlin notificationManager.cancel(1) ``` 以上代码会取消ID为1的通知。通常在你的代码执行结束或Activity即将销毁时,调用该代码取消通知。 通过以上步骤,你就可以在Activity打开时,在通知中显示正在运行的代码了。记得在实际使用时,根据你的需求和UI设计进行相应的修改。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

asmcvc

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值