当前位置:首页 » 安卓系统 » androidimageview边框

androidimageview边框

发布时间: 2025-08-12 05:51:48

① Android开发权威指南的图书目录

第一部分准备篇
第1章初识庐山真面目——Android开发简介2
1.1Android的基本概念2
1.1.1Android简介2
1.1.2Android的版本4
1.1.3Android的系统构架5
1.1.4Android的应用程序框架6
1.2JIL Widget介绍7
1.3小结8
第2章工欲善其事,必先利其器——搭建和使用Android开发环境9
2.1开发包及工具的安装9
2.1.1开发Android程序都需要些什么9
2.1.2安装JDK和配置java开发环境10
2.1.3Eclipse的安装与汉化11
2.1.4安装AndroidSDK12
2.1.5安装Eclipse插件ADT13
2.2真实体验——编写第一个Android程序(随机绘制圆饼)15
2.2.1创建Android工程15
2.2.2在模拟器中运行Android程序17
2.2.3界面控件的布局19
2.2.4编写代码20
2.2.5调试程序23
2.2.6在手机上运行和调试程序28
2.3迁移Android工程可能发生的错误29
2.4不需要写一行代码的开发工具:AppInventor31
2.4.1AppInventor简介31
2.4.2AppIntentor的下载和安装31
2.4.3用拖曳控件的方式设计界面33
2.4.4像拼图一样拼装代码34
2.5小结37
第二部分基础篇
第3章千里之行始于足下——Android程序设计基础40
3.1Android应用程序框架40
3.1.1Android项目的目录结构40
3.1.2AndroidManifest.xml文件的结构42
3.2Android应用程序中的资源44
3.3Android的应用程序组件44
3.3.1Activity(Android的窗体)45
3.3.2Service(服务)45
3.3.3Broadcast Receiver(广播接收器)45
3.3.4Content Provider(内容提供者)46
3.4Android程序的UI设计46
3.4.1手工配置XML布局文件46
3.4.2ADT自带的可视化UI设计器47
3.4.3使用DroidDraw设计UI布局47
3.5小结48
第4章我的UI我做主——用户界面开发基础49
4.1Activity的使用方法49
4.1.1创建Activity49
4.1.2配置Activity50
4.1.3显示其他的Activity(Intent与Activity)52
4.2Activity的生命周期55
4.3在不同Activity之间传递数据60
4.3.1使用Intent传递数据60
4.3.2使用静态变量传递数据62
4.3.3使用剪切板传递数据63
4.3.4使用全局对象传递数据65
4.3.5返回数据到前一个Activity67
4.4视图(View)68
4.4.1视图简介68
4.4.2使用XML布局文件定义视图69
4.4.3在代码中控制视图70
4.5布局(Layout)72
4.5.1框架布局(FrameLayout)72
4.5.2线性布局(LinearLayout)75
4.5.3相对布局(RelativeLayout)79
4.5.4表格布局(TableLayout)81
4.5.5绝对布局(AbsoluteLayout)82
4.5.6重用XML布局文件82
4.5.7优化XML布局文件85
4.5.8查看apk文件中的布局86
4.6小结87
第5章良好的学习开端——控件(Widget)详解88
5.1常用XML属性解析88
5.1.1android:id属性88
5.1.2控件的宽度(android:layout_width)和高度(android:layout_height)88
5.1.3android:layout_margin属性89
5.1.4android:padding属性89
5.1.5android:layout_weight属性90
5.1.6android:layout_gravity和android:gravity属性90
5.1.7android:visibility属性91
5.1.8android:background属性91
5.1.9指定单击事件方法(android:onClick属性)92
5.1.10控件焦点属性(android:focusable和android:focusable-InTouchMode)92
5.2TextView(显示文本的控件)93
5.2.1显示富文本(URL、不同大小、字体、颜色的文本)93
5.2.2在TextView中显示表情图像和文字97
5.2.3单击链接弹出Activity100
5.2.4为指定文本添加背景103
5.2.5带边框的TextView106
5.2.6设置行间距110
5.2.7在未显示完的文本后面加省略号(…)111
5.2.8用TextView实现走马灯效果113
5.2.9垂直滚动TextView中的文本114
5.3EditText(编辑文本的控件)115
5.3.1像QQ一样输入表情图像115
5.3.2在EditText中输入特定的字符117
5.3.3AutoCompleteText-View(自动完成输入内容的控件)118
5.4按钮和复选框控件120
5.4.1Button(普通按钮控件)120
5.4.2图文混排的按钮122
5.4.3ImageButton(图像按钮控件)124
5.4.4RadioButton(选项按钮控件)124
5.4.5ToggleButton(开关状态按钮控件)125
5.4.6CheckBox(复选框控件)126
5.5ImageView(显示图像的控件)128
5.5.1ImageView控件的基本用法128
5.5.2显示指定区域的图像129
5.5.3缩放和旋转图像132
5.6时间与日期控件133
5.6.1DatePicker(输入日期的控件)133
5.6.2TimePicker(输入时间的控件)134
5.6.3DatePicker、TimePicker与TextView同步显示日期和时间134
5.6.4AnalogClock和DigitalClock(显示时钟的控件)136
5.7进度条控件137
5.7.1ProgressBar(进度条控件)137
5.7.2SeekBar(拖动条控件)139
5.7.3设置ProgressBar和SeekBar的颜色及背景图140
5.7.4RatingBar(评分控件)143
5.8列表控件145
5.8.1ListView(普通列表控件)145
5.8.2为ListView列表项添加复选框和选项按钮147
5.8.3对列表项进行增、删、改操作149
5.8.4改变列表项的背景色153
5.8.5ListActivity(封装ListView的Activity)154
5.8.6ExpandableListView(可扩展的列表控件)155
5.8.7Spinner(下拉列表控件)157
5.9滚动控件160
5.9.1ScrollView(垂直滚动控件)160
5.9.2HorizontalScrollView(水平滚动控件)161
5.9.3可垂直和水平滚动的视图162
5.9.4Gallery(画廊控件)163
5.10ImageSwitcher(图像切换控件)164
5.11GridView(网格控件)166
5.12TabHost(标签控件)168
5.13ViewStub(惰性装载控件)169
5.14小结171
第6章友好的菜单——Menu介绍与实例172
6.1菜单的基本用法172
6.1.1创建选项菜单(Options Menu)172
6.1.2带图像的选项菜单173
6.1.3关联Activity173
6.1.4响应菜单的单击动作174
6.1.5动态添加、修改和删除选项菜单175
6.1.6带复选框和选项按钮的子菜单176
6.1.7上下文菜单178
6.1.8菜单事件179
6.1.9从菜单资源中装载菜单180
6.2菜单特效181
6.2.1自定义菜单181
6.2.2模拟UCWeb效果菜单184
6.2.3QuickContactBadge与联系人菜单189
6.3小结192
第7章友好地互动交流——信息提醒(对话框、Toast与Notification)193
7.1对话框的基本用法193
7.1.1带2个按钮(确认/取消)的对话框193
7.1.2带3个按钮(覆盖/忽略/取消)的对话框195
7.1.3简单列表对话框196
7.1.4单选列表对话框198
7.1.5多选列表对话框199
7.1.6进度对话框201
7.1.7登录对话框205
7.1.8使用Activity托管对话框207
7.2对话框的高级应用209
7.2.1阻止单击按钮关闭对话框209
7.2.2改变对话框的显示位置213
7.2.3在对话框按钮和内容文本中插入图像215
7.2.4改变对话框的透明度216
7.3Toast217
7.3.1Toast的基本用法217
7.3.2永不关闭的Toast218
7.3.3用PopupWindow模拟Toast提示信息框221
7.4通知(Notification)221
7.4.1在状态栏上显示通知信息222
7.4.2Notification的清除动作224
7.4.3永久存在的Notification225
7.4.4自定义Notification226
7.5小结227
第8章移动的信息仓库——数据存储228
8.1读写key-value对:SharedPreferences228
8.1.1SharedPreferences的基本用法228
8.1.2数据的存储位置和格式229
8.1.3存取复杂类型的数据230
8.1.4设置数据文件的访问权限233
8.1.5可以保存设置的Activity:PreferenceActivity234
8.2文件存储238
8.2.1openFileOutput和openFileInput方法238
8.2.2读写SD卡中的文件239
8.2.3SAX引擎读取XML文件的原理241
8.2.4将XML文件转换成Java对象242
8.2.5文件压缩(Jar、Zip)245
8.3SQLite数据库249
8.3.1SQLite数据库管理工具249
8.3.2SQLiteOpenHelper类与自动升级数据库251
8.3.3数据绑定与SimpleCursorAdapter类252
8.3.4操作SD卡上的数据库255
8.3.5将数据库与应用程序一起发布256
8.3.6内存数据库257
8.4小结258
第9章Android中的窗口——Activity259
9.1调用其他程序中的Activity259
9.1.1直接拨号259
9.1.2将电话号传入拨号程序259
9.1.3调用拨号程序260
9.1.4浏览网页261
9.1.5向E-mail客户端传递E-mail地址261
9.1.6发送E-mail261
9.1.7查看联系人262
9.1.8显示系统设置界面(设置主界面、Wifi设置界面)263
9.1.9启动处理音频的程序264
9.2自定义Activity Action264
9.3Activity的高级应用266
9.3.1ActivityGroup266
9.3.2自定义半透明窗口268
9.3.3Activity之间切换的动画效果269
9.4小结270
第10章全局事件——广播(Broadcast)271
10.1什么是广播271
10.2接收系统广播272
10.2.1短信拦截272
10.2.2用代码注册广播接收器274
10.2.3广播接收器的优先级275
10.2.4来去电拦截276
10.2.5截获屏幕休眠与唤醒280
10.2.6开机自动运行281
10.2.7显示手机电池的当前电量282
10.3发送广播284
10.4验证广播接收器是否注册285
10.5小结286
第11章跨应用数据源——Content Provider287
11.1Content Provider的作用287
11.2获得系统数据288
11.2.1读取联系人信息288
11.2.2查看收到的短信290
11.3自定义Content Provider291
11.3.1查询城市信息291
11.3.2为Content Provider添加访问权限297
11.4小结298
第12章一切为用户服务——Service基础与实例299
12.1Service基础299
12.1.1Service的生命周期299
12.1.2绑定Activity和Service302
12.1.3开机启动Service305
12.1.4判断Service是否已注册306
12.1.5判断Service是否已开始307
12.2跨进程访问(AIDL服务)308
12.2.1什么是AIDL服务308
12.2.2建立AIDL服务的步骤308
12.2.3建立AIDL服务308
12.2.4传递复杂数据的AIDL服务312
12.2.5AIDL与来去电自动挂断317
12.3小结319
第13章做好应用桥梁——网络与通信320
13.1WebView控件320
13.1.1用WebView控件浏览网页320
13.1.2用WebView控件装载HTML代码322
13.2访问HTTP资源324
13.2.1提交HTTP GET和HTTP POST请求324
13.2.2HttpURLConnection类326
13.2.3上传文件327
13.3客户端Socket330
13.3.1连接服务器331
13.3.2扫描服务器打开的端口331
13.3.3发送和接收数据333
13.3.4获得无线路由分配给手机的IP地址334
13.3.5设置Socket选项335
13.4服务端Socket339
13.4.1手机服务器的实现339
13.4.2利用Socket在应用程序之间通信340
13.5蓝牙通信342
13.5.1蓝牙简介342
13.5.2打开和关闭蓝牙设备343
13.5.3搜索蓝牙设备344
13.5.4蓝牙数据传输346
13.6小结351
第14章炫酷你的应用——多媒体开发352
14.1音乐352
14.1.1播放音乐352
14.1.2录音353
14.2视频354
14.2.1使用VideoView播放视频354
14.2.2使用SurfaceView播放视频355
14.2.3录制视频357
14.3相机357
14.3.1调用系统的拍照功能358
14.3.2自定义拍照功能359
14.4铃声364
14.5小结366
第15章2D游戏开发367
15.1绘制游戏的画布367
15.1.1在View上实现动画效果367
15.1.2在SurfaceView上实现动画效果371
15.2图形绘制基础374
15.2.1绘制像素点374
15.2.2绘制直线374
15.2.3绘制圆形375
15.2.4绘制弧375
15.2.5绘制文本376
15.2.6综合绘制各种图形376
15.3高级图像处理技术380
15.3.1绘制位图380
15.3.2图像的透明度382
15.3.3旋转图像383
15.3.4路径384
15.3.5Shader的渲染效果388
15.4帧(Frame)动画392
15.4.1AnimationDrawable与帧动画392
15.4.2播放Gif动画394
15.5补间(Tween)动画397
15.5.1移动补间动画397
15.5.2缩放补间动画399
15.5.3旋转补间动画402
15.5.4透明度补间动画403
15.6小结404
第16章有趣的Android应用405
16.1传感器405
16.1.1如何使用传感器405
16.1.2加速度传感器(Accelerometer)409
16.1.3重力传感器(Gravity)409
16.1.4光线传感器(Light)410
16.1.5陀螺仪传感器(Gyroscope)411
16.1.6方向传感器(Orientation)411
16.1.7其他传感器412
16.2输入输出技术413
16.2.1语音识别413
16.2.2手势输入415
16.2.3语音朗读(TTS)417
16.3Google地图419
16.4GPS定位423
16.5桌面上的小东西425
16.5.1窗口小部件(AppWidget)425
16.5.2快捷方式431
16.5.3实时文件夹433
16.6应用更华丽——动态壁纸435
16.7小结441
第三部分高级篇
第17章HTML5与移动Web开发444
17.1HTML5简介444
17.2HTML5精彩效果演示445
17.3HTML5在Android中的应用447
17.4HTML5的画布(Canvas)448
17.4.1Canvas概述448
17.4.2检测浏览器是否支持Canvas449
17.4.3在Web页面中使用Canvas450
17.4.4使用路径(Path)452
17.4.5设置线条风格453
17.4.6设置填充类型453
17.4.7填充矩形区域454
17.4.8使用渐变色(Gradient)454
17.4.9拉伸画布对象455
17.4.10在Canvas上绘制文本456
17.4.11使用阴影457
17.5调试JavaScript458
17.6小结459
第18章输入法开发460
18.1Android输入法简介460
18.2控制输入法461
18.3输入法实战462
18.3.1实现输入法的步骤463
18.3.2编写输入法程序463
18.3.3输入法服务的生命周期466
18.3.4预输入文本467
18.3.5输入法设置467
18.4小结468
第19章Android OpenGL ES开发基础469
19.1OpenGL简介469
19.2什么是OpenGL ES469
19.3多边形470
19.4颜色474
19.5旋转三角形475
19.6旋转立方体477
19.7小结478
第20章OpenGL ES的超酷效果479
20.1保持平衡的旋转文本479
20.2左右摇摆的Android机器人482
20.3纠缠在一起的旋转立方体485
20.4透明背景的旋转立方体486
20.5触摸旋转的立方体487
20.62D和3D的综合旋转效果489
20.7旋转立体天空491
20.8小结493
第21章Android NDK编程494
21.1Android NDK简介494
21.2安装、配置和测试NDK开发环境495
21.2.1系统和软件要求495
21.2.2下载和安装Android NDK495
21.2.3下载和安装Cygwin495
21.2.4配置Android NDK的开发环境498
21.3第一个NDK程序:世界你好499
21.3.1编写和调用NDK程序499
21.3.2用命令行方式编译NDK程序501
21.3.3在Eclipse中集成Android NDK502
21.4背景不断变化的三角形(NDK 版OpenGL ES)504
21.5使用NDK OpenGL ES API实现千变万化的3D效果507
21.6使用NDK调用音频API510
21.7本地Activity(Native Activity)511
21.8Android NDK配置文件详解513
21.8.1Android NDK定义的变量513
21.8.2Android NDK定义的函数514
21.8.3描述模块的变量515
21.8.4配置Application mk文件516
21.9小结516
第22章测试驱动开发(TDD)517
22.1JUnit测试框架517
22.2测试Activity517
22.3测试Content Provider521
22.4测试Service523
22.5测试普通类523
22.6小结525
第四部分综合实例篇
第23章Android综合案例一——蓝牙聊天528
23.1蓝牙聊天主界面528
23.2添加选项菜单530
23.3搜索和连接蓝牙设备530
23.4使设备可被其他蓝牙设备发现533
23.5发送和接收聊天信息533
23.6小结537
第24章Android综合案例二——月球登陆(游戏)538
24.1游戏的玩法538
24.2实现游戏界面539
24.3设置游戏难度540
24.4开始游戏541
24.5控制飞船喷火544
24.6控制飞船改变飞行方向544
24.7判断飞船是否成功着陆545
24.8小结546
第25章Android综合案例三——全键盘输入法(应用)547
25.1安装输入法547
25.2输入法的初始化工作548
25.3响应键盘操作549
25.4根据EditText控件的属性显示不同的软键盘551
25.5小结553
第26章Android综合案例四——贪吃蛇(游戏)554
26.1游戏玩法554
26.2游戏主界面设计555
26.3控制小蛇的移动557
26.4小结560
第27章Android综合案例五——新浪微博客户端(应用)561
27.1新浪微博简介561
27.1.1新浪微博客户端561
27.1.2新浪微博开放API563
27.2使用新浪微博开发API563
27.3创建和配置新浪微博客户端工程564
27.4登录新浪微博564
27.5功能按钮567
27.6显示“我的首页”的微博569
27.7评论微博572
27.8转发微博573
27.9写微博574
27.10小结576
第28章Android综合案例六——笑脸连连看(游戏)577
28.1游戏玩法577
28.2准备图像素材578
28.3实现主界面578
28.4随机生成连连看图像580
28.5选中两个相同图像后消失580
28.6用定时器限制游戏时间581
28.7小结582

② android中GridView的显示图片边框

用ImageView里面,如果是在xml里面就设置一个android:padding="4dip"这样就可以了,如果是在java里面,那就设置一下ImageView.setPadding(4,4,4,4);这样就可以了,我也纠结了好久,其实是自己对这个东西不太熟悉

③ Android 圆角、圆形 ImageView 实现

我们要实现的图片控件继承自 AppCompatImageView ,它是 ImageView 的子类,但提供了更好的兼容性,我们在此基础上添加了若干自定义的属性和方法以实现最终的 NiceImageView :

要实圆角或者圆形的显示效果,就是对图片显示的内容区域进行“裁剪”,只显示指定的区域即可。如何做呢?

一种比较直接的办法是这样的,由于图片是被绘制在画布上的,所以用 canvas 的 clipPath() 方法先将画布裁剪成指定形状,这样就能让图片按指定形状显示了,重新 draw() 方法即可:

这样使用 src 、 background 属性给ImageView设置显示的图片都能达到预期的显示效果。但是由于 clipPath() 方法不支持抗锯齿,图片边缘会有明显的毛糙感,体验并不理想,所以需要寻找其它方法。

另一种方法是使用图像的 Alpha 合成模式 ,即
PorterDuff 来实现, 官方文档 。这里我们使用其中的 DST_IN 模式。整个过程就是先绘制目标图像,也就是图片;再绘制原图像,即一个圆角矩形或者圆形,这样最终目标图像只显示和原图像重合的区域。

到这里就实现了显示为圆角或者圆形了。但是需要通过 src 属性或者对应的方法来设置图片,否则不能达到预期效果。

绘制边框就相对容易理解了,只需要绘制一个指定样式的圆角矩形或者圆形即可:

当图片显示为圆形时,还可以绘制一个内边框,但圆角矩形的话由于圆角大小的问题,目前只能设置一个边框咯。

但是有个问题,绘制的边框会覆盖在图片上,如果边框太宽会导致图片的可见区域变小了,影像显示效果,像这样,左下角的花盆不见了:

那么如何让边框不覆盖在图片上呢?可以在 Alpha 合成绘制前先将画布缩小一定比例,最后再绘制边框,这样问题就解决了。

缩放后的ImageView显示区域的宽高就是原宽、高分别减去2倍的边框宽度,这样缩小的比例也就显而易见了。效果如下,左下角的花盆出来了:

遮罩可以理解为一层带透明度的颜色,遮罩默认不绘制,当制定了遮罩颜色时才会绘制,实现很简单:

例如加一个透明度30%的红色遮罩后的效果:

核心的实现逻辑就这些了,剩下的就是自定义属性和方法了,有兴趣的可以看源码,都很简单,希望对你有所帮助吧!

更多细节及用法见GitHub: https://github.com/SheHuan/NiceImageView

如果你需要实现类似钉钉的圆形组合头像,例如:

④ android LinearLayout 里面的东西怎么换行

由于前段时间项目中使用到了自动换行的线性布局,本来打算用表格布局在里面一个个的用Java代码添加ImageView的,但是添加的View控件是不确定的,因为得靠服务器的数据返回,就这样手动用Java代码画布局的方式就这样夭折了,因为在表哥布局中我无法确定一行显示多少个ImageView的数目,所以无法动态添加,最后自能自己去看看那种能够换行的线性布局了,线性布局比较不好的是不能自动换行,也就是当设置LinearLayout的orentation 设置为vertical 为竖直方向也就是只有一列,每行只能显示一个View或者View的子类,当设置LinearLayout的orentitation为Horizontal,LinearLayout的只能显示为一行,横向显示,当屏幕满了的时候,View控件并不会自动换行,所以我们要做的就是在LinearLayout满的时候自动换行。x0dx0a需要了解的是怎么样绘制根据子控件的长宽绘制父控件的宽度与高度,所以需要传入的参数控件的高度,视图分为两种一种是View类型的,代表控件有TextView,Button,EditText 等等,还有一种是装视图的容器控件继承自ViewGroup的控件,如LinearLayout,RelativeLayout,TabHost等等控件,需要自动换行的线性布局的话,就需要根据子控件的高度与宽度,来动态加载父控件的高度与宽度,所以需要在构造函数中传入每一个子控件的固定的高度,或者是动态设置子控件的高度与宽度。x0dx0a将自定义的LinearLayout 也继承自ViewGroup 并且重写抽象类ViewGrouop的几个方法:onMeasure(),onLayout(),dispathDraw() 三个方法的意思分别是:第一个onMeasure()是用来计算控件以及子控件所占用的区域,第二个onLayout()是控制子控件的换行,第三个可写可不写,主要是用来绘制控件的边框,x0dx0a自定义LinearLayout的代码如下:x0dx0ax0dx0a[java] view plainprint?x0dx0apackage com.huanglong.mylinearlayout; x0dx0a x0dx0aimport android.content.Context; x0dx0aimport android.graphics.Canvas; x0dx0aimport android.graphics.Color; x0dx0aimport android.graphics.Paint; x0dx0aimport android.graphics.Rect; x0dx0aimport android.util.AttributeSet; x0dx0aimport android.view.View; x0dx0aimport android.view.ViewGroup; x0dx0a x0dx0a/** x0dx0a * @author huanglong 2013-5-28 自定义自动换行LinearLayout x0dx0a */ x0dx0apublic class FixGridLayout extends ViewGroup { x0dx0a private int mCellWidth; x0dx0a private int mCellHeight; x0dx0a x0dx0a public FixGridLayout(Context context) { x0dx0a super(context); x0dx0a } x0dx0a x0dx0a public FixGridLayout(Context context, AttributeSet attrs) { x0dx0a super(context, attrs); x0dx0a } x0dx0a x0dx0a public FixGridLayout(Context context, AttributeSet attrs, int defStyle) { x0dx0a super(context, attrs, defStyle); x0dx0a } x0dx0a x0dx0a public void setmCellWidth(int w) { x0dx0a mCellWidth = w; x0dx0a requestLayout(); x0dx0a } x0dx0a x0dx0a public void setmCellHeight(int h) { x0dx0a mCellHeight = h; x0dx0a requestLayout(); x0dx0a } x0dx0a x0dx0a /** x0dx0a * 控制子控件的换行 x0dx0a */ x0dx0a @Override x0dx0a protected void onLayout(boolean changed, int l, int t, int r, int b) { x0dx0a int cellWidth = mCellWidth; x0dx0a int cellHeight = mCellHeight; x0dx0a int columns = (r - l) / cellWidth; x0dx0a if (columns < 0) { x0dx0a columns = 1; x0dx0a } x0dx0a int x = 0; x0dx0a int y = 0; x0dx0a int i = 0; x0dx0a int count = getChildCount(); x0dx0a for (int j = 0; j < count; j++) { x0dx0a final View childView = getChildAt(j); x0dx0a // 获取子控件Child的宽高 x0dx0a int w = childView.getMeasuredWidth(); x0dx0a int h = childView.getMeasuredHeight(); x0dx0a // 计算子控件的顶点坐标 x0dx0a int left = x + ((cellWidth - w) / 2); x0dx0a int top = y + ((cellHeight - h) / 2); x0dx0a // int left = x; x0dx0a // int top = y; x0dx0a // 布局子控件 x0dx0a childView.layout(left, top, left + w, top + h); x0dx0a x0dx0a if (i >= (columns - 1)) { x0dx0a i = 0; x0dx0a x = 0; x0dx0a y += cellHeight; x0dx0a } else { x0dx0a i++; x0dx0a x += cellWidth; x0dx0a x0dx0a } x0dx0a } x0dx0a } x0dx0a x0dx0a /** x0dx0a * 计算控件及子控件所占区域 x0dx0a */ x0dx0a @Override x0dx0a protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { x0dx0a // 创建测量参数 x0dx0a int cellWidthSpec = MeasureSpec.makeMeasureSpec(mCellWidth, MeasureSpec.AT_MOST); x0dx0a int cellHeightSpec = MeasureSpec.makeMeasureSpec(mCellHeight, MeasureSpec.AT_MOST); x0dx0a // 记录ViewGroup中Child的总个数 x0dx0a int count = getChildCount(); x0dx0a // 设置子空间Child的宽高 x0dx0a for (int i = 0; i < count; i++) { x0dx0a View childView = getChildAt(i); x0dx0a /* x0dx0a * 090 This is called to find out how big a view should be. 091 The x0dx0a * parent supplies constraint information in the width and height x0dx0a * parameters. 092 The actual mesurement work of a view is performed x0dx0a * in onMeasure(int, int), 093 called by this method. 094 Therefore, x0dx0a * only onMeasure(int, int) can and must be overriden by subclasses. x0dx0a * 095 x0dx0a */ x0dx0a childView.measure(cellWidthSpec, cellHeightSpec); x0dx0a } x0dx0a // 设置容器控件所占区域大小 x0dx0a // 注意setMeasuredDimension和resolveSize的用法 x0dx0a setMeasuredDimension(resolveSize(mCellWidth * count, widthMeasureSpec), x0dx0a resolveSize(mCellHeight * count, heightMeasureSpec)); x0dx0a // setMeasuredDimension(widthMeasureSpec, heightMeasureSpec); x0dx0a x0dx0a // 不需要调用父类的方法 x0dx0a // super.onMeasure(widthMeasureSpec, heightMeasureSpec); x0dx0a } x0dx0a x0dx0a /** x0dx0a * 为控件添加边框 x0dx0a */ x0dx0a @Override x0dx0a protected void dispatchDraw(Canvas canvas) { x0dx0a // 获取布局控件宽高 x0dx0a int width = getWidth(); x0dx0a int height = getHeight(); x0dx0a // 创建画笔 x0dx0a Paint mPaint = new Paint(); x0dx0a // 设置画笔的各个属性 x0dx0a mPaint.setColor(Color.BLUE); x0dx0a mPaint.setStyle(Paint.Style.STROKE); x0dx0a mPaint.setStrokeWidth(10); x0dx0a mPaint.setAntiAlias(true); x0dx0a // 创建矩形框 x0dx0a Rect mRect = new Rect(0, 0, width, height); x0dx0a // 绘制边框 x0dx0a canvas.drawRect(mRect, mPaint); x0dx0a // 最后必须调用父类的方法 x0dx0a super.dispatchDraw(canvas); x0dx0a } x0dx0a x0dx0a} x0dx0a然后在Xml文件中引用自己定义的控件,在Java代码中调用:x0dx0ax0dx0a[java] view plainprint?x0dx0apackage com.huanglong.mylinearlayout; x0dx0a x0dx0aimport android.os.Bundle; x0dx0aimport android.app.Activity; x0dx0aimport android.view.Menu; x0dx0aimport android.view.MenuItem; x0dx0aimport android.widget.CheckBox; x0dx0aimport android.widget.SimpleAdapter; x0dx0aimport android.support.v4.app.NavUtils; x0dx0a x0dx0apublic class MainActivity extends Activity { x0dx0a private SimpleAdapter adapter; x0dx0a @Override x0dx0a public void onCreate(Bundle savedInstanceState) { x0dx0a super.onCreate(savedInstanceState); x0dx0a setContentView(R.layout.activity_main); x0dx0a FixGridLayout fixGridLayout = (FixGridLayout) findViewById(R.id.ll); x0dx0a fixGridLayout.setmCellHeight(30); x0dx0a fixGridLayout.setmCellWidth(100); x0dx0a for (int i = 0; i < 7; i++) { x0dx0a CheckBox box = new CheckBox(MainActivity.this); x0dx0a box.setText("第"+i+"个"); x0dx0a fixGridLayout.addView(box); x0dx0a } x0dx0a } x0dx0a x0dx0a @Override x0dx0a public boolean onCreateOptionsMenu(Menu menu) { x0dx0a getMenuInflater().inflate(R.menu.activity_main, menu); x0dx0a return true; x0dx0a } x0dx0ax0dx0a}

热点内容
访问外网数据库 发布:2025-08-12 08:09:52 浏览:905
长江存储签约费违约金 发布:2025-08-12 08:09:37 浏览:881
蒙哥马利访问中国 发布:2025-08-12 08:08:07 浏览:689
编译程序所需内存空间大 发布:2025-08-12 08:07:28 浏览:577
缓存倍频 发布:2025-08-12 08:00:08 浏览:104
如何破译数字和字母的密码 发布:2025-08-12 07:54:24 浏览:640
阴影体算法 发布:2025-08-12 07:45:23 浏览:625
android腾讯开放平台 发布:2025-08-12 07:45:22 浏览:29
向服务器上传数据 发布:2025-08-12 07:20:48 浏览:92
美术设计专业需什么配置电脑 发布:2025-08-12 07:19:08 浏览:483