本文实例讲述了Android编程常用技巧。分享给大家供大家参考,具体如下:
1. 登录的时候,如果输入有误,则输入框左右震动,表示输入有误
在res下准备一个anim文件夹,里面包含两个文件,main_login_shake.xml 和 main_login_cycle_7.xml,
其中,main_login_shake.xml如下:
<?xml version="1.0" encoding="utf-8"?> <translate xmlns:android="http://schemas.android.com/apk/res/android" android:fromXDelta="0" android:toXDelta="10" android:duration="1000" android:interpolator="@anim/main_login_cycle_7" />
上面文件中引用了main_login_cycle_7.xml,代码如下:
<?xml version="1.0" encoding="utf-8"?> <cycleInterpolator xmlns:android="http://schemas.android.com/apk/res/android" android:cycles="7" />
这两段代码的意思就是在1秒钟之类,x坐标从0到10晃动7次
看java代码:
shakeanim = AnimationUtils.loadAnimation(this,R.anim.main_login_shake); btn_login.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { boolean ready = true; String username=et_username.getText().toString(); String password=et_password.getText().toString(); if (!username.matches("^\\w{1,}+$")) { ready = false; et_username.startAnimation(shakeanim); } if (!password.matches("^\\w{1,}+$")) { ready = false; et_password.startAnimation(shakeanim); } if(selectClinic==null){ ready = false; et_clinic.startAnimation(shakeanim); } if (ready) { loginStart(username,password,Long.parseLong(selectClinic.get("id").toString()),Integer.parseInt(selectClinic.get("type_id").toString())); } } });
2. 当一个Activity中很多地方需要使用到对话框,可以如下操作:
showDialog(R.id.wait_edit_arriveltime); showDialog(R.id.wait_edit_yuyuedata); showDialog(R.id.wait_edit_close); ...... protected Dialog onCreateDialog(int id) { Dialog dialog = null; switch (id) { case R.id.wait_edit_yuyuedata: DatePickerDialog.OnDateSetListener dateListener = new DatePickerDialog.OnDateSetListener() { @Override public void onDateSet(DatePicker datePicker,int year, int month, int dayOfMonth) { wait_edit_yuyuedata.setText(dayOfMonth + "/"+(month+1)+"/"+year); } }; dialog = new DatePickerDialog(this, dateListener, Integer.parseInt(app.getAppointedDate().split("/")[2]), Integer.parseInt(app.getAppointedDate().split("/")[1]), Integer.parseInt(app.getAppointedDate().split("/")[0])); break; case R.id.wait_edit_arriveltime: TimePickerDialog.OnTimeSetListener timeListener = new TimePickerDialog.OnTimeSetListener() { @Override public void onTimeSet(TimePicker view, int hourOfDay, int minute) { wait_edit_arriveltime.setText(hourOfDay+":"+minute); } }; dialog = new TimePickerDialog(this, timeListener, Integer.parseInt(app.getEstimateArriveTime().split(":")[0]), Integer.parseInt(app.getEstimateArriveTime().split(":")[1]), true); break; case R.id.wait_edit_close: AlertDialog.Builder builder = new AlertDialog.Builder(EditWaitActivity.this); builder.setTitle("您要确定放弃编辑吗?"); builder.setPositiveButton("确定",new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface arg0, int arg1) { EditWaitActivity.this.finish(); }}); builder.setNegativeButton("取消",new DialogInterface.OnClickListener() { public void onClick(DialogInterface dialog,int whichButton) { } }); builder.show(); break; default: break; } return dialog; }
3. 标准的adapter的格式,以后就按照这样的形式写
public class MyAdapter extends BaseAdapter{ Context context; PageRecord<Appointment> data; private ViewHolder tempHolder; private View tempView; public MyAdapter(Context context,PageRecord<Appointment> data){ this.context = context; this.data = data; } public View getView(int position, View convertView, ViewGroup parent) { final ViewHolder holder; Appointment app = data.getResultSet().get(position); if(convertView==null){ convertView=LayoutInflater.from(context).inflate(R.layout.item, null); holder=new ViewHolder(convertView); convertView.setTag(holder); }else{ holder=(ViewHolder) convertView.getTag(); } tempHolder = holder; tempView = convertView; holder.setData(app); return convertView; } public long getItemId(int position) { return position; } public Object getItem(int position) { return data.getResultSet().get(position); } public int getCount() { return data.getResultSet()==null?0:data.getResultSet().size(); } public void setData(PageRecord<Appointment> data){ this.data = data; this.notifyDataSetChanged(); tempView.invalidate(); } /** * 重新绘制 * @param app */ public void redraw(Appointment app){ tempHolder.timeView.setText(app.getAppointedDate()+" "+app.getEstimateArriveTime()); tempHolder.nameView.setText(app.getPatient().getNameEN()); tempHolder.doctorView.setText(app.getMo().getNameEN()); tempView.invalidate(); } private class ViewHolder{ private TextView timeView; private TextView nameView; private TextView doctorView; public ViewHolder(View convertView){ timeView = (TextView) convertView.findViewById(R.id.yuyuetime); nameView = (TextView) convertView.findViewById(R.id.yuyuename); doctorView = (TextView) convertView.findViewById(R.id.doctorname); } public void setData(Appointment app){ timeView.setText(app.getAppointedDate()+" "+app.getEstimateArriveTime()); nameView.setText(app.getPatient().getNameEN()); doctorView.setText(app.getMo().getNameEN()); } } }
4. 获取屏幕分辨率的两种方法
// 方法1 Android获得屏幕的宽和高 WindowManager windowManager = getWindowManager(); Display display = windowManager.getDefaultDisplay(); int screenWidth = display.getWidth(); int screenHeight = display.getHeight(); // 方法2 DisplayMetrics dm = new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMetrics(dm); float width=dm.widthPixels*dm.density; float height=dm.heightPixels*dm.density;
打印结果:width:320.0,height:480.0,screenWidth:320,screenHeight:480
dpi值的是屏幕上每英寸的像素点。如果一个160dpi的屏幕,1dp=1px。假如我现在有一个480*800,160dp的屏,那么他的实际面积要比480*800,240dp的屏面积大,但是清晰度却不如后面这个屏。
如果有些实体手机在做测试的时候发现得到的分辨率比实际的分辨率小很多,那么这里得到的是dp单位的像素值,可以通过dp的密度值来转换,如下:
480*800的手机(WVGA)density=240。
转换公式如下:
pixs =dips * (density/160) dips=(pixs*160)/density
480*800单位是px。而320*533单位是dp
5,资源的一些应用
* 不同的layout
Android手机屏幕大小不一,有480x320,640x360,800x480.怎样才能让App自动适应不同的屏幕呢? 其实很简单,只需要在res目录下创建不同的layout文件夹,比如:layout-640x360,layout-800x480,所有的layout文件在编译之后都会写入R.java里,而系统会根据屏幕的大小自己选择合适的layout进行使用。
* hdpi、mdpi、ldpi
前的版本中,只有一个drawable,而2.1版本中有drawable-mdpi、drawable-ldpi、drawable-hdpi三个,这三个主要是为了支持多分辨率。
* drawable- hdpi、drawable- mdpi、drawable-ldpi的区别:
drawable-hdpi里面存放高分辨率的图片,如WVGA (480x800),FWVGA (480x854)
drawable-mdpi里面存放中等分辨率的图片,如HVGA (320x480)
drawable-ldpi里面存放低分辨率的图片,如QVGA (240x320)
系统会根据机器的分辨率来分别到这几个文件夹里面去找对应的图片。在开发程序时为了兼容不同平台不同屏幕,建议各自文件夹根据需求均存放不同版本图片。
* 屏幕方向
横屏竖屏自动切换
可以在res目录下建立layout-port和layout-land两个目录,里面分别放置竖屏和横屏两种布局文件,这样在手机屏幕方向变化的时候系统会自动调用相应的布局文件,避免一种布局文件无法满足两种屏幕显示的问题。
* 禁用自动切换
只需要在AndroidManifest.xml文件中加入android:screenOrientation属性限制。
Android:screenOrientation="landscape" //是限制此页面横屏显示
Android:screenOrientation="portrait" //是限制此页面数竖屏显示
* 字体自适应大小
方法1:
首先根据不同分辨率获取不同字体大小。
在RES里创建
values-480x320/strings.xml 里面设置<dimen name="Text_size">30px</dimen>
和
values-800x400/strings.xml 里面设置<dimen name="Text_size">40px</dimen>
分别代表480X320 和 800X400分辨率情况下 字号为30px和40px;
在java文件中这样调用
int sizeOfText = (int) this.getResources().getDimension(R.dimen.Text_size);
在视图的 onsizechanged里获取视图宽度,一般情况下默认宽度是320,所以计算一个缩放比率rate = (float) w/320 w是实际宽度
然后在设置字体尺寸时 paint.setTextSize((int)(8*rate)); 8是在分辨率宽为320 下需要设置的字体大小实际字体大小 = 默认字体大小 x rate
希望本文所述对大家Android程序设计有所帮助。
本文向大家介绍Android ListView常用小技巧汇总,包括了Android ListView常用小技巧汇总的使用技巧和注意事项,需要的朋友参考一下 ListView在我们Android项目中的地位是有目共睹的,相信几乎每一个App中都有它的身影。 ListView主要是用列表形式来加载数据,在特定情况下需要实现一些特殊功能:如刷新数据,加载数据,实现动画效果等。 作为我们常用的控件,有哪些
本文向大家介绍总结Python编程中三条常用的技巧,包括了总结Python编程中三条常用的技巧的使用技巧和注意事项,需要的朋友参考一下 在 python 代码中可以看到一些常见的 trick,在这里做一个简单的小结。 json 字符串格式化 在开发 web 应用的时候经常会用到 json 字符串,但是一段比较长的 json 字符串是可读性较差的,不容易看出来里面结构的。 这时候就可以用 pytho
本文向大家介绍Android编程之OpenGL绘图技巧总结,包括了Android编程之OpenGL绘图技巧总结的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android编程之OpenGL绘图技巧。分享给大家供大家参考,具体如下: 很久不用OpenGL ES绘图,怕自己忘记了,于是重新复习一遍,顺便原理性的东西总结如下: 1. Android 3D坐标系统 如图: Android的三维坐
本文向大家介绍Docker 实用技巧总结,包括了Docker 实用技巧总结的使用技巧和注意事项,需要的朋友参考一下 我有机会建立一个以Docker为基础的微服务架构在我现在的工作中,很多人都会分享他们使用Docker的心得,我想我也不会例外。因此我总结了一些,可能你会在日常使用Docker的时候会用到。 1. 一台主机部署多个Docker实例 如果你想运行多个Docker 容器在一台主机上,如果要
本文向大家介绍c++编程学习的技巧总结,包括了c++编程学习的技巧总结的使用技巧和注意事项,需要的朋友参考一下 1、把C++当成一门新的语言学习(和C没啥关系)。 2、看《Thinking In C++》,不要看《C++编程思想》。 3、看《The C++ Programming Language》和《Inside The C++ Object Model》,不要因为他们很难而我们自己是初学者所以
本文向大家介绍Android编程开发之性能优化技巧总结,包括了Android编程开发之性能优化技巧总结的使用技巧和注意事项,需要的朋友参考一下 本文详细总结了Android编程开发之性能优化技巧。分享给大家供大家参考,具体如下: 1.http用gzip压缩,设置连接超时时间和响应超时时间 http请求按照业务需求,分为是否可以缓存和不可缓存,那么在无网络的环境中,仍然通过缓存的httprespon