当前位置: 编程技术>移动开发
本页文章导读:
▪兑现类似QQ通讯录中新建短信时选择联系人的效果 实现类似QQ通讯录中新建短信时选择联系人的效果
效果如下:
Activity的上面是GridView,下面是ListView
项目结构:
实现起来很简单。注释代码中都有,直接上代码:
ChoosePanelAdapter.java:
im.........
▪ UITextView封闭键盘 UITextView关闭键盘
1.如果你程序是有导航条的,可以在导航条上面加多一个Done的按钮,用来退出键盘,当然要先实UITextViewDelegate。
- (void)textViewDidBeginEditing:(UITextView *)textView {
UIBarButtonIte.........
▪ Mac系统上查看鼠标所在点的RGB值-数码测色计 Mac系统下查看鼠标所在点的RGB值--数码测色计
苹果电脑的Mac OS X系统自带鼠标所在点颜色RGB值查看工具:数码测色计。打开Finder(Dock栏第一个笑脸图标),选择应用程序--实用工 具--.........
[1]兑现类似QQ通讯录中新建短信时选择联系人的效果
来源: 互联网 发布时间: 2014-02-18
实现类似QQ通讯录中新建短信时选择联系人的效果
效果如下:
Activity的上面是GridView,下面是ListView
项目结构:
实现起来很简单。注释代码中都有,直接上代码:
ChoosePanelAdapter.java:
import java.util.List; import android.content.Context; import android.graphics.drawable.Drawable; import android.view.View; import android.view.View.OnClickListener; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.Button; import android.widget.GridView; /** * This is the adapter of GridView. * Make every Item of GridView setOnClickListener in the method of getView(), * when Item clicked,get the background drawable of this Item. * If it's normal drawable,then go through all the items of GridView and set normal drawable. * If it's selected drawable,delete the data of arrayList by Item id,and call notifyDataSetChanged() * * 这个是GridView的数据适配器。 * 在getView()中让每一个Item都设置了OnClickListener,在点击事件触发的时候,判断下当前Item的背景图片 * 如果是normal,则遍历所有的Item,将背景设置为normal,将当前被点击的Item的背景图片设置成selected, * 如果是selected,就根据索引删除当前的Item的数据源,并调用notifyDataSetChanged(),刷新。 * * @author MichaelYe * @since 2012-8-28 * */ public class ChoosePanelAdapter extends BaseAdapter { private Context context; private List<String> arrayList; private Drawable iconDefalut; private Drawable iconSelected; public ChoosePanelAdapter(Context context, List<String> arrayList) { this.context = context; this.arrayList = arrayList; iconDefalut = context.getResources().getDrawable(R.drawable.icon_default); iconSelected = context.getResources().getDrawable(R.drawable.icon_selected); } @Override public int getCount() { return arrayList.size(); } @Override public Object getItem(int position) { return arrayList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(final int position, View convertView, ViewGroup parent) { Button button; if (convertView == null) { button = new Button(context); } else { button = (Button) convertView; } button.setText(arrayList.get(position)); button.setBackgroundDrawable(iconDefalut); button.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { if(v.getBackground() == iconSelected)//判断当前的背景是哪个 { arrayList.remove(position); ChoosePanelAdapter.this.notifyDataSetChanged(); } else { ChoosePanelAdapter.this.setButtonDefaultState(v); v.setBackgroundDrawable(iconSelected); } v.invalidate(); } }); return button; } /** * set all the buttons state normal * * 设置按钮背景图片为默认状态 * * */ private void setButtonDefaultState(View v) { GridView gvParent = (GridView)v.getParent(); int childCount = gvParent.getChildCount(); for(int i = 0; i < childCount; i++) { gvParent.getChildAt(i).setBackgroundDrawable(iconDefalut); } gvParent.invalidate(); } }
MainActivity.java
import java.util.ArrayList; import java.util.List; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.widget.AdapterView; import android.widget.AdapterView.OnItemClickListener; import android.widget.ArrayAdapter; import android.widget.GridView; import android.widget.ListView; /** * use GridView make the effect like QQ Address Book when choose a contact * * 类似QQ通讯录中的短信模块中选择联系人的效果,使用的是GridView * * @author MichaelYe * @since 2012-8-28 * */ public class MainActivity extends Activity { private GridView gvPanel; private ListView listView; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); gvPanel = (GridView)findViewById(R.id.gv_panel); listView = (ListView)findViewById(R.id.listview); final List<String> data = this.getData(); final List<String> panelArrayList = new ArrayList<String>(); final ChoosePanelAdapter adapter = new ChoosePanelAdapter(MainActivity.this, panelArrayList); listView.setAdapter(new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_expandable_list_item_1, data)); listView.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) { panelArrayList.add(data.get(position)); adapter.notifyDataSetChanged(); } }); gvPanel.setAdapter(adapter); } /** * DataSource * * * */ private List<String> getData() { List<String> list = new ArrayList<String>(); list.add("张三"); list.add("李四"); list.add("王五"); list.add("赵六"); list.add("乔丹"); list.add("爱斯基摩"); list.add("维也纳"); list.add("周星星"); return list; } }
布局文件activity_main.xml:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="fill_parent" android:layout_height="fill_parent" > <GridView android:id="@+id/gv_panel" android:layout_width="wrap_content" android:layout_height="wrap_content" android:numColumns="auto_fit" android:columnWidth="60dp" android:layout_alignParentTop="true" android:verticalSpacing="5dp" android:horizontalSpacing="5dp" android:stretchMode="columnWidth" /> <ListView android:id="@+id/listview" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_below="@+id/gv_panel" /> </RelativeLayout>
项目下载地址:
https://github.com/michaelye/DemoChooseValues
[2] UITextView封闭键盘
来源: 互联网 发布时间: 2014-02-18
UITextView关闭键盘
1.如果你程序是有导航条的,可以在导航条上面加多一个Done的按钮,用来退出键盘,当然要先实UITextViewDelegate。
2.如果你的textview里不用回车键,可以把回车键当做退出键盘的响应键。
代码如下:
这样无论你是使用电脑键盘上的回车键还是使用弹出键盘里的return键都可以达到退出键盘的效果。
3.第三种方法感觉效果比上面两种都好,就是在弹出的键盘上面加一个view来放置退出键盘的Done按钮。
推荐第三种,很好用~
1.如果你程序是有导航条的,可以在导航条上面加多一个Done的按钮,用来退出键盘,当然要先实UITextViewDelegate。
- (void)textViewDidBeginEditing:(UITextView *)textView { UIBarButtonItem *done = [[[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemDone target:self action:@selector(leaveEditMode)] autorelease]; self.navigationItem.rightBarButtonItem = done; } - (void)textViewDidEndEditing:(UITextView *)textView { self.navigationItem.rightBarButtonItem = nil; } - (void)leaveEditMode { [self.textView resignFirstResponder]; }
2.如果你的textview里不用回车键,可以把回车键当做退出键盘的响应键。
代码如下:
#pragma mark - UITextView Delegate Methods -(BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text { if ([text isEqualToString:@"\n"]) { [textView resignFirstResponder]; return NO; } return YES; }
这样无论你是使用电脑键盘上的回车键还是使用弹出键盘里的return键都可以达到退出键盘的效果。
3.第三种方法感觉效果比上面两种都好,就是在弹出的键盘上面加一个view来放置退出键盘的Done按钮。
- (void) initFeedText{ //初始化 UITextView CGRect frame = CGRectMake(12, 0, 160, 88); textFeed = [[UITextView alloc] initWithFrame:frame]; textFeed.delegate = self; textFeed.font = [UIFont fontWithName:@"TrebuchetMS" size:16]; textFeed.backgroundColor = [UIColor clearColor]; textFeed.autocorrectionType = UITextAutocorrectionTypeYes; textFeed.autocapitalizationType = UITextAutocapitalizationTypeNone; textFeed.keyboardType = UIKeyboardTypeDefault; textFeed.returnKeyType = UIReturnKeyDone; textFeed.delegate = self; //在弹出的键盘上面加一个view来放置退出键盘的Done按钮 UIToolbar * topView = [[UIToolbar alloc] initWithFrame:CGRectMake(0, 0, 320, 30)]; [topView setBarStyle:UIBarStyleDefault]; UIBarButtonItem * btnSpace = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:self action:nil]; UIBarButtonItem * doneButton = [[UIBarButtonItem alloc] initWithTitle:@"完成" style:UIBarButtonItemStyleDone target:self action:@selector(dismissKeyBoard)]; NSArray * buttonsArray = [NSArray arrayWithObjects:btnSpace, doneButton, nil]; [btnSpace release]; [doneButton release]; [topView setItems:buttonsArray]; [textFeed setInputAccessoryView:topView]; [topView release]; } //关闭键盘 -(void) dismissKeyBoard{ [textFeed resignFirstResponder]; }
推荐第三种,很好用~
[3] Mac系统上查看鼠标所在点的RGB值-数码测色计
来源: 互联网 发布时间: 2014-02-18
Mac系统下查看鼠标所在点的RGB值--数码测色计
苹果电脑的Mac OS X系统自带鼠标所在点颜色RGB值查看工具:数码测色计。打开Finder(Dock栏第一个笑脸图标),选择应用程序--实用工 具--数码测色计,双击即可启动。
苹果电脑的Mac OS X系统自带鼠标所在点颜色RGB值查看工具:数码测色计。打开Finder(Dock栏第一个笑脸图标),选择应用程序--实用工 具--数码测色计,双击即可启动。
最新技术文章: