鱼C论坛

 找回密码
 立即注册
查看: 2085|回复: 0

[技术交流] kotlin for android 之alertdailog控件与添加删除条目

[复制链接]
发表于 2017-12-1 12:05:37 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
        继续昨天的项目,给增加可以添加删除条目的功能。修改data_item.xml
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout
  3.     xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"
  4.     android:layout_height="match_parent"
  5.     android:orientation="horizontal">

  6.     <ImageView
  7.         android:id="@+id/idimage"
  8.         android:layout_width="wrap_content"
  9.         android:layout_height="wrap_content"
  10.         android:layout_marginLeft="10dp"
  11.         android:src="@android:drawable/ic_delete" />
  12.     <LinearLayout
  13.         android:layout_width="wrap_content"
  14.         android:layout_height="wrap_content"
  15.         android:orientation="vertical"
  16.         android:layout_marginLeft="10dp"
  17.         android:background="@drawable/background">
  18.         <TextView
  19.             android:id="@+id/idtext1"
  20.             android:layout_width="wrap_content"
  21.             android:layout_height="wrap_content"
  22.             android:text="aaaaaaaaaaaaaaa"
  23.             android:layout_marginBottom="10dp"
  24.             android:textSize="20sp"
  25.             android:textStyle="bold"/>
  26.         <TextView
  27.             android:id="@+id/idtext2"
  28.             android:layout_width="wrap_content"
  29.             android:layout_height="wrap_content"
  30.             android:text="bbbbbbbbbbbbbbbbbb"
  31.             android:textSize="20sp"
  32.             android:fontFamily="cursive" />
  33.     </LinearLayout>

  34. </LinearLayout>
复制代码

在layout目录下新建alert_dailog.xml文件,修改为:
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout
  3.     xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"
  4.     android:layout_height="match_parent"
  5.     android:orientation="vertical">
  6.     <EditText
  7.         android:id="@+id/idaddtext"
  8.         android:layout_width="140dp"
  9.         android:layout_height="wrap_content"
  10.         android:layout_gravity="center_horizontal"/>
  11.     <Button
  12.         android:id="@+id/idaddbutton"
  13.         android:layout_width="wrap_content"
  14.         android:layout_height="wrap_content"
  15.         android:text="add data"
  16.         android:layout_gravity="center_horizontal"
  17.         android:layout_marginTop="20dp"/>

  18. </LinearLayout>
复制代码

在res目录下新建menu目录,然后再menu目录里新建menu.xml文件:
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <menu xmlns:app="http://schemas.android.com/apk/res-auto"
  3.     xmlns:android="http://schemas.android.com/apk/res/android">
  4.     <item
  5.         android:id="@+id/idmenu"
  6.         android:icon="@android:drawable/ic_input_add"
  7.         android:title="menu"
  8.         android:visible="true"
  9.         app:showAsAction="ifRoom" />
  10. </menu>
复制代码

修改MainActivity.kt文件:
  1. package com.example.xinwei.httpproject

  2. import android.annotation.SuppressLint
  3. import android.content.Context
  4. import android.content.DialogInterface
  5. import android.os.AsyncTask
  6. import android.support.v7.app.AppCompatActivity
  7. import android.os.Bundle
  8. import android.support.v7.app.AlertDialog
  9. import android.util.Log
  10. import android.view.LayoutInflater
  11. import android.view.Menu
  12. import android.view.MenuItem
  13. import android.view.View
  14. import android.widget.ArrayAdapter
  15. import android.widget.Button
  16. import kotlinx.android.synthetic.main.activity_main.*
  17. import kotlinx.android.synthetic.main.alert_dailog.*
  18. import kotlinx.android.synthetic.main.alert_dailog.view.*
  19. import org.json.JSONObject
  20. import org.xmlpull.v1.XmlPullParser
  21. import org.xmlpull.v1.XmlPullParserFactory
  22. import java.io.*
  23. import java.net.HttpURLConnection
  24. import java.net.URL

  25. class MainActivity : AppCompatActivity() {

  26.     var adapter:InternetDataAdapter?=null
  27.     override fun onCreate(savedInstanceState: Bundle?) {
  28.         super.onCreate(savedInstanceState)
  29.         setContentView(R.layout.activity_main)
  30.         getInternetData()
  31.     }
  32.     fun getInternetData(){
  33.         val url="https://query.yahooapis.com/v1/public/yql?q=show%20tables&diagnostics=true"
  34.         val myAsyncTask=MyAsyncTask(this)
  35.         myAsyncTask.execute(url)
  36.     }
  37.     @SuppressLint("StaticFieldLeak")
  38.     inner class MyAsyncTask(val context:Context) : AsyncTask<String, String, String>() {

  39.         override fun onProgressUpdate(vararg values: String?) {
  40.             super.onProgressUpdate(*values)
  41.         }

  42.         override fun doInBackground(vararg p0: String?):String {
  43.             try {
  44.                 val url=URL(p0[0])
  45.                 val urlConnect=url.openConnection() as HttpURLConnection
  46.                 urlConnect.connectTimeout=7000
  47.                 urlConnect.requestMethod="GET"
  48.                 urlConnect.readTimeout=7000
  49.                 var inString=convertToString(urlConnect.inputStream)
  50.                 var parsedData=parseXML(inString)
  51.                 publishProgress(parsedData)
  52.                 urlConnect.disconnect()
  53.                 return parsedData
  54.             }catch (e:Exception){
  55.                 e.printStackTrace()
  56.             }
  57.             return "网站连接失败"
  58.         }

  59.         private fun convertToString(inputStream: InputStream?): String {
  60.             var bufferedReader=BufferedReader(InputStreamReader(inputStream))
  61.             var allString=StringBuilder()
  62.             bufferedReader.forEachLine {
  63.                 allString.append(it)
  64.             }
  65.             bufferedReader.close()
  66.             inputStream?.close()
  67.             return allString.toString()
  68.         }

  69.         override fun onPostExecute(result: String?) {
  70.             super.onPostExecute(result)
  71.             var data=result!!.split(" ")
  72.             data.map {
  73.                 dataArray.add(InternetData("title",it))
  74.             }
  75.             adapter=InternetDataAdapter(context, dataArray)
  76.             idlist.adapter=adapter
  77.         }

  78.         private fun parseXML(result: String): String {

  79.             try {
  80.                 var factory=XmlPullParserFactory.newInstance()
  81.                 var xmlParser=factory.newPullParser()
  82.                 xmlParser.setInput(StringReader(result))
  83.                 var eventType=xmlParser.eventType
  84.                 var str= ArrayList<String>()
  85.                 while (eventType!=XmlPullParser.END_DOCUMENT){
  86.                     var nodeName=xmlParser.name
  87.                     when(eventType){
  88.                         XmlPullParser.START_TAG->{
  89.                             if ("table".equals(nodeName)){
  90.                                 str.add(xmlParser.nextText())
  91.                             }
  92.                         }
  93.                     }
  94.                     eventType=xmlParser.next()
  95.                 }

  96.                 return str.joinToString(" ")
  97.             }catch (e:Exception){
  98.                 e.printStackTrace()
  99.             }
  100.             return ""
  101.         }
  102.     }

  103.     override fun onCreateOptionsMenu(menu: Menu?): Boolean {
  104.         menuInflater.inflate(R.menu.menu,menu)
  105.         return true
  106.     }

  107.     override fun onOptionsItemSelected(item: MenuItem?): Boolean {
  108.         if (item!!.itemId==R.id.idmenu){
  109.             var view=layoutInflater.inflate(R.layout.alert_dailog,null)
  110.             var addButton=view.idaddbutton
  111.             var addText=view.idaddtext
  112.             var alert=AlertDialog.Builder(this)
  113.             alert.setView(view)
  114.             alert.create()
  115.             alert.show()
  116.             addButton.setOnClickListener {
  117.                 if (addText.text.isNotEmpty()){
  118.                     dataArray.add(InternetData("added data",addText.text.toString()))
  119.                     dataArray.reverse()
  120.                     adapter!!.notifyDataSetChanged()
  121.                 }
  122.             }
  123.         }
  124.         return true
  125.     }
  126. }
复制代码

修改makeAdapter.kt文件:
  1. package com.example.xinwei.httpproject

  2. import android.content.Context
  3. import android.view.LayoutInflater
  4. import android.view.View
  5. import android.view.ViewGroup
  6. import android.widget.BaseAdapter
  7. import android.widget.ImageView
  8. import android.widget.TextView

  9. data class InternetData(val title:String,val data:String)

  10. var dataArray=ArrayList<InternetData>()

  11. class InternetDataAdapter(val context:Context, val dataArray:ArrayList<InternetData>):BaseAdapter() {
  12.     override fun getView(p0: Int, p1: View?, p2: ViewGroup?): View {
  13.         var internetData=dataArray[p0]
  14.         var view:View?
  15.         if (p1==null){
  16.             view=LayoutInflater.from(context).inflate(R.layout.data_item,p2,false)
  17.         }else{
  18.             view=p1
  19.         }
  20.         var title=view!!.findViewById<View>(R.id.idtext1) as TextView
  21.         var data=view!!.findViewById<View>(R.id.idtext2) as TextView
  22.         var image=view!!.findViewById<View>(R.id.idimage) as ImageView
  23.         title.text=internetData.title
  24.         data.text=internetData.data
  25.         image.setOnClickListener {
  26.             dataArray.remove(internetData)
  27.             notifyDataSetChanged()
  28.         }
  29.         return view
  30.     }

  31.     override fun getItem(p0: Int): Any {
  32.         return dataArray[p0]
  33.     }

  34.     override fun getItemId(p0: Int): Long {
  35.         return p0.toLong()
  36.     }

  37.     override fun getCount(): Int {
  38.         return dataArray.size
  39.     }
  40. }
复制代码

效果图为:
jdfw.gif

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-24 11:39

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表