#Android自定义控件1

自定义控件blog的第一篇,学习的大部分内容是通过Android原生控件的组合,来实现一些开发时比较实用且比较常用的各种自定义控件。

##1、自定义控件之仿优酷菜单

定义三个相对布局,用来存放3级动画图片

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context="com.example.xwf.androiddiywidget.MainActivity">

android:id="@+id/rl_level3"

android:layout_width="360dp"

android:layout_height="180dp"

android:layout_alignParentBottom="true"

android:layout_centerHorizontal="true"

android:background="@drawable/level3">

android:id="@+id/rl_level2"

android:layout_width="200dp"

android:layout_height="100dp"

android:layout_alignParentBottom="true"

android:layout_centerHorizontal="true"

android:background="@drawable/level2">

android:id="@+id/btn_menu"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:src="@drawable/icon_menu"

android:background="@android:color/transparent"

android:layout_centerHorizontal="true"/>

android:id="@+id/rl_level1"

android:layout_width="100dp"

android:layout_height="50dp"

android:layout_alignParentBottom="true"

android:layout_centerHorizontal="true"

android:background="@drawable/level1">

android:id="@+id/btn_home"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:background="@android:color/transparent"

android:layout_centerInParent="true"

android:src="@drawable/icon_home"/>

写一个旋转动画的工具类,接受参数是RelativeLayout

/**

* Created by Hsia on 16/5/13.

* E-mail: xiaweifeng@live.cn

* //TODO:动画工具类

*/

public class AnimationUtils {

//定义动画执行过程

public static int runingAnimation = 0;

/**

* 退出动画

* @param rl

*/

public static void rotateOutAnimation(RelativeLayout rl,long offset){

RotateAnimation rotateAnimation = new RotateAnimation(0, -180, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 1f);

rotateAnimation.setDuration(1000);

rotateAnimation.setStartOffset(offset);

rotateAnimation.setFillAfter(true);

rotateAnimation.setAnimationListener(new MyAnimationListener());

rl.startAnimation(rotateAnimation);

}

/**

* 进入动画

* @param rl

*/

public static void rotateInAnimation(RelativeLayout rl,long offset){

RotateAnimation rotateAnimation = new RotateAnimation(-180, 0, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 1f);

rotateAnimation.setDuration(1000);

rotateAnimation.setStartOffset(offset);

rotateAnimation.setFillAfter(true);

rotateAnimation.setAnimationListener(new MyAnimationListener());

rl.startAnimation(rotateAnimation);

}

//设置一个动画监听

static class MyAnimationListener implements Animation.AnimationListener{

private static final String TAG = "Hsia";

@Override

public void onAnimationStart(Animation animation) {

runingAnimation++;

}

@Override

public void onAnimationEnd(Animation animation) {

runingAnimation--;

}

@Override

public void onAnimationRepeat(Animation animation) {

}

}

}

##2、viewpager简单学习

一个Viewpager的Demo,可无限左右切换页面,没3秒自动切换页面。

定义布局

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context="com.example.a02viewpagertest.MainActivity">

android:id="@+id/vp"

android:layout_width="match_parent"

android:layout_height="210dp">

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:orientation="vertical"

android:layout_alignBottom="@+id/vp"

android:background="#55000000">

android:id="@+id/tv_description"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:text="哈哈哈哈哈哈哈"

android:layout_marginTop="3dp"

android:layout_marginBottom="3dp"

android:gravity="center_horizontal"

android:textSize="20sp"/>

android:id="@+id/ll_point"

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:gravity="center_horizontal"

android:layout_marginBottom="5dp"

android:orientation="horizontal">

shape选择器

详细代码就3个部分(伪无限循环,自动循环定时器)

public class MainActivity extends AppCompatActivity {

private static final String TAG = "Hsia";

@Bind(R.id.vp)

ViewPager vp;

@Bind(R.id.tv_description)

TextView tvDescription;

@Bind(R.id.ll_point)

LinearLayout llPoint;

private List imageViewList;

private int beforePager = 0;

private String[] imageDescriptionArrays;

//viewpager伪无限循环

private int newPosition;

//当Activity界面不见时不自动切换

private boolean switchPager = true;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

ButterKnife.bind(this);

initVPData();

//设置viewpager数据

MyPagerAdapter pagerAdapter = new MyPagerAdapter();

vp.setAdapter(pagerAdapter);

vp.setOnPageChangeListener(new MyOnPageChangeListener());

final int current = Integer.MAX_VALUE / 2 - (Integer.MAX_VALUE / 2 % imageViewList.size());

vp.setCurrentItem(current);

//自动切换页面

autoSwitchPager();

}

/**

* 3、用一个定时器,定时没3秒切换页面

*/

private void autoSwitchPager() {

//用一个定时器

Timer timer = new Timer();

TimerTask timerTask = new TimerTask() {

@Override

public void run() {

runOnUiThread(new Runnable() {

@Override

public void run() {

if(switchPager){

vp.setCurrentItem(vp.getCurrentItem()+1);

}

}

});

}

};

timer.schedule(timerTask,3000,3000);

}

@Override

protected void onStart() {

super.onStart();

switchPager = true;

Log.d(TAG, "onStart: ");

}

@Override

protected void onStop() {

super.onStop();

switchPager = false;

Log.d(TAG, "onStop: ");

}

@Override

protected void onDestroy() {

switchPager = false;

super.onDestroy();

}

/**

* 1、初始化Viewpager数据

*/

private void initVPData() {

imageDescriptionArrays = new String[] {

"巩俐不低俗,我就不能低俗",

"朴树又回来啦!再唱经典老歌",

"揭秘北京电影如何升级",

"乐视网TV版大派送",

"热血屌丝的反杀"

};

int[] imageResIDs = new int[]{R.drawable.a,R.drawable.b,R.drawable.c,R.drawable.d,R.drawable.e};

//用于存放图片数据的集合

imageViewList = new ArrayList<>();

for (int i = 0; i < imageResIDs.length; i++) {

ImageView iv = new ImageView(getApplicationContext());

iv.setBackgroundResource(imageResIDs[i]);

imageViewList.add(iv);

//初始化点

View view = new View(getApplicationContext());

view.setBackgroundResource(R.drawable.dot_select);

LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(20, 20);

if (i > 0){

params.leftMargin = 20;

}

view.setEnabled(false);

view.setLayoutParams(params);

llPoint.addView(view);

}

//设置第一个点和文字描述

tvDescription.setText(imageDescriptionArrays[beforePager]);

llPoint.getChildAt(beforePager).setEnabled(true);

}

/**

* 2、定义viewpager数据适配器

*/

class MyPagerAdapter extends PagerAdapter{

@Override

public int getCount() {

return Integer.MAX_VALUE;

}

@Override

public boolean isViewFromObject(View view, Object object) {

return view == object;

}

@Override

public Object instantiateItem(ViewGroup container, int position) {

newPosition = position%imageViewList.size();

ImageView imageView = imageViewList.get(newPosition);

container.addView(imageView);

return imageView;

}

@Override

public void destroyItem(ViewGroup container, int position, Object object) {

container.removeView((View)object);

}

}

class MyOnPageChangeListener implements ViewPager.OnPageChangeListener{

@Override

public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

// Log.d(TAG, "onPageScrolled: ");

}

@Override

public void onPageSelected(int position) {

int newPosition = position % imageViewList.size();

Log.d(TAG, "onPageSelected: ");

llPoint.getChildAt(beforePager).setEnabled(false);

//把后一个页面赋值给前一个页面

beforePager = newPosition;

llPoint.getChildAt(newPosition).setEnabled(true);

tvDescription.setText(imageDescriptionArrays[newPosition]);

}

@Override

public void onPageScrollStateChanged(int state) {

}

}

}

##自定义下拉框(用PopupWindow实现)

涉及知识点

Popupwindow的简单使用

popupWindow = new PopupWindow(listView,mETContext.getWidth(),1200);

//点击popupwindow的外面 隐藏poupwindow

popupWindow.setOutsideTouchable(true);

popupWindow.setBackgroundDrawable(new BitmapDrawable());

popupWindow.showAsDropDown(mETContext);

popupwindow内listview的点击事件处理

在layout的节点下设置 android:descendantFocusability="blocksDescendants"这个属性

listview数据移除和刷新

//删除集合数据,并刷新listview数据设配器

list.remove(position);

myBaseAdapter.notifyDataSetChanged();

//如果集合中没有数据了,关闭popupwindow

if (list.size() == 0) {

popupWindow.dismiss();

}

自定义下拉框代码展示

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

private static final String TAG = "Hsia";

private ImageButton mIBtn;

private EditText mETContext;

private ListView listView;

private List list;

private TextView et_text;

private PopupWindow popupWindow;

private MyBaseAdapter myBaseAdapter;

private boolean isopen = true;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

init();

mIBtn.setOnClickListener(this);

}

/**

* 初始化数据

*/

private void init() {

mETContext = ((EditText) findViewById(R.id.et_context));

mIBtn = ((ImageButton) findViewById(R.id.ib_check));

}

/**

* 点击imagebutton 弹出PopupWindow

*

* @param v

*/

@Override

public void onClick(View v) {

if (isopen) {

Log.d(TAG, "onClick: ");

initListView();

popupWindow = new PopupWindow(listView, mETContext.getWidth(), 1200);

//点击popupwindow的外面 隐藏poupwindow

popupWindow.setOutsideTouchable(true);

popupWindow.setBackgroundDrawable(new BitmapDrawable());

popupWindow.showAsDropDown(mETContext);

isopen = false;

} else {

popupWindow.dismiss();

isopen = true;

}

}

/**

* 初始化listview数据

*/

private void initListView() {

listView = new ListView(getApplicationContext());

myBaseAdapter = new MyBaseAdapter();

initlvData();

listView.setAdapter(myBaseAdapter);

// listView.setBackgroundResource(R.drawable.listview_background); //指定listv的背景

// listView.setCacheColorHint(Color.BLACK);

listView.setOnItemClickListener(new AdapterView.OnItemClickListener() {

@Override

public void onItemClick(AdapterView> parent, View view, int position, long id) {

String context = list.get(position);

mETContext.setText(context);

popupWindow.dismiss();

}

});

}

private void initlvData() {

//把listview需要的数据放入到集合中

list = new ArrayList<>();

for (int i = 0; i < 20; i++) {

list.add("1000000" + i);

}

}

class MyBaseAdapter extends BaseAdapter {

@Override

public int getCount() {

return list.size();

}

@Override

public Object getItem(int position) {

return null;

}

@Override

public long getItemId(int position) {

return 0;

}

@Override

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

View view = null;

if (convertView == null) {

view = View.inflate(getApplicationContext(), R.layout.list_item, null);

} else {

view = convertView;

}

ImageButton imageButton = (ImageButton) view.findViewById(R.id.ibtn);

imageButton.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

//删除集合数据,并刷新listview数据设配器

list.remove(position);

myBaseAdapter.notifyDataSetChanged();

//如果集合中没有数据了,关闭popupwindow

if (list.size() == 0) {

popupWindow.dismiss();

}

}

});

et_text = (TextView) view.findViewById(R.id.et);

et_text.setText(list.get(position));

return view;

}

}

}

android 自定义控件github,GitHub - swordman20/AndroidDIYWidget: Android组合自定义控件相关推荐

  1. 【UI学习】Android github开源项目,酷炫自定义控件(View)汇总

    [UI学习]Android github开源项目,酷炫自定义控件(View)汇总 转载  2016年09月04日 23:23:15 3484 近期整理的比较酷炫并且我们会经常用到的custom vie ...

  2. github上的优秀android开源项目 大全 真是太他妈的全了!!!!!!

    酷炫不需要理由 http://blog.csdn.net/a774057695/article/details/49889437 https://github.com/XinRan5312/andro ...

  3. github上的优秀android开源项目

    酷炫不需要理由 Skip to content Pull requests Issues Gist 6,696 Trinea/android-open-project Code Issues4 Pul ...

  4. GitHub 优秀的 Android 开源项目 淘宝技术牛p博客整理开发中最常用的GitHub上 优秀的 Android 开源项目整理(精品)...

    原文地址为http://www.trinea.cn/android/android-open-source-projects-view/,作者Trinea 主要介绍那些不错个性化的View,包括Lis ...

  5. Android Studio导入github项目详解

    版权声明:本文为博主原创文章,转载请标明出处. https://blog.csdn.net/lyhhj/article/details/48789705 最近在群里发现总有人问一些关于Android ...

  6. 使用Android Studio向GitHub提交代码

    使用Android Studio向GitHub提交代码 在GitHub上创建一个仓库 填写仓库名称.描述.类型(公有.私有)等信息,点击创建 到此,成功创建了我们的仓库,并且初始化创建了README. ...

  7. [Android开源项目] GitHub开源项目总结 (转)

    [Android开源项目] GitHub开源项目总结 GitHub开源项目android-styled-dialogs http://neast.cn/forum.php?mod=viewthread ...

  8. git命令下载项目,上传android项目到github步骤,以及取消项目关联Git,设置git忽略文件

    设置忽略文件 1.工程下创建文件夹gitignore.push即可 *.iml .gradle /local.properties /.idea/caches /.idea/libraries /.i ...

  9. 2020 年 GitHub 上那些优秀 Android 开源库,这里是 Top10! | 原力计划

    作者 | 依然饭特稀西 责编 | 郭芮 出品 | CSDN博客 每过一段时间呀,我都会给大家带来一些从Github上收集的一些开源库,有的是炫酷动效,有的则是实用的工具和类库.2020年有哪些优秀的开 ...

  10. GitHub上不错的Android开源项目(二)

    摘要:GitHub上的开源项目不胜枚举,通过这些项目,也能让开发者在应用开发过程中事半功倍,作为开发者的你,在用这些开源项目吗?今天我们将介绍另外20个在GitHub上备受欢迎的Android开源项目 ...

最新文章

  1. 某程序员哀叹:二本计算机,4年开发,年包才40多万。二本真的不如985/211吗?
  2. UIColor的封装
  3. All men are brothers(并查集+思维 好题!!!)
  4. oracle自带的加密函数,oracle 的加密解密函数
  5. python实现离线翻译_10分钟教你用Python实现微信翻译机器人
  6. 安全扫描失败无法上传_Apache Solr 未授权上传(RCE)漏洞的原理分析与验证
  7. api es7 删除所有数据_男子让月薪6万的人技术入股,结果工作3月蒙了:删除所有数据入职其他公司...
  8. jquery 检测div宽度变化_jquery判断浏览器宽度小于指定值改变div样式
  9. 人工智能在塑造未来移动应用开发中的作用
  10. java native2ascii的用法介绍
  11. android文档在线批注,文档批注
  12. 利用python通过字幕文件.srt来实现对视频片段的截取
  13. [RK3288][Android6.0] 调试笔记 --- Audio的Voice Call无法静音问题
  14. 迅捷fw310uh驱动下载_迅捷FW150UH驱动程序官方版
  15. 2022-2028年中国航空货运产业发展动态及竞争战略分析报告
  16. 人脸识别60年:欧盟通用数据保护条例真的算“史上最严”吗
  17. 浅谈css3的3D动画效果并制作一个简单的旋转照片墙
  18. TSINGSEE青犀视频监控技术在城市轨道交通中的应用
  19. 10种常见的回归算法总结和介绍
  20. webots仿真机器人平台

热门文章

  1. 如何进行app消息推送(push)
  2. TCP协议之《ACK pingpong交互模式详解》
  3. redisTemplate ping pong
  4. 2021.04.07 126邮箱自动登陆
  5. 罗马数字转换python_Python将阿拉伯数字转换为罗马数字的方法
  6. 在Total Commander下使用sftp操作服务器
  7. Latex的常见错误
  8. 关于Toast的一些常见操作
  9. 邮箱收不到验证邮件怎么回事?为什么我的电子邮件收不到验证码的原因,无限容量邮箱开通
  10. C语言 打地鼠游戏 超级详解,各个函数与算法,设计思路与流程