package com.example.dynamiclist; /** * 带有标题的listview */ import java.util.List; import android.content.Context; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.view.Gravity; import android.view.View; import android.view.ViewGroup; import android.widget.AdapterView; import android.widget.BaseAdapter; import android.widget.LinearLayout; import android.widget.ListView; import android.widget.TextView; public class CListView extends LinearLayout { private static LayoutParams FILL_FILL_LAYOUTPARAMS = new LayoutParams(LayoutParams.MATCH_PARENT, LayoutParams.MATCH_PARENT, 1); private static LayoutParams WAP_WAP_LAYOUTPARAMS = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); private CAdapter cAdapter; /** 标题空间. */ private LinearLayout titleLayout; private String[] title; private ListView listView; /** 数据. */ private List<String[]> data; /** 列宽数据. */ private int[] itemWidth; /** 当前选中行. */ private int selectedPosition = -1; /** 自动列宽列. */ private int autoWidthIndex = -1; private AdapterView.OnItemClickListener onItemClickListener; /** 行背景颜色. */ private int[] rowsBackgroundColor; /** 选中行背景颜色. */ private int selectedBackgroundColor = Color.argb(200, 224, 243, 250); /** 标题背景颜色. */ private int titleBackgroundColor; /** 标题字体颜色. */ private int titleTextColor = Color.argb(255, 100, 100, 100); /** 内容字体颜色. */ private int contentTextColor = Color.argb(255, 100, 100, 100); /** 标题字体大小. */ private float titleTextSize = 0; /** 内容字体大小. */ private float contentTextSize = 0; /** * 初始化带标题ListView * @param context 父级上下文 * @param title 标题数组 * @param data 内容列表 */ public CListView(Context context, String[] title, List<String[]> data) { super(context); this.title = title; this.data = data; // 设定纵向布局 setOrientation(VERTICAL); // 设定背景为白色 setBackgroundColor(Color.WHITE); // 预先设定好每列的宽 this.itemWidth = new int[title.length]; autoWidthIndex = this.itemWidth.length - 1; // 计算列宽 calcColumnWidth(); // 添加title位置 titleLayout = new LinearLayout(getContext()); titleLayout.setBackgroundColor(Color.parseColor("#CCCCCC")); addView(titleLayout); // 绘制标题面板 drawTitleLayout(); // 添加listview listView = new ListView(getContext()); listView.setPadding(0, 2, 0, 0); cAdapter = new CAdapter(); listView.setAdapter(cAdapter); listView.setCacheColorHint(0); listView.setLayoutParams(FILL_FILL_LAYOUTPARAMS); listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { if (onItemClickListener != null) onItemClickListener.onItemClick(parent, view, position, id); setSelectedPosition(position); selectedPosition = position; cAdapter.notifyDataSetChanged(); } }); addView(listView); } /** * 绘制标题 */ private void drawTitleLayout() { titleLayout.removeAllViews(); for (int i = 0; i < title.length; i++) { TextView tv = new CTextView(titleLayout.getContext()); // TextView tv = new TextView(titleLayout.getContext()); tv.setTextColor(titleTextColor); tv.setGravity(Gravity.CENTER); tv.setText(title[i]); if (titleTextSize > 0) { tv.setTextSize(titleTextSize); } tv.setPadding(5, 0, 5, 0); if (i == autoWidthIndex) tv.setLayoutParams(CListView.FILL_FILL_LAYOUTPARAMS); else { tv.setWidth(itemWidth[i]); } titleLayout.addView(tv); } } /** * 计算列宽 * @return 是否有改动 */ private boolean calcColumnWidth() { boolean result = false; float textSize = new TextView(getContext()).getTextSize();//21px // 计算标题列宽 for (int i = 0; i < itemWidth.length; i++) { int w = (int) CListView.GetPixelByText((titleTextSize > 0) ? titleTextSize : textSize, title[i]); if (itemWidth[i] < w) { itemWidth[i] = w; result = true; } } // 计算内容列宽 if (contentTextSize > 0) { textSize = contentTextSize; } for (int i = 0; i < data.size(); i++) { for (int j = 0; j < itemWidth.length && j < data.get(i).length; j++) { int w = (int) CListView.GetPixelByText(textSize, data.get(i)[j]); if (itemWidth[j] < w) { itemWidth[j] = w; result = true; } } } return result; } /** * 计算字符串所占像素 * @param textSize 字体大小 * @param text 字符串 * @return 字符串所占像素 */ private static int GetPixelByText(float textSize, String text) { Paint mTextPaint = new Paint(); mTextPaint.setTextSize(textSize); // 指定字体大小 mTextPaint.setFakeBoldText(true); // 粗体 mTextPaint.setAntiAlias(true); // 非锯齿效果 return (int) (mTextPaint.measureText(text) + textSize); } /** * 主要用的Adapter * @author Cdisk */ class CAdapter extends BaseAdapter { /** * (non-Javadoc) * @see android.widget.Adapter#getCount() */ @Override public int getCount() { if (data == null) return 0; return data.size(); } /** * (non-Javadoc) * @see android.widget.Adapter#getItem(int) */ @Override public Object getItem(int position) { if (data == null) return null; return data.get(position); } /** * (non-Javadoc) * @see android.widget.Adapter#getItemId(int) */ @Override public long getItemId(int position) { return 0; } /** * (non-Javadoc) * @see android.widget.Adapter#getView(int, android.view.View, android.view.ViewGroup) */ @Override public View getView(int position, View convertView, ViewGroup parent) { // 初始化主layout LinearLayout contextLayout = new LinearLayout(CListView.this.getContext()); String[] dataItem = data.get(position); if (getSelectedPosition() == position) { // 为当前选中行 contextLayout.setBackgroundColor(selectedBackgroundColor); } else if (rowsBackgroundColor != null && rowsBackgroundColor.length > 0) { contextLayout.setBackgroundColor(rowsBackgroundColor[position % rowsBackgroundColor.length]); } for (int i = 0; i < title.length; i++) { TextView tv = new CTextView(contextLayout.getContext()); // TextView tv = new TextView(contextLayout.getContext()); tv.setTextColor(contentTextColor); tv.setGravity(Gravity.CENTER); if (i < dataItem.length) { tv.setText(dataItem[i]); } if (i == autoWidthIndex) tv.setLayoutParams(CListView.FILL_FILL_LAYOUTPARAMS); else { tv.setWidth(itemWidth[i]); } if (contentTextSize > 0) { tv.setTextSize(contentTextSize); } contextLayout.addView(tv); } return contextLayout; } } /** * 整体有改变时,刷新显示 */ public void definedSetChanged() { calcColumnWidth(); drawTitleLayout(); cAdapter.notifyDataSetChanged(); } /** * 设置选中时的监听器 * @param onItemClickListener */ public void setOnItemClickListener(AdapterView.OnItemClickListener onItemClickListener) { this.onItemClickListener = onItemClickListener; } /** * 设置行背景颜色, 多个颜色可以作为间隔色 * @param color 行背景颜色,可以为多个 */ public void setItemBackgroundColor(int... color) { rowsBackgroundColor = color; } /** * 数据总数 */ public int getCount() { if (data == null) return 0; return data.size(); } /** * 当前选中数据 * @param position * @return */ public String[] getItem(int position) { if (data == null) return null; return data.get(position); } /** * 设置当前选中位置 * @return */ public void setSelectedPosition(int selectedPosition) { this.selectedPosition = selectedPosition; } /** * 当前选中位置 * @return */ public int getSelectedPosition() { return selectedPosition; } /** * 设置被选中时的背景色 * @param color */ public void setSelectedBackgroundColor(int color) { selectedBackgroundColor = color; } /** * 设置标题背景色. * @param color */ public void setTitleBackgroundColor(int color) { titleBackgroundColor = color; titleLayout.setBackgroundColor(titleBackgroundColor); } /** * 设置标题文字颜色 * @param color */ public void setTitleTextColor(int color) { titleTextColor = color; for (int i = 0; i < titleLayout.getChildCount(); i++) { ((TextView) titleLayout.getChildAt(i)).setTextColor(titleTextColor); } } /** * 设置内容文字颜色 * @param color */ public void setContentTextColor(int color) { contentTextColor = color; } /** * 设置标题字体大小 * @param szie */ public void setTitleTextSize(float szie) { titleTextSize = szie; } /** * 设置内容字体大小 * @param szie */ public void setContentTextSize(float szie) { contentTextSize = szie; } /** * 设定哪列自动列宽 从0开始计算 * @param index */ public void setAutoColumnWidth(int index) { autoWidthIndex = index; for (int i = 0; i < titleLayout.getChildCount(); i++) { TextView tv = ((TextView) titleLayout.getChildAt(i)); if (i == autoWidthIndex){ tv.setLayoutParams(FILL_FILL_LAYOUTPARAMS); }else { tv.setLayoutParams(WAP_WAP_LAYOUTPARAMS); tv.setWidth(itemWidth[i]); } } } /**TextView画边框所用的paint*/ private static Paint BLACK_PAINT = new Paint(); private static Paint WHITE_PAINT = new Paint(); static { WHITE_PAINT.setColor(Color.WHITE); BLACK_PAINT.setColor(Color.BLACK); } /** * 重写的TextView,给TextView四周加上了边框 * @author Cdisk */ class CTextView extends TextView { @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); // Top canvas.drawLine(0, 0, this.getWidth() - 1, 0, WHITE_PAINT); // Left canvas.drawLine(0, 0, 0, this.getHeight() - 1, WHITE_PAINT); // Right canvas.drawLine(this.getWidth() - 1, 0, this.getWidth() - 1, this.getHeight() - 1, BLACK_PAINT); // Buttom canvas.drawLine(0, this.getHeight() - 1, this.getWidth() - 1, this.getHeight() - 1, BLACK_PAINT); } public CTextView(Context context) { super(context); } } }
package com.example.dynamiclist; import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.graphics.Color; import android.os.Bundle; import android.view.View; import android.widget.AdapterView; public class CsvDynamicToListActivity extends Activity { CListView listView; List<String[]> list = new ArrayList<String[]>(); @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); makeData(); String[] title = new String[] { "ID", "标题2", "标题3", "标题4", "标题5" }; listView = new CListView(this, title, list); listView.setTitleTextColor(Color.GREEN); listView.setTitleBackgroundColor(Color.RED); // listView.setAutoColumnWidth(3); // listView.setItemBackgroundColor(Color.GREEN, Color.WHITE); listView.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { String[] item = listView.getItem(position); item[2] = "12312312312"; listView.definedSetChanged(); } }); listView.definedSetChanged(); setContentView(listView); } private void makeData() { list.add(new String[] { "1", "数据1.2", "数据1.3", "数据1.4" }); list.add(new String[] { "2", "数据2.2", "数据2.3", "数据2.4", "数据2.5" }); list.add(new String[] { "10", "数据10.2", "数据10.3", "数据10.4", "数据10.5", "数据10.6", "数据10.7" }); } }
中国移动重磅推出了MM应用引擎(MM AppEngine),一个网络应用程序的开发和托管平台。MM应用引擎提供了应用托管、数据库托管等多种云服务,利用它你可以花费更低的成本、更快地构建应用,并获得零维护的运营体验。
MM应用引擎是由中国移动互联网公司和中国移动研究院联合推出的云计算PaaS服务,相对于IaaS这种云计算服务模型,PaaS提供的服务更加全面化和精细化,它将虚拟化计算资源、应用管理工具、应用云服务等集成在一起提供给用户,并提供应用开发,测试、部署环境等完整生命周期服务。
三种云计算服务模型
从普适性的“资源作为服务”到专业化的“软件平台作为服务”,MM应用引擎极大降低了用户使用IT资源的门槛,无论你是不是云计算专家,都能享受云计算带来的一切便利:
◆支持主流应用运行环境:JAVA,PHP
◆丰富的云服务:MySQL服务,Memcahce服务,对象存储服务,定时任务服务
◆提供应用开发工具:Eclipse集成开发环境和在线代码编辑器
特色
1.安全、弹性伸缩的高可用应用托管环境
◆应用沙箱和安全隔离:提供符合业界标准的Java、PHP安全沙箱,确保托管应用之间的隔离,以及托管应用和系统之间的隔离
◆动态负载均衡:包括反向代理、智能应用路由,发挥效用最大化
◆应用资源弹性伸缩:根据负载情况自动调整应用资源,既不影响业务运行,也不造成资源浪费
◆自动分布式部署和高可用:托管应用均以多副本部署,避免单点故障
◆健康监控和自动恢复:系统完成节点健康监控,避免节点失效造成的业务中断,提高可靠性
2.可靠、标准、易用的云服务
◆MySQL服务:提供标准的MySQL数据库集约化托管、多应用共享、可弹性扩展的数据库服务能力
◆Memcache服务:业界流行的缓存服务,方便的服务开通/注销,直观清晰的使用情况查看
3.强大的开发工具
◆提供基于Eclipse的集成开发环境,方便开发者进行本地应用开发、测试、一键部署
◆提供在线代码编辑器,允许开发者在开发者门户直接编辑托管应用代码无缝集成MM云能力池SDK,方便能力应用的开发
4.卓越的用户体验
o简洁的应用上线流程:在门户创建应用'应用开发/本地调试'一键部署'立即访问
o友好的开发者门户:便捷的应用创建流程、实时直观的资源监控和统计、详尽的一站式资源报表、完善的应用日志中心
场景
面向终端应用、WAP/WEB应用及HTML5应用提供应用托管服务:
1.终端应用
◆离线类终端应用:假如你正在开发一款名叫“愤怒的小鸡”的手机游戏,可以将应用更新程序、游戏积分排行榜数据、或者游戏推广网页托管在MM应用引擎上
◆在线类终端应用:对于“豆瓣FM”这样主要程序在网络侧的应用,MM应用引擎可以提供应用逻辑及数据库的托管服务
2. WEB应用:将“水果团购”等电商网站,或者基于wordpress的个人博客系统托管在MMAE上再合适不过了
3. WAP应用:提供应用的全站点托管
免费试用,极致体验,屌丝也能云计算!
官方网站:http://www.mmae.cn
开发手册地址:http://www.mmae.cn/download/usermanual-1.5.1.doc
离线安装地址:http://www.mmae.cn/download/mmade20130521.zip
NSMutableAttributedString *attriString = [[NSMutableAttributedString alloc] initWithString:@"范例范例范例范例范例范例范例范例范例范例"];
[attriString addAttribute:(NSString *)kCTForegroundColorAttributeName
value:(id)[UIColor redColor].CGColor
range:NSMakeRange(3, 4)];
NSUInteger length = [attriString length];
//添加字体目标字符串从下标0开始到字符串结尾
UIFont *baseFont = [UIFont systemFontOfSize:17.0];
[attriString addAttribute:NSFontAttributeName value:baseFont
range:NSMakeRange(0, length)];
CATextLayer *textLayer = [CATextLayer layer];
textLayer.string = attriString;
textLayer.frame = CGRectMake(47, 12, 226, 56);
[self.view.layer addSublayer:textLayer];