自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(26)
  • 资源 (6)
  • 收藏
  • 关注

原创 sublime text记录

http://www.imooc.com/learn/254

2016-08-20 17:50:14 514

原创 git的一些操作(记录)

git config --global user.name "value"  //配置你的用户名。git config --global user.email "邮箱" // 配置你的邮箱。cd f: //意思是进入到f盘目录下。git init //创建代码仓库。ls -al //用来查看.git文件夹。git add . //表示将整

2016-08-10 18:03:14 516

原创 百度地图开发(记录)

http://blog.csdn.net/a873228446/article/details/51316979

2016-08-27 16:04:16 449

原创 Volley请求模板

package com.example.k.volleytest;import android.content.Context;import android.graphics.Bitmap;import android.util.Log;import android.widget.ImageView;import com.android.volley.RequestQueue;im

2016-08-26 23:21:33 403

原创 Android Studio构建优化

第一步到 android studio安装目录下的bin文件夹下打开图中图片:(2)把 -xmx 后面的数字改大一点,比如 2048m 或4096m第二步:在项目下的gradle.properties文件中加入org.gradle.daemon=trueorg.gradle.parallel=true

2016-08-26 14:19:14 429

原创 上下拉刷新控件的监听器(个人记录)

//上拉 public class MyOnPullProcessListener_Top implements PullToRefreshLayout.OnPullProcessListener { //一下拉第一个调用的方法调用一次 @Override public void onPrepare(View v, int which

2016-08-26 13:15:58 630

原创 Android Studio 中建议过滤的文件:

Android Studio 中建议过滤的文件:- .idea 文件夹- .gradle 文件夹- 所有的 build 文件夹- 所有的 .iml 文件- local.properties 文件

2016-08-23 17:29:11 1411

原创 处理svn可能产生的错误

去掉bin和gen文件夹后,需要做以下操作:第一步:(1)右击项目,选则Build Path标签,接着选中Configure.....标签,在src里加入**/.svn/** 如图:双击打开,然后添加进去即可

2016-08-22 20:58:13 310

原创 SQLite总结

查看手机数据的方法:打开安卓SDK目录下的platform-tools目录,将它的路径配置到系统变量里面去如图:然后就可以在doc窗口下进行操作了,步骤如下:(1)在doc窗口输入 cd data/data/程序的包名/databases/  (2)接着输入 ls 即可查看该目录下的内容了,其中后缀名为:db-journal的则是为了让数据库能够支持事务而产生的临时日志文件

2016-08-19 23:24:09 413

原创 RecyclerView的一些操作(记录一下)判断是否到达顶部和尾部

获得网格模式下的RecyclerView第一列第一个可见Item的位置,(位置的排列是从左往右数下去的),比如下面的,Re中有两列,那么aa[0]就是的得到第一列第一个可见状态Item的位置!int aa[] = ((StaggeredGridLayoutManager)getLayoutManager()).findFirstVisibleItemPositions(null);Log.i

2016-08-16 21:08:45 14668 4

原创 绘制带边框的正方形的图片

package com.example.k.shoppingapp.Other;import android.content.Context;import android.graphics.Bitmap;import android.graphics.BitmapFactory;import android.graphics.Canvas;import android.graphics

2016-08-14 20:01:48 2018

原创 Volley的基础使用

requestQueue = Volley.newRequestQueue(baby_activity); for(int a = 0;a<pic_address.length;a++) { requestQueue.add(new ImageRequest(pic_address[a],new Response.Listener(){

2016-08-13 23:42:20 239

原创 广播接收机(监听网络例子,记录一下方便使用)

public class MainActivity extends Activity { private IntentFilter intentfilter;// IntentFilter:意图过滤器。 private NetworkChangeReceier networkchangereceier; @Override protected void onCreate(Bundle s

2016-08-13 23:34:45 828

原创 解决ScrollView嵌套RecyclerView的冲突,非常简单,拿去可以直接用

建一个类package com.example.k.shoppingapp.Extend.Baby_Activity_Extend;import android.content.Context;import android.support.v7.widget.LinearLayoutManager;import android.support.v7.widget.RecyclerVie

2016-08-13 19:32:06 25300 21

原创 图片缓存技术LruCache

privateLruCache cache;//得到本进程最大的可用内存//maxMemory()返回本进程的最大内存,以字节(B)为单位int maxCacheSize = (int) Runtime.getRuntime().maxMemory();//使用五分之一的内存设置int cacheSize = maxCacheSize / 5;//实例化cach

2016-08-13 14:58:23 313

原创 自定义ImageView实现切图的无缝对接

安卓原生ImageView不怎么好用于是乎,网上搜索了一个模板,为了实现切图的无缝对接,参考了网上的资料之后改装了一下如下:package com.example.k.myrecyclerview;/** * Created by k on 2016/8/11. */import android.content.Context;import android.graphics.Bi

2016-08-12 08:42:58 3310

原创 用AutoLayout的一些配置

AutoLayout库的地址 点击打开链接 (1)使用的时候引用autolayout模块,然后在项目的build.gradle文件写入:classpath 'com.jfrog.bintray.gradle:gradle-bintray-plugin:1.0' classpath 'com.github.dcendents:android-maven-gradle-plug

2016-08-11 11:33:51 356

原创 安卓插件错误解决办法(用AutoLayout布局会用到可能)classpath 'com.github.dcendents:android-maven-gradle-plugin:1.3'

Error:Cause: org/gradle/api/publication/maven/internal/DefaultMavenFactory Android首先,要看一下自己的项目使用 “Gradle版本”接着要看一下项目根目录的build.gradle文件中的“dependencies”的 classpath 'com.github.dcendents:and

2016-08-11 10:58:24 3311

原创 自定义ViewGroup实现纵向滑动切换的ViewPager

package com.example.k.scroll_test_1.custom;import android.content.Context;import android.support.v4.view.MotionEventCompat;import android.util.AttributeSet;import android.view.MotionEvent;import

2016-08-09 15:56:58 806

原创 解决事件冲突的代码参考

package com.example.k.touchtest;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.util.Log;import android.view.MotionEvent;import android.view.View;import

2016-08-06 10:05:47 388

原创 anroid studio下的文件分组用法

http://blog.csdn.net/growth58/article/details/47756921

2016-08-05 15:07:45 256

原创 调用系统设置

Intent intent = new Intent(android.provider.Settings.ACTION_WIRELESS_SETTINGS); startActivity(intent);使用下面的字段,可以在你的软件中打开相应的系统设置界面:android.provider.Settings.ACTION_SETTINGS                 

2016-08-05 09:10:34 817

原创 流式布局(实现历史记录功能)

package com.example.k.flowlayout_test;import android.content.Context;import android.graphics.Color;import android.util.AttributeSet;import android.view.View;import android.view.ViewGroup;import

2016-08-04 20:12:07 1897 2

原创 改变按钮风格去掉边框

style="?android:attr/borderlessButtonStyle"

2016-08-04 16:25:32 467

原创 View绘制流程图

2016-08-02 10:53:31 405

原创 自定义ScrollView实现弹性ScrollView

package com.example.k.srctest;import android.annotation.SuppressLint;import android.content.Context;import android.graphics.Rect;import android.util.AttributeSet;import android.view.MotionEvent;

2016-08-02 07:06:43 866

网络请求框架Volley

谷歌最近推出的网路请求框架,功能强大,使用简单,只需几行代码即可完成完成网络请求,适用于数据量不大的请求,比如加载图片,JSON,String等,具体使用方法请百度一下吧,很多教程的!

2016-08-13

解析JSON数据的gson库

这是一款出自谷歌公司的Gson库,用来解析JSON数据非常的简单,用法可以参考http://blog.csdn.net/revival_liang/article/details/51819969

2016-07-04

安卓《独立版Mat》内存分析工具

Android Studio自带的内存监控不够强大,所以我们应该选择独立版Mat来弥补这个不足,使用此工具让我们可以更好的分析内存的泄漏问题。

2016-06-20

SwipeListViewTest项目

先来看activity_main.xml <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" xmlns:swipe="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent" tools:context=".MainActivity" > <com.fortysevendeg.swipelistview.SwipeListView android:id="@+id/example_lv_list" android:layout_width="match_parent" android:layout_height="match_parent" android:listSelector="#00000000" swipe:swipeActionLeft="dismiss" swipe:swipeActionRight="reveal" swipe:swipeAnimationTime="0" swipe:swipeBackView="@+id/back" swipe:swipeCloseAllItemsWhenMoveList="true" swipe:swipeFrontView="@+id/front" swipe:swipeMode="both" swipe:swipeOffsetLeft="0dp" swipe:swipeOffsetRight="0dp" swipe:swipeOpenOnLongPress="false" /> </RelativeLayout> 这里就一个swipelistview控件,我说几个不易理解的属性 表示滑动时的操作,dismiss表示滑动时删除,如果设置为reveal表示滑动时会显示出item后面的选项 swipe:swipeActionLeft=”dismiss” swipe:swipeActionRight=”reveal” 这个是背面布局的id(我们把直接看到的布局叫做前面的,滑动之后才能看到的布局叫做背面的),必须与背面布局id对应 swipe:swipeBackView=”@+id/back” 这个是滚动时候是否关闭背面的布局,true表示关闭,false表示不关闭,一般设置为true swipe:swipeCloseAllItemsWhenMoveList=”true” 这个是前面布局的id,要与布局的id对应 swipe:swipeFrontView=”@+id/front” both表示可以向左滑也可以向右滑,right和left分别表示只能向有或者向左滑动。 swipe:swipeMode=”both” 下面两个表示向左或者向右滑动时的偏移量,一般不在xml文件中设置,而是在代码中根据设置的大小来设置偏移量。 swipe:swipeOffsetLeft=”0dp” swipe:swipeOffsetRight=”0dp” 再来看看Item布局文件,这里包括前面的和后面的,两个重叠在一起: <?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" > <!-- linearlayout中的布局是每一项后面隐藏的布局 --> <LinearLayout android:id="@+id/back" android:layout_width="match_parent" android:layout_height="80dp" android:background="#eee" android:tag="back" > <Button android:id="@+id/example_row_b_action_1" android:layout_width="0dp" android:layout_height="60dp" android:layout_gravity="center" android:layout_marginRight="10dp" android:layout_weight="1" android:text="测试" /> <Button android:id="@+id/example_row_b_action_2" android:layout_width="0dp" android:layout_height="60dp" android:layout_gravity="center" android:layout_marginLeft="10dp" android:layout_weight="1" android:text="删除" /> <Button android:id="@+id/example_row_b_action_3" android:layout_width="0dp" android:layout_height="60dp" android:layout_gravity="center" android:layout_weight="1" android:text="编辑" /> </LinearLayout> <!-- 这里是前台显示的布局 --> <RelativeLayout android:id="@+id/front" android:layout_width="match_parent" android:layout_height="80dp" android:background="#ffffff" android:orientation="vertical" android:tag="front" > <TextView android:id="@+id/example_row_tv_title" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_centerInParent="true" android:textSize="18sp" /> </RelativeLayout> </FrameLayout> 这个布局是一个常规布局,我就不解释了。 MainActivity.Java,关键地方都有注释 public class MainActivity extends Activity { private SwipeListView mSwipeListView ; private SwipeAdapter mAdapter ; public static int deviceWidth ; private List<String> testData ; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); mSwipeListView = (SwipeListView) findViewById(R.id.example_lv_list); testData = getTestData(); //数据适配 mAdapter = new SwipeAdapter(this, R.layout.package_row, testData,mSwipeListView); //拿到设备宽度 deviceWidth = getDeviceWidth(); mSwipeListView.setAdapter(mAdapter); //设置事件监听 mSwipeListView.setSwipeListViewListener( new TestBaseSwipeListViewListener()); reload(); } private List<String> getTestData() { String [] obj = new String[]{"红楼梦","西游记","水浒传","管锥编","宋诗选注","三国演义","android开发高级编程","红楼梦","西游记","水浒传","管锥编","宋诗选注","三国演义","android开发高级编程"}; List<String> list = new ArrayList<String>(Arrays.asList(obj)); return list; } private int getDeviceWidth() { return getResources().getDisplayMetrics().widthPixels; } private void reload() { // mSwipeListView.setSwipeMode(SwipeListView.SWIPE_MODE_LEFT); // mSwipeListView.setSwipeActionLeft(SwipeListView.SWIPE_ACTION_REVEAL); // mSwipeListView.setSwipeActionRight(settings.getSwipeActionRight()); //滑动时向左偏移量,根据设备的大小来决定偏移量的大小 mSwipeListView.setOffsetLeft(deviceWidth * 1 / 3); mSwipeListView.setOffsetRight(deviceWidth * 1 / 3); // mSwipeListView.setOffsetRight(convertDpToPixel(settings.getSwipeOffsetRight())); //设置动画时间 mSwipeListView.setAnimationTime(30); mSwipeListView.setSwipeOpenOnLongPress(false); } class TestBaseSwipeListViewListener extends BaseSwipeListViewListener{ //点击每一项的响应事件 @Override public void onClickFrontView(int position) { super.onClickFrontView(position); Toast.makeText(getApplicationContext(), testData.get(position), Toast.LENGTH_SHORT).show(); } //关闭事件 @Override public void onDismiss(int[] reverseSortedPositions) { for (int position : reverseSortedPositions) { Log.i("lenve", "position--:"+position); testData.remove(position); } mAdapter.notifyDataSetChanged(); } } } 数据适配器: public class SwipeAdapter extends ArrayAdapter<String> { private LayoutInflater mInflater ; private List<String> objects ; private SwipeListView mSwipeListView ; public SwipeAdapter(Context context, int textViewResourceId,List<String> objects, SwipeListView mSwipeListView) { super(context, textViewResourceId, objects); this.objects = objects ; this.mSwipeListView = mSwipeListView ; mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE); } @Override public View getView(final int position, View convertView, ViewGroup parent) { ViewHolder holder = null ; if(convertView == null){ convertView = mInflater.inflate(R.layout.package_row, parent, false); holder = new ViewHolder(); holder.mFrontText = (TextView) convertView.findViewById(R.id.example_row_tv_title); holder.mBackEdit = (Button) convertView.findViewById(R.id.example_row_b_action_3); holder.mBackDelete = (Button) convertView.findViewById(R.id.example_row_b_action_2); convertView.setTag(holder); }else{ holder = (ViewHolder) convertView.getTag(); } holder.mBackDelete.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { //关闭动画 mSwipeListView.closeAnimate(position); //调用dismiss方法删除该项(这个方法在MainActivity中) mSwipeListView.dismiss(position); } }); String item = getItem(position); holder.mFrontText.setText(item); return convertView; } class ViewHolder{ TextView mFrontText ; Button mBackEdit,mBackDelete ; } } 以上就是SwipeListViewTest的用法,希望对你有帮助

2016-05-23

BadgeView提示图标

2016-05-06

SwipeListView

SwipeListView

2016-05-06

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除