欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android實(shí)現(xiàn)類似execel的表格 能回顯并能修改表格內(nèi)容的方法

 更新時(shí)間:2018年08月28日 15:51:56   作者:安了個(gè)卓  
今天小編就為大家分享一篇Android實(shí)現(xiàn)類似execel的表格 能回顯并能修改表格內(nèi)容的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

如下所示:

自定義實(shí)現(xiàn)一個(gè)水平滾動(dòng)控件HorizontalScrollView

package com.example.view;

import android.content.Context;
import android.util.AttributeSet;
import android.view.View;
import android.widget.HorizontalScrollView;

/**
 * 自定義實(shí)現(xiàn)一個(gè)水平滾動(dòng)控件HorizontalScrollView
 * @author Administrator
 *
 */
public class SyncHorizontalScrollView extends HorizontalScrollView {
  private View mView;

  public SyncHorizontalScrollView(Context context) {
   super(context);
  }

  public SyncHorizontalScrollView(Context context, AttributeSet attrs) {
   super(context, attrs);
  }

  public SyncHorizontalScrollView(Context context, AttributeSet attrs, int defStyleAttr) {
   super(context, attrs, defStyleAttr);
  }

  protected void onScrollChanged(int l, int t, int oldl, int oldt) {
   super.onScrollChanged(l, t, oldl, oldt);
   if (mView != null) {
    mView.scrollTo(l, t);
   }
  }

  public void setScrollView(View view) {
   mView = view;
  }
}

自定義實(shí)現(xiàn)LinearLayout讓其能跟著ScrollView滾動(dòng)

 package com.example.view;

import android.content.Context;
import android.util.AttributeSet;
import android.widget.LinearLayout;
import android.widget.ListView;

/**
 * 自定義實(shí)現(xiàn)LinearLayout讓其能跟著ScrollView滾動(dòng)
 * @author Administrator
 *
 */
public class NoscrollLinearLayout extends LinearLayout {


 public NoscrollLinearLayout(Context context) {
  super(context);
 }

 public NoscrollLinearLayout(Context context, AttributeSet attrs) {
  super(context, attrs);
 }

 public NoscrollLinearLayout(Context context, AttributeSet attrs, int defStyleAttr) {
  super(context, attrs, defStyleAttr);
 }

 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
  super.onMeasure(widthMeasureSpec, expandSpec);
 }
}

自定義實(shí)現(xiàn)ListView讓其能跟著ScrollView滾動(dòng)

package com.example.view;

import android.content.Context;
import android.util.AttributeSet;
import android.widget.ListView;

/**
 * 自定義實(shí)現(xiàn)ListView讓其能跟著ScrollView滾動(dòng)
 * @author Administrator
 *
 */
public class NoscrollListView extends ListView {

 public NoscrollListView(Context context) {
  super(context);
 }

 public NoscrollListView(Context context, AttributeSet attrs) {
  super(context, attrs);
 }

 public NoscrollListView(Context context, AttributeSet attrs, int defStyleAttr) {
  super(context, attrs, defStyleAttr);
 }

 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
  super.onMeasure(widthMeasureSpec, expandSpec);
 }
}

顯示數(shù)據(jù)的fragment

package com.example.fragment;

import java.util.ArrayList;

import android.app.Fragment;
import android.os.Bundle;
import android.text.TextUtils;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.MeasureSpec;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.EditText;

import com.example.auto.R;

/**
 * 顯示數(shù)據(jù)的fragment
 * @author Administrator
 *
 */
public class ItemFragment extends Fragment {
 private EditText et_1,et_2,et_3,et_4,et_5;
 private ArrayList<EditText>list ;

  @Override 
  public void onCreate(Bundle savedInstanceState) 
  { 
   super.onCreate(savedInstanceState); 
   setHasOptionsMenu(true); 
  } 
  @Override 
 public View onCreateView(LayoutInflater inflater,
    ViewGroup container, Bundle savedInstanceState) {
  View view =inflater.inflate(R.layout.item_fragment,container, false);
  setView(view);
//  setListener();
  return view;
 }
 private void setListener() {

 }
 private void setView(View view) {
  list =new ArrayList<>();
  et_1=(EditText) view.findViewById(R.id.et_1);
  et_2=(EditText) view.findViewById(R.id.et_2);
  et_3=(EditText) view.findViewById(R.id.et_3);
  et_4=(EditText) view.findViewById(R.id.et_4);
  et_5=(EditText) view.findViewById(R.id.et_5);
  list.add( et_1);
  list.add( et_2);
  list.add( et_3);
  list.add( et_4);
  list.add( et_5);
 }
 private StringBuffer sb;
 public String getValue(){
  sb =new StringBuffer();
  for (int i = 0; i < list.size(); i++) {
   String string =list.get(i).getText().toString();
 /*  if (i==0) {
    if (string!=null) {
     sb.append(string);
     sb.append("$");
    }else {
     sb.append("-1");sb.append("$");
    }
   }else*/ if (i==list.size()-1) {
    if (!TextUtils.isEmpty(string)) {
     sb.append(string);
    }else {
     sb.append("-1");
    }
   }else {
    if (!TextUtils.isEmpty(string)) {
     sb.append(string);sb.append("$");
    }else {
     sb.append("-1");sb.append("$");
    }
   }
  }
  return sb.toString();
 }
 public void setXm(String string){
  if (!TextUtils.isEmpty(string)) {
   et_1.setText(string);
  }
 }
 public void setNl(String string){
  if (!TextUtils.isEmpty(string)) {
   et_2.setText(string);
  }
 }
 public void setTw(String string){
  if (!TextUtils.isEmpty(string)) {
   et_3.setText(string);
  }
 }
 public void setMb(String string){
  if (!TextUtils.isEmpty(string)) {
   et_4.setText(string);
  }
 }
 public void setHx(String string){
  if (!TextUtils.isEmpty(string)) {
   et_5.setText(string);
  }
 }

}

java主程序;

package com.example.auto;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

import android.app.Activity;
import android.app.Fragment;
import android.app.FragmentManager;
import android.app.FragmentTransaction;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.view.Window;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;

import com.example.fragment.ItemFragment;
import com.example.view.NoscrollListView;
import com.example.view.SyncHorizontalScrollView;

public class MainActivity extends Activity {
 private NoscrollListView mLeft;
 private LeftAdapter mLeftAdapter;
 private SyncHorizontalScrollView mHeaderHorizontal;
 private SyncHorizontalScrollView mDataHorizontal;
 private List<String> mListData;
 private ArrayList<HashMap<String, String>> data ;
 private Button bt_1;
 private ArrayList< Fragment> fragments;
 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  requestWindowFeature(Window.FEATURE_NO_TITLE);
  setContentView(R.layout.activity_main);
  initView();
//  initData();
  setListener();
  FragmentManager manager =getFragmentManager();
  FragmentTransaction tx = manager.beginTransaction(); 
  fragments=new ArrayList<Fragment>();
  for (int i = 0; i < mListData.size(); i++) {
    ItemFragment mFOne = new ItemFragment(); 
   fragments.add(mFOne);
  }
  Log.i("TAG", "fragment.size=="+fragments.size());
  for (int i = 0; i < fragments.size(); i++) {
   tx.add(R.id.lv_data, fragments.get(i)); 
  }
   tx.commit(); 
 }

// private void initData() {
// }

 private void setListener() {
  bt_1.setOnClickListener(new OnClickListener() {
   @Override
   public void onClick(View v) {
    save();
   }
  });
 }
 @Override
 protected void onResume() {
  super.onResume();
  for (int i = 0; i < fragments.size(); i++) {
   ItemFragment fragment=(ItemFragment) fragments.get(i);
   fragment.setXm(data.get(i).get("姓名"+i));
   fragment.setNl(data.get(i).get("年齡"+i));
   fragment.setTw(data.get(i).get("體溫"+i));
   fragment.setMb(data.get(i).get("脈搏"+i));
   fragment.setHx(data.get(i).get("呼吸"+i));
  }

 }

 protected void save() {
  for (int i = 0; i < fragments.size(); i++) {
  String string= ((ItemFragment)fragments.get(i)).getValue();
  Log.i("TAG", "string=="+string);

  }

 }

 private void initView(){
  bt_1 =(Button) findViewById(R.id.bt_1);
  mLeft = (NoscrollListView) findViewById(R.id.lv_left);
  mDataHorizontal = (SyncHorizontalScrollView) findViewById(R.id.data_horizontal);
  mHeaderHorizontal = (SyncHorizontalScrollView) findViewById(R.id.header_horizontal);

  mDataHorizontal.setScrollView(mHeaderHorizontal);
  mHeaderHorizontal.setScrollView(mDataHorizontal);

  mListData = new ArrayList<>();
  mListData.add("1");
  mListData.add("2");
  mListData.add("3");
  mListData.add("4");
  mListData.add("5");
  mListData.add("6");
  mListData.add("7");
  mListData.add("8");
  mListData.add("9");
  mListData.add("10");
  mListData.add("11");
  mListData.add("12");
  mListData.add("13");

  mLeftAdapter= new LeftAdapter();
  mLeft.setAdapter(mLeftAdapter);
  setData();
 }

 private void setData() {
  if (data==null) {
   data=new ArrayList<>();

  }
  for (int i = 0; i <mListData.size(); i++) {
   HashMap<String, String> map=new HashMap<String, String>();
   map.put("姓名"+i, i+"姓名");
   map.put("年齡"+i, i+"年齡");
   map.put("體溫"+i, i+"體溫");
   map.put("脈搏"+i, i+"脈搏");
   map.put("呼吸"+i, i+"呼吸");
   data.add(map);

  }

 }

 class LeftAdapter extends BaseAdapter {

  @Override
  public int getCount() {
   return mListData.size();
  }

  @Override
  public Object getItem(int position) {
   return mListData.get(position);
  }

  @Override
  public long getItemId(int position) {
   return position;
  }

  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
   ViewHolder holder = null;
   if (convertView == null) {
    holder = new ViewHolder();
    convertView = LayoutInflater.from(MainActivity.this).inflate(R.layout.item_left, null);
    holder.tvLeft = (TextView) convertView.findViewById(R.id.tv_left);
    convertView.setTag(holder);
   } else {
    holder = (ViewHolder) convertView.getTag();
   }

   holder.tvLeft.setText("第" + position + "床");

   return convertView;
  }

  class ViewHolder {
   TextView tvLeft;
  }
 }
 ArrayList<ArrayList<EditText>>list;


}

以下是主布局文件;

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#ffffff"
    android:orientation="vertical">
    <include layout="@layout/top_layout"/>

 <LinearLayout
  android:layout_width="match_parent"
  android:layout_height="50dp"
  android:orientation="horizontal">

  <LinearLayout
   android:layout_width="0dp"
   android:layout_height="50dp"
   android:layout_weight="1"


   android:orientation="vertical">

    <TextView
      android:layout_width="100dp"
      android:layout_height="50dp"
      android:layout_gravity="center"
      android:gravity="center"
      android:text="床號(hào)"/>
  </LinearLayout>

  <View
   android:layout_width="1px"
   android:layout_height="50dp"
   android:background="#cccccc"/>

  <LinearLayout
   android:id="@+id/lin_header_content"
   android:layout_width="0dp"
   android:layout_height="50dp"
   android:layout_weight="3"
   android:orientation="vertical">

   <com.example.view.SyncHorizontalScrollView
    android:id="@+id/header_horizontal"
    android:layout_width="match_parent"
    android:layout_height="50dp"
    android:overScrollMode="never"
    android:scrollbars="none">

    <LinearLayout
     android:id="@+id/lin_year_title"
     android:layout_width="match_parent"
     android:layout_height="50dp"
     android:orientation="horizontal">

     <TextView
      android:id="@+id/tv_name"
      android:layout_width="100dp"
      android:layout_height="50dp"
      android:layout_gravity="center"
      android:gravity="center"
      android:text="姓名"/>

     <View
      android:layout_width="1px"
      android:layout_height="50dp"
      android:background="#cccccc"/>

     <TextView
      android:layout_width="100dp"
      android:layout_height="50dp"
      android:layout_gravity="center"
      android:gravity="center"
      android:text="年齡"/>

     <View
      android:layout_width="1px"
      android:layout_height="50dp"
      android:background="#cccccc"/>

     <TextView
      android:layout_width="100dp"
      android:layout_height="50dp"
      android:layout_gravity="center"
      android:gravity="center"
      android:text="體溫"/>

     <View
      android:layout_width="1px"
      android:layout_height="50dp"
      android:background="#cccccc"/>

     <TextView
      android:layout_width="100dp"
      android:layout_height="50dp"
      android:layout_gravity="center"
      android:gravity="center"
      android:text="脈搏"/>

     <View
      android:layout_width="1px"
      android:layout_height="50dp"
      android:background="#cccccc"/>

     <TextView
      android:layout_width="100dp"
      android:layout_height="50dp"
      android:layout_gravity="center"
      android:gravity="center"
      android:text="呼吸"/>

     <View
      android:layout_width="1px"
      android:layout_height="50dp"
      android:background="#cccccc"/>
    </LinearLayout>
   </com.example.view.SyncHorizontalScrollView>
  </LinearLayout>
 </LinearLayout>

 <View
  android:layout_width="match_parent"
  android:layout_height="1px"
  android:background="#cccccc"/>

 <ScrollView
  android:id="@+id/scroll_content"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:overScrollMode="never"
  android:scrollbars="none">

  <LinearLayout
   android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:layout_alignParentTop="true"
   android:orientation="horizontal">

   <com.example.view.NoscrollListView
    android:id="@+id/lv_left"
    android:layout_width="0dp"
    android:layout_height="match_parent"
    android:divider="@null"
    android:layout_weight="1"
    android:overScrollMode="never"
    android:scrollbars="none"/>

   <View
    android:layout_width="1px"
    android:layout_height="match_parent"
    android:background="#cccccc"/>

   <LinearLayout
    android:id="@+id/lin_data_content"
    android:layout_width="0dp"
    android:layout_height="match_parent"
    android:layout_weight="3"
    android:orientation="vertical">

    <com.example.view.SyncHorizontalScrollView
     android:id="@+id/data_horizontal"
     android:layout_width="match_parent"
     android:layout_height="match_parent"
     android:overScrollMode="never"
     android:scrollbars="none">


     <com.example.view.NoscrollLinearLayout
      android:layout_width="match_parent"
      android:layout_height="match_parent"
      android:overScrollMode="never"
      android:scrollbars="none">
     <LinearLayout
    android:id="@+id/lv_data"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:gravity="center"
    android:orientation="vertical" />
    </com.example.view.NoscrollLinearLayout> 
    </com.example.view.SyncHorizontalScrollView> 
   </LinearLayout>
  </LinearLayout>
 </ScrollView>
</LinearLayout>

以下是數(shù)據(jù)fragment的布局文件;

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

 <EditText
  android:id="@+id/et_1"
  style="@style/et_item"

  android:hint="姓名"
  />
 <View
   android:layout_width="1px"
   android:layout_height="50dp"
   android:background="#cccccc"/>
 <EditText
  android:id="@+id/et_2"
  style="@style/et_item"
   android:hint="年齡"
  android:ems="10" />
 <View
   android:layout_width="1px"
   android:layout_height="50dp"
   android:background="#cccccc"/>
 <EditText
  android:id="@+id/et_3"
      style="@style/et_item"
   android:hint="體溫"
  android:ems="10" />
  <View
   android:layout_width="1px"
   android:layout_height="50dp"
   android:background="#cccccc"/>
 <EditText
  android:id="@+id/et_4"
     style="@style/et_item"
   android:hint="脈搏"
  android:ems="10" />
  <View
   android:layout_width="1px"
   android:layout_height="50dp"
   android:background="#cccccc"/>
 <EditText
  android:id="@+id/et_5"
  style="@style/et_item"
   android:hint="呼吸"
  android:ems="10" />
  <View
   android:layout_width="1px"
   android:layout_height="50dp"
   android:background="#cccccc"/>

</LinearLayout>
 <View
   android:layout_width="match_parent"
   android:layout_height="1px"
   android:background="#cccccc"/>
</LinearLayout>

fragment的EditText的樣式:

<resources>

 <!--
  Base application theme, dependent on API level. This theme is replaced
  by AppBaseTheme from res/values-vXX/styles.xml on newer devices.
 -->
 <style name="AppBaseTheme" parent="android:Theme.Light">
  <!--
   Theme customizations available in newer API levels can go in
   res/values-vXX/styles.xml, while customizations related to
   backward-compatibility can go here.
  -->
 </style>

 <!-- Application theme. -->
 <style name="AppTheme" parent="AppBaseTheme">
  <!-- All customizations that are NOT specific to a particular API-level can go here. -->
 </style>
  <style name="et_item">
  <item name="android:layout_width">100dp</item>
  <item name="android:layout_height">50dp</item>
  <item name="android:gravity">center</item>
  <item name="android:background">@null</item>
 </style>

</resources>

左側(cè)的床號(hào)的listview的布局,只能上下移動(dòng)的部分

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



  <TextView
   android:id="@+id/tv_left"
   android:layout_width="match_parent"
   android:layout_height="50dp"
   android:gravity="center"
   android:text="第1行"/>
   <View
   android:layout_width="match_parent"

   android:layout_height="1px"
   android:background="#cccccc"/>
</LinearLayout>

以下是最上邊的按鈕的布局;

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:layout_width="match_parent"
 android:layout_height="45dp"
 android:background="@drawable/top_bar_bg" >

 <Button
  android:id="@+id/bt_1"
  android:layout_width="wrap_content"
  android:layout_height="wrap_content"
  android:layout_alignParentRight="true"
  android:layout_alignParentTop="true"
  android:text="保存" />

</RelativeLayout>

以上這篇Android實(shí)現(xiàn)類似execel的表格 能回顯并能修改表格內(nèi)容的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • android 通知Notification詳解及實(shí)例代碼

    android 通知Notification詳解及實(shí)例代碼

    這篇文章主要介紹了android 通知Notification詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • 淺談android獲取存儲(chǔ)目錄(路徑)的幾種方式和注意事項(xiàng)

    淺談android獲取存儲(chǔ)目錄(路徑)的幾種方式和注意事項(xiàng)

    今天小編就為大家分享一篇淺談android獲取存儲(chǔ)目錄(路徑)的幾種方式和注意事項(xiàng),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • Android編程模擬HOME鍵功能示例

    Android編程模擬HOME鍵功能示例

    這篇文章主要介紹了Android編程模擬HOME鍵功能的方法,結(jié)合實(shí)例形式分析了Android模擬HOME鍵的原理與相關(guān)事件操作技巧,需要的朋友可以參考下
    2016-10-10
  • Android高手進(jìn)階教程(二十二)之Android中幾種圖像特效處理的集錦匯總!!

    Android高手進(jìn)階教程(二十二)之Android中幾種圖像特效處理的集錦匯總!!

    本篇文章主要介紹了Android中幾種圖像特效處理,比如圓角,倒影,還有就是圖片縮放,Drawable轉(zhuǎn)化為Bitmap,Bitmap轉(zhuǎn)化為Drawable等,有需要的可以了解一下。
    2016-11-11
  • Android仿微信實(shí)現(xiàn)評(píng)論功能

    Android仿微信實(shí)現(xiàn)評(píng)論功能

    這篇文章主要為大家詳細(xì)介紹了Android仿微信實(shí)現(xiàn)評(píng)論功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • Android getActivity()為空的問(wèn)題解決辦法

    Android getActivity()為空的問(wèn)題解決辦法

    這篇文章主要介紹了Android getActivity()為空的問(wèn)題解決辦法的相關(guān)資料,導(dǎo)致apk空指針崩潰問(wèn)題,很嚴(yán)重的問(wèn)題,為了解決這問(wèn)題,上網(wǎng)搜索了很多資料,需要的朋友可以參考下
    2017-07-07
  • Android?利用OpenCV制作人臉檢測(cè)APP

    Android?利用OpenCV制作人臉檢測(cè)APP

    本篇文章手把手教大家使用OpenCV來(lái)實(shí)現(xiàn)一個(gè)能在安卓手機(jī)上運(yùn)行的人臉檢測(cè)APP。其實(shí)不僅僅是能檢測(cè)人臉,還能檢測(cè)鼻子,嘴巴,眼睛和耳朵。需要的朋友可以參考一下
    2021-12-12
  • Android實(shí)現(xiàn)多點(diǎn)觸摸操作

    Android實(shí)現(xiàn)多點(diǎn)觸摸操作

    這篇文章主要介紹了Android實(shí)現(xiàn)多點(diǎn)觸摸操作,實(shí)現(xiàn)圖片的放大、縮小和旋轉(zhuǎn)等處理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Android集成高德地圖詳細(xì)介紹

    Android集成高德地圖詳細(xì)介紹

    大家好,本篇文章主要講的是Android集成高德地圖詳細(xì)介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2022-02-02
  • Android實(shí)現(xiàn)動(dòng)態(tài)添加數(shù)據(jù)與堆疊折線圖詳解流程

    Android實(shí)現(xiàn)動(dòng)態(tài)添加數(shù)據(jù)與堆疊折線圖詳解流程

    堆疊折線圖是折線圖的一種,堆積折線圖用于顯示每一數(shù)值所占大小隨時(shí)間或有序類別而變化的趨勢(shì),可能顯示數(shù)據(jù)點(diǎn)以表示單個(gè)數(shù)據(jù)值,也可能不顯示這些數(shù)據(jù)點(diǎn)。堆疊折線圖中,類別數(shù)據(jù)沿水平軸均勻分布,所有值數(shù)據(jù)沿垂直軸均勻分布
    2021-10-10

最新評(píng)論