当前位置:首页 > 嵌入式 > 嵌入式软件
[导读] 界面 关键代码下拉列表类? 1 2 3 4 5 6 7 8

 

界面

关键代码

下拉列表类

package com.example.dropdownrefresh.ui;

import java.text.SimpleDateFormat;

import java.util.Date;

import com.example.dropdownrefresh.R;

import android.content.Context;

import android.util.AttributeSet;

import android.util.Log;

import android.view.LayoutInflater;

import android.view.MotionEvent;

import android.view.View;

import android.view.ViewGroup;

import android.view.animation.LinearInterpolator;

import android.view.animation.RotateAnimation;

import android.widget.AbsListView;

import android.widget.AbsListView.OnScrollListener;

import android.widget.BaseAdapter;

import android.widget.ImageView;

import android.widget.LinearLayout;

import android.widget.ListView;

import android.widget.ProgressBar;

import android.widget.TextView;

/**

* 下拉列表类

* @author Administrator

*

*/

public class DropdownListView extends ListView implements OnScrollListener {

private static final String TAG = listview;

private final static int RELEASE_To_REFRESH = 0;

private final static int PULL_To_REFRESH = 1;

private final static int REFRESHING = 2;

private final static int DONE = 3;

private final static int LOADING = 4;

// 实际的padding的距离与界面上偏移距离的比例

private final static int RATIO = 3;

private LayoutInflater inflater;

private LinearLayout headView;

private TextView tipsTextview;

private TextView lastUpdatedTextView;

private ImageView arrowImageView;

private ProgressBar progressBar;

private RotateAnimation animation;

private RotateAnimation reverseAnimation;

// 用于保证startY的值在一个完整的touch事件中只被记录一次

private boolean isRecored;

private int headContentWidth;

private int headContentHeight;

private int startY;

private int firstItemIndex;

private int state;

private boolean isBack;

private OnRefreshListener refreshListener;

private boolean isRefreshable;

public DropdownListView(Context context) {

super(context);

// TODO Auto-generated constructor stub

init(context);

}

public DropdownListView(Context context, AttributeSet attrs) {

super(context, attrs);

init(context);

}

private void init(Context context) {

setCacheColorHint(context.getResources().getColor(R.color.transparent));

inflater = LayoutInflater.from(context);

headView = (LinearLayout) inflater.inflate(R.layout.head, null);

arrowImageView = (ImageView) headView

.findViewById(R.id.head_arrowImageView);

arrowImageView.setMinimumWidth(70);

arrowImageView.setMinimumHeight(50);

progressBar = (ProgressBar) headView

.findViewById(R.id.head_progressBar);

tipsTextview = (TextView) headView.findViewById(R.id.head_tipsTextView);

lastUpdatedTextView = (TextView) headView

.findViewById(R.id.head_lastUpdatedTextView);

measureView(headView);

headContentHeight = headView.getMeasuredHeight();

headContentWidth = headView.getMeasuredWidth();

headView.setPadding(0, -1 * headContentHeight, 0, 0);

headView.invalidate();

Log.v(size, width: + headContentWidth + height:

+ headContentHeight);

addHeaderView(headView, null, false);

setOnScrollListener(this);

animation = new RotateAnimation(0, -180,

RotateAnimation.RELATIVE_TO_SELF, 0.5f,

RotateAnimation.RELATIVE_TO_SELF, 0.5f);

animation.setInterpolator(new LinearInterpolator());

animation.setDuration(250);

animation.setFillAfter(true);

reverseAnimation = new RotateAnimation(-180, 0,

RotateAnimation.RELATIVE_TO_SELF, 0.5f,

RotateAnimation.RELATIVE_TO_SELF, 0.5f);

reverseAnimation.setInterpolator(new LinearInterpolator());

reverseAnimation.setDuration(200);

reverseAnimation.setFillAfter(true);

state = DONE;[!--empirenews.page--]

isRefreshable = false;

}

@Override

public void onScroll(AbsListView arg0, int firstVisiableItem, int arg2,

int arg3) {

// TODO Auto-generated method stub

firstItemIndex = firstVisiableItem;

}

@Override

public void onScrollStateChanged(AbsListView view, int scrollState) {

// TODO Auto-generated method stub

}

public boolean onTouchEvent(MotionEvent event) {

if (isRefreshable) {

switch (event.getAction()) {

case MotionEvent.ACTION_DOWN:

if (firstItemIndex == 0 && !isRecored) {

isRecored = true;

startY = (int) event.getY();

Log.v(TAG, 在down时候记录当前位置‘);

}

break;

case MotionEvent.ACTION_UP:

if (state != REFRESHING && state != LOADING) {

if (state == DONE) {

// 什么都不做

}

if (state == PULL_To_REFRESH) {

state = DONE;

changeHeaderViewByState();

Log.v(TAG, 由下拉刷新状态,到done状态);

}

if (state == RELEASE_To_REFRESH) {

state = REFRESHING;

changeHeaderViewByState();

onRefresh();

Log.v(TAG, 由松开刷新状态,到done状态);

}

}

isRecored = false;

isBack = false;

break;

case MotionEvent.ACTION_MOVE:

int tempY = (int) event.getY();

if (!isRecored && firstItemIndex == 0) {

Log.v(TAG, 在move时候记录下位置);

isRecored = true;

startY = tempY;

}

if (state != REFRESHING && isRecored && state != LOADING) {

// 保证在设置padding的过程中,当前的位置一直是在head,否则如果当列表超出屏幕的话,当在上推的时候,列表会同时进行滚动

// 可以松手去刷新了

if (state == RELEASE_To_REFRESH) {

setSelection(0);

// 往上推了,推到了屏幕足够掩盖head的程度,但是还没有推到全部掩盖的地步

if (((tempY - startY) / RATIO < headContentHeight)

&& (tempY - startY) > 0) {

state = PULL_To_REFRESH;

changeHeaderViewByState();

Log.v(TAG, 由松开刷新状态转变到下拉刷新状态);

}

// 一下子推到顶了

else if (tempY - startY <= 0) {

state = DONE;

changeHeaderViewByState();

Log.v(TAG, 由松开刷新状态转变到done状态);

}

// 往下拉了,或者还没有上推到屏幕顶部掩盖head的地步

else {

// 不用进行特别的操作,只用更新paddingTop的值就行了

}

}

// 还没有到达显示松开刷新的时候,DONE或者是PULL_To_REFRESH状态

if (state == PULL_To_REFRESH) {

setSelection(0);

// 下拉到可以进入RELEASE_TO_REFRESH的状态

if ((tempY - startY) / RATIO >= headContentHeight) {

state = RELEASE_To_REFRESH;

isBack = true;

changeHeaderViewByState();

Log.v(TAG, 由done或者下拉刷新状态转变到松开刷新);

}

// 上推到顶了

else if (tempY - startY <= 0) {

state = DONE;

changeHeaderViewByState();

Log.v(TAG, 由DOne或者下拉刷新状态转变到done状态);

}

}

// done状态下

if (state == DONE) {

if (tempY - startY > 0) {

state = PULL_To_REFRESH;

changeHeaderViewByState();

}

}

// 更新headView的size

if (state == PULL_To_REFRESH) {

headView.setPadding(0, -1 * headContentHeight

+ (tempY - startY) / RATIO, 0, 0);

}

// 更新headView的paddingTop

if (state == RELEASE_To_REFRESH) {

headView.setPadding(0, (tempY - startY) / RATIO

- headContentHeight, 0, 0);

}

}

break;

}

}

return super.onTouchEvent(event);

}

/**

* 当状态改变时候,调用该方法,以更新界面

*/

private void changeHeaderViewByState() {

switch (state) {

case RELEASE_To_REFRESH:

arrowImageView.setVisibility(View.VISIBLE);

progressBar.setVisibility(View.GONE);

tipsTextview.setVisibility(View.VISIBLE);

lastUpdatedTextView.setVisibility(View.VISIBLE);

arrowImageView.clearAnimation();

arrowImageView.startAnimation(animation);

tipsTextview.setText(松开刷新);

Log.v(TAG, 当前状态,松开刷新);

break;

case PULL_To_REFRESH:

progressBar.setVisibility(View.GONE);

tipsTextview.setVisibility(View.VISIBLE);

lastUpdatedTextView.setVisibility(View.VISIBLE);

arrowImageView.clearAnimation();

arrowImageView.setVisibility(View.VISIBLE);

// 是由RELEASE_To_REFRESH状态转变来的

if (isBack) {

isBack = false;

arrowImageView.clearAnimation();

arrowImageView.startAnimation(reverseAnimation);

tipsTextview.setText(下拉刷新);

} else {

tipsTextview.setText(下拉刷新);

}

Log.v(TAG, 当前状态,下拉刷新);

break;

case REFRESHING:[!--empirenews.page--]

headView.setPadding(0, 0, 0, 0);

progressBar.setVisibility(View.VISIBLE);

arrowImageView.clearAnimation();

arrowImageView.setVisibility(View.GONE);

tipsTextview.setText(正在刷新...);

lastUpdatedTextView.setVisibility(View.VISIBLE);

Log.v(TAG, 当前状态,正在刷新...);

break;

case DONE:

headView.setPadding(0, -1 * headContentHeight, 0, 0);

progressBar.setVisibility(View.GONE);

arrowImageView.clearAnimation();

arrowImageView.setImageResource(R.drawable.arrow);

tipsTextview.setText(下拉刷新);

lastUpdatedTextView.setVisibility(View.VISIBLE);

Log.v(TAG, 当前状态,done);

break;

}

}

public void setonRefreshListener(OnRefreshListener refreshListener) {

this.refreshListener = refreshListener;

isRefreshable = true;

}

public interface OnRefreshListener {

public void onRefresh();

}

public void onRefreshComplete() {

state = DONE;

SimpleDateFormat sdf = new SimpleDateFormat(yyyy-MM-dd HH:mm:ss);

lastUpdatedTextView.setText(最近更新: + sdf.format(new Date()));

changeHeaderViewByState();

}

private void onRefresh() {

if (refreshListener != null) {

refreshListener.onRefresh();

}

}

/**

* 此方法直接照搬自网络上的一个下拉刷新的demo,此处是“估计”headView的width以及height

* @param child

*/

private void measureView(View child) {

ViewGroup.LayoutParams p = child.getLayoutParams();

if (p == null) {

p = new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,

ViewGroup.LayoutParams.WRAP_CONTENT);

}

int childWidthSpec = ViewGroup.getChildMeasureSpec(0, 0 + 0, p.width);

int lpHeight = p.height;

int childHeightSpec;

if (lpHeight > 0) {

childHeightSpec = MeasureSpec.makeMeasureSpec(lpHeight,

MeasureSpec.EXACTLY);

} else {

childHeightSpec = MeasureSpec.makeMeasureSpec(0,

MeasureSpec.UNSPECIFIED);

}

child.measure(childWidthSpec, childHeightSpec);

}

public void setAdapter(BaseAdapter adapter) {

SimpleDateFormat sdf = new SimpleDateFormat(yyyy-MM-dd HH:mm:ss);

lastUpdatedTextView.setText(最近更新: + sdf.format(new Date()));

super.setAdapter(adapter);

}

}

main.xml

 

 

 

 

 

下拉列表松开后需要扫描Wifi,再刷新列表

 

106package com.example.dropdownrefresh;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import android.app.Activity;

import android.net.wifi.ScanResult;

import android.os.AsyncTask;

import android.os.Bundle;

import android.view.View;

import android.view.ViewGroup;[!--empirenews.page--]

import android.widget.BaseAdapter;

import android.widget.LinearLayout;

import android.widget.TextView;

import com.example.dropdownrefresh.ui.DropdownListView;

import com.example.dropdownrefresh.ui.DropdownListView.OnRefreshListener;

import com.example.dropdownrefresh.utils.WifiAdmin;

/**

* 使用下拉刷新搜索wifi

* @author Administrator

*

*/

public class MainActivity extends Activity {

WifiAdmin wifiAdmin = null;

private ArrayList

private BaseAdapter adapter;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

wifiAdmin = new WifiAdmin(this);

list = new ArrayList

RefreshList();

final DropdownListView listView = (DropdownListView) findViewById(R.id.listView);

adapter = new BaseAdapter() {

public View getView(int position, View convertView, ViewGroup parent) {

LinearLayout layout = new LinearLayout(getApplicationContext());

layout.setOrientation(LinearLayout.VERTICAL); //垂直布局

HashMap

TextView txtName = new TextView(getApplicationContext());

TextView txtSignal = new TextView(getApplicationContext());

txtName.setText(map.get(wifi_name));

txtSignal.setText(map.get(wifi_signal));

layout.addView(txtName);

layout.addView(txtSignal);

return layout;

}

public long getItemId(int position) {

return 0;

}

public Object getItem(int position) {

return null;

}

public int getCount() {

return list.size();

}

};

listView.setAdapter(adapter);

listView.setonRefreshListener(new OnRefreshListener() {

public void onRefresh() {

new AsyncTask

protected Void doInBackground(Void... params) {

try {

Thread.sleep(1000);

} catch (Exception e) {

e.printStackTrace();

}

list.clear();

RefreshList();

return null;

}

@Override

protected void onPostExecute(Void result) {

adapter.notifyDataSetChanged();

listView.onRefreshComplete();

}

}.execute(null, null, null);

}

});

}

private void RefreshList(){

wifiAdmin.startScan(); // 扫描wifi热点,前提是wifi已经打开

List wifiList = wifiAdmin.getWifiList();

for (int index = 0; index < wifiList.size(); index++) {

HashMap

map.put(wifi_name, (wifiList.get(index)).SSID);

map.put(wifi_signal, signal:

+ (-(wifiList.get(index)).level) + %);

list.add(map);

}

}

}

 

 
[!--empirenews.page--]
本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

2024年5月30日 – 专注于引入新品的全球电子元器件和工业自动化产品授权代理商贸泽电子 (Mouser Electronics) 即日起开售Microchip Technology的RNWF02抢先体验版开发工具。R...

关键字: 工业自动化 IoT Wi-Fi

随着每家每户联网设备数量的不断增加,管理无线干扰(尤其是 2.4 GHz 频段)的挑战也随之而来。根据国际专业服务机构德勤(Deloitte)的数据,2022 年每个家庭的平均联网设备数量为 22 台,随着消费者在家中部...

关键字: Wi-Fi 智能家居 物联网

此战略布局将Wi-Fi HaLow置于台湾无线网络产业中心

关键字: Wi-Fi 无线网络 物联网

全球智能城市运动代表着城市环境设计、体验和导航方式的重大转变。这一重大变革部分是由数字化转型和物联网(IoT)技术推动的,这些技术正在将城市基础设施和城市景观重塑为智能连接中心。这一趋势的核心是符合智能城市独特需求的先进...

关键字: 数字化转型 物联网 Wi-Fi

以下内容中,小编将对宽带和WiFi的区别的相关内容进行着重介绍和阐述,希望本文能帮您增进对宽带和WiFi的了解,和小编一起来看看吧。

关键字: 宽带 Wi-Fi

Wi-Fi,全称为Wireless Fidelity,是一种在全球范围内广泛应用于各类电子设备间无线网络连接的技术。Wi-Fi技术始于20世纪90年代末期,由Wi-Fi联盟(Wi-Fi Alliance)开发并推广,旨在...

关键字: Wi-Fi 无线网络

随着科技的飞速发展,物联网(IoT)技术已经逐渐渗透到我们生活的方方面面。在这个智能化的世界里,各种设备需要通过无线通信技术实现互联互通。而蓝牙网关作为其中的一种重要技术,正扮演着连接物联网世界的桥梁角色。本文将深入探讨...

关键字: 蓝牙网关 Wi-Fi

随着科技的日新月异,无线网络技术也在不断发展与演进。作为现代生活的重要组成部分,WiFi技术经历了从第一代到第五代的演变。本文将重点探讨第四代(WiFi 4)和第五代(WiFi 5,即802.11ac)WiFi技术的区别...

关键字: Wi-Fi 无线网络

在下述的内容中,小编将会对路由器的相关消息予以报道,如果路由器是您想要了解的焦点之一,不妨和小编共同阅读这篇文章哦。

关键字: 路由器 Wi-Fi

在现实条件下,通过 sub-GHz Wi-Fi HaLow 信号远程视频通话距离达传统 Wi-Fi 的 十倍以上

关键字: Wi-Fi 物联网
关闭
关闭