芳华前任3百度网盘云资源

Android软键盘弹出不影响布局的方法
The Manifest.xml File
:windowSoftInputMode=["stateUnspecified",
"stateUnchanged", "stateHidden",
"stateAlwaysHidden", "stateVisible",
"stateAlwaysVisible", "adjustUnspecified",
"adjustResize", "adjustPan"] …… &
attributes:
:windowSoftInputMode
活动的主窗口如何与包含屏幕上的软键盘窗口交互。这个属性的设置将会影响两件事情:
1& 软键盘的状态——是否它是隐藏或显示——当活动()成为用户关注的焦点。
活动的主窗口调整——是否减少活动主窗口大小以便腾出空间放软键盘或是否当活动窗口的部分被软键盘覆盖时它的内容的当前焦点是可见的。
它的设置必须是下面列表中的一个值,或一个”state…”值加一个”adjust…”值的组合。在任一组设置多个值——多个”state…”values,例如&mdash有未定义的结果。各个值之间用|分开。例如:
在这设置的值(除”stateUnspecified”和”adjustUnspecified”以外)将覆盖在主题中设置的值
“stateUnspecified”
软键盘的状态(是否它是隐藏或可见)没有被指定。系统将选择一个合适的状态或依赖于主题的设置。
这个是为了软件盘行为默认的设置。
“stateUnchanged”
软键盘被保持无论它上次是什么状态,是否可见或隐藏,当主窗口出现在前面时。
“stateHidden”
当用户选择该Activity时,软键盘被隐藏——也就是,当用户确定导航到该Activity时,而不是返回到它由于离开另一个Activity。
“stateAlwaysHidden”
软键盘总是被隐藏的,当该Activity主窗口获取焦点时。
“stateVisible”
软键盘是可见的,当那个是正常合适的时(当用户导航到Activity主窗口时)。
“stateAlwaysVisible”
当用户选择这个Activity时,软键盘是可见的——也就是,也就是,当用户确定导航到该Activity时,而不是返回到它由于离开另一个Activity。
“adjustUnspecified”
它不被指定是否该Activity主窗口调整大小以便留出软键盘的空间,或是否窗口上的内容得到屏幕上当前的焦点是可见的。系统将自动选择这些模式中一种主要依赖于是否窗口的内容有任何布局视图能够滚动他们的内容。如果有这样的一个视图,这个窗口将调整大小,这样的假设可以使滚动窗口的内容在一个较小的区域中可见的。这个是主窗口默认的行为设置。
“adjustResize”
该Activity主窗口总是被调整屏幕的大小以便留出软键盘的空间
“adjustPan”
该Activity主窗口并不调整屏幕的大小以便留出软键盘的空间。相反,将当前窗口的内容自动移动以便当前焦点从不被键盘覆盖和用户能总是看到输入内容的部分。这个通常是不期望比调整大小,因为用户可能关闭软键盘以便获得与被覆盖内容的交互操作。
关闭软键盘:
InputMethodManager m = (InputMethodManager)
mContext.getSystemService(Context.INPUT_METHOD_SERVICE);
m .hideSoftInputFromWindow(mContentEt.getWindowToken(), 0);
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。一个中文输入法软键盘的布局方式怎么实现的问题
你好,想跟你请教个问题:关于输入法字母键盘的布局,比如下面的样子
android自带的例程SoftKeyboard中是通过下面这种&Keyboard&&Row&标签来确定的
&Keyboard xmlns:android=&/apk/res/android&
android:keyWidth=&10%p&
android:horizontalGap=&0px&
android:verticalGap=&0px&
android:keyHeight=&@dimen/key_height&
&Key android:codes=&113& android:keyLabel=&q& android:keyEdgeFlags=&left&/&
&Key android:codes=&119& android:keyLabel=&w&/&
&Key android:codes=&101& android:keyLabel=&e&/&
&Key android:codes=&114& android:keyLabel=&r&/&
&Key android:codes=&116& android:keyLabel=&t&/&
&Key android:codes=&121& android:keyLabel=&y&/&
&Key android:codes=&117& android:keyLabel=&u&/&
&Key android:codes=&105& android:keyLabel=&i&/&
&Key android:codes=&111& android:keyLabel=&o&/&
&Key android:codes=&112& android:keyLabel=&p& android:keyEdgeFlags=&right&/&
&/Keyboard&
我可以把其中每个字母键直接定义成一个按钮,即在xml中用布局Activity那样的方式进行布局吗(直接用Button标签)?
&RelativeLayout
xmlns:android=&/apk/res/android&
android:background=&@drawable/bottom&
android:layout_width=&fill_parent&
android:layout_height=&wrap_content&
android:id=&@+id/b1&
android:text=&A&
android:layout_width=&80dip&
android:layout_height=&wrap_content&&
&/RelativeLayout& 谢谢红薯大哥!
以下是问题补充:
:问一下,怎么实现点击字母弹出的pop的背景和内部提示字母的字体颜色啊??android软键盘影响布局问题
android软键盘影响布局问题
大布局整体为,上面是一个搜索edittext,然后有一个banner,下面是一个scrollview,scrollview里面有一个imageview,imageview下面是gridview。(别问我为什么这样)
问题:我点击edittext,输入文字后,在点击搜索跳转页面时,scrollview里面的imageview会自动隐藏,当你返回搜索页面时,滑动scrollview才能滑出来。如果不搜索,直接跳转其他页面,就正常。哪位大神帮忙解释一下
解决方案二:
既然是仿,那么我们来看看源微信通讯录是个什么样子什么功能以及我们实现后的效果,如下图所示:
下面我们就来一步一步剖析这个功能实现及其思路。
1.分析界面的构成
界面由上左右中四部分构成,控件分别为:
Ⅰ上为EditText输入文本框。
Ⅱ左为ListView。
Ⅲ右为自定义控件。
Ⅳ中为一个隐藏的TextView,当点击右侧自定义控件的字母时,将隐藏的TextView显示出来。
左右中三控件使用什么布局才能达到如此效果?使用LinearLayout显然不可能完成,TextView无法设置在某个控件之上,设置为RelativeLayout需要设置许多参数才能达到上面的效果,那么FrameLayout呢?
FrameLayout是最简单的布局了。所有放在布局里的控件,都按照层次堆叠在屏幕的左上角。后加进来的控件覆盖前面的控件。在FrameLayout布局里,定义任何空间的位置相关的属性都毫无意义。控件自动的堆放在左上角,根本不听你的控制。
当设置为FrameLayout层叠的控件问题解决了,当设置android:layout_gravity="right"时,自定义控件自动就水平居右了,当设置android:gravity="center"中间的TextView就居中了,不像RelativeLayout还要设置什么控件在什么控件的左过或者右边等复杂的属性。
当了解这些后,我们的布局文件也可形成了,代码如下:
android:layout_width="match_parent"
android:layout_height="match_parent"
android:focusable="true"
android:focusableInTouchMode="true"
android:orientation="vertical"&
android:id="@+id/searchEdit"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/search_frame" /&
&FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent"&
android:id="@+id/myList"
android:layout_width="match_parent"
android:layout_height="wrap_content" /&
android:id="@+id/dialogString"
android:layout_width="100dp"
android:layout_height="100dp"
android:layout_gravity="center"
android:textSize="50sp"
android:visibility="invisible"
android:background="#54FF9F"
android:textColor="#8B1A1A"
android:gravity="center"/&
&com.example.liyuanjing.addressbook.RightView
android:id="@+id/rightView"
android:layout_width="20dp"
android:layout_height="match_parent"
android:layout_gravity="right" /&
&/FrameLayout&
这里的两个属性要说明一下:
㈠.android:focusableInTouchMode:顾名思义,让activity能获取用户焦点
㈡.android:focusable:获取用户焦点
使用这两个属性,是为了防止启动APP后立即弹出输入法。这里的解决思路就是让其他不能弹出输入法的焦点获取焦点,这样就不会启动时弹出输入法了。
2.实现自定义控件RightView
界面思路:从上面截图可以看出来,这是一个竖立的控件,字母也是竖立的写的,那么我们可以设置它的宽度很小,高度为除上面EditText外的高度,字母根据高度除26等于每个字母的长度。
响应点击事件思路:根据字母所占的位置高度,来确定控件点击了哪个字母。得到字母后,通过设置回调函数更新ListView的显示。并且设置TextView的值及显示和隐藏。
②具体的实现
Ⅰ首先我们定义RightView类继承自View
public class RightView extends View {
public RightView(Context context, AttributeSet attrs) {
super(context, attrs);
因为在上面的布局文件中设置了属性,所以需要带有AttributeSet参数的构造方法。
Ⅱ定义TextView
当自定义控件接收到触摸事件的时候,需要设置中间TextView的值,并且还要设置其隐藏还是显示。故代码如下:
private TextV
public void setMdialog(TextView mdialog) {
this.mdialog =
Ⅲ绘制控件
重写onDraw()方法来绘制控件,代码如下:
private String[] chars = {"A", "B", "C", "D", "E", "F", "G", "H", "I",
"J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"};
protected void onDraw(Canvas canvas) {
super.onDraw(canvas);
this.paint = new Paint();//创建一个画笔
int x = getWidth();//获取控件的宽度
int y = getHeight();//获取控件的高度
int singleHeight = y / chars.//获取每个字母的高度
for (int i = 0; i & chars. i++) {
this.paint.setColor(Color.BLACK);//设置画笔的颜色为黑色
this.paint.setTextSize(20.0f);//设置字体的大小为20f
canvas.drawText(chars[i], 10, singleHeight * (i + 1), paint);//画字符到控件上
在上面的布局文件中我们设置了设置为match_parent,宽度为20dp。那么这里的getWidth()和getHeight()获取的就是设置自定义控件在屏幕上占有的宽度和高度。
Canvas是画布,你可以理解为一张纸,Paint是画笔,可以理解为在纸上作画的那支笔,有了这两个,才能画画。才能在屏幕上画控件。
drawText为画文本:
第一个参数为要画的文本。
第二个参数为文本在控件的X坐标。
第三个参数为文本在控件的Y坐标。
第四个参数为画笔。
如下图,假设文本占整个矩形框,坐标为文本左上角的坐标:
现在运行程序,得到如下图所示:
当然没有红色,这为后面加上去的。
Ⅳ创建接口
当中间TextView内容改变的时候,为了能通知ListView作出相应的变化,需要创建一个回调接口,以便通知ListView。让ListView作出响应。
private OnTextViewC
public interface OnTextViewChange {
void onTextChange(String s);
public void setOnTextViewChange(OnTextViewChange change) {
this.changelistener =
Ⅴ监听触摸事件
public boolean dispatchTouchEvent(MotionEvent event) {
float x = (int) event.getX();//获取触摸到控件上的X坐标值
float y = (int) event.getY();//获致触摸到控件上的Y坐标值
switch (event.getAction()) {//判断触摸事件的类型
case MotionEvent.ACTION_DOWN: {//当类型为按下
setBackgroundColor(Color.RED);//设置控件的背景
if (this.mdialog.getVisibility() == View.INVISIBLE) {//当TextView为隐藏
int vi = (int) ((y / (float) getHeight()) * (float) chars.length);//获取具体按下哪个字母
this.mdialog.setText(chars[vi]);//设置弹出文本
this.mdialog.setVisibility(View.VISIBLE);//显示控件
this.changelistener.onTextChange(this.mdialog.getText().toString());//通知ListView
case MotionEvent.ACTION_UP://当类型为抬起
setBackgroundColor(Color.WHITE);//设置背景
if (this.mdialog.getVisibility() == View.VISIBLE) {//判断TextView是否为显示
this.mdialog.setText("");//设置文本为空
this.mdialog.setVisibility(View.INVISIBLE);//当手指离开控件,隐藏TextView
case MotionEvent.ACTION_MOVE: {//当类型为移动
int vi = (int) ((y / (float) getHeight()) * (float) chars.length);////获取具体按下哪个字母
this.mdialog.setText(chars[vi]);////设置弹出文本
this.changelistener.onTextChange(this.mdialog.getText().toString());//通知ListView
可以看到,代码按下和移动事件有重复的代码,这里你可以提取出来,为了方便理解,我将此写到了一起。
获取具体按到哪个字母的公式为((y/(float)getHeight)*(float)chars.length)。这里先计算高度占有的比例,然后*26就是具体的字母。当然用了许多强转类型,防止为int后丢失精度。
每次变化坐标都设置一次文本通知ListView。
3.ListView设计
从上面的截图来看,这个ListView在每个最先出现的字母上多了一个字母编号,这是怎么实现的呢?
答案就是当是第一次出现某个字母的时候显示首字母,当不是第一个显示的时候隐藏首字母。
也就是ListView里面有两个TextView,一个用来显示首字母,一个用来显示名字,当不是首次出现的字母时,隐藏第一个TextView。这样这个 效果就实现了。
下面我们就来实现我们的ListView。
Ⅰ首先实现联系人信息类MessageItem
它有两个属性,一个字母,一个名字,代码如下:
public class MessageItem {
public String firstC
Ⅱ实现ListView的适配器
还要用我们常用的BaseAdapter,代码如下:
private List nameList = new ArrayList&&();
private class NameAdapter extends BaseAdapter {
private LayoutI
NameAdapter() {
this.inflater = getLayoutInflater();
public int getCount() {
return nameList.size();
public Object getItem(int position) {
return nameList.get(position);
public long getItemId(int position) {
public View getView(int position, View convertView, ViewGroup parent) {
View view = convertV
if (view == null) {
view = this.inflater.inflate(R.layout.list_item, null);
holder = new ViewHolder(view);
view.setTag(holder);
holder = (ViewHolder) view.getTag();
MessageItem item = nameList.get(position);
holder.name.setText(item.name);
if (item.firstChar != null) {//如果有首字母
holder.title.setText(item.firstChar);//设置其首字母
holder.title.setVisibility(View.VISIBLE);//显示TextView
holder.title.setVisibility(View.GONE);//隐藏TextView
public class ViewHolder {
public TextV
public TextV
public ViewHolder(View view) {
this.title = (TextView) view.findViewById(R.id.title);
this.name = (TextView) view.findViewById(R.id.name);
需要讲解View.GONE与View.INVISIBLE,两样是隐藏,前一个隐藏后不占位置,后一个隐藏后会占位置。但都不会显示。
其他都是最基本的Android知识,这里不作过多的描述,如果看不懂,请认真学习Android基础在来。
Ⅲ排序联系人,确立首字母
我偷了一个小懒,不排序联系人,直接给了排序好的联系人如下:
private String[] name = {"aimengyuan", "aili", "bibo", "bbmb", "caonima", "changjiang", "debug", "eoog", "fengxinyao", "git", "hefan", "inne", "ppoppo", "renmingbi", "xinxin", "you", "zzzzzzz"};
这里之所以不用汉字,是因为汉字排序的工具类,我没有下载,你可以去下载后使用,这里具体讲解功能实现,排序汉字不是本章重点。原谅我偷懒一下。
现在我们假设我们有了排序好的联系人。那么怎么设置首字母在该显示的地方显示,不该显示的地方不显示呢?
代码如下:
private int[] charFlag = new int[26];//设置标志符,当设置了某个字母的首字母后,标志为1
public void initView() {
for (int i = 0; i & name. i++) {
MessageItem item = new MessageItem();//创建一个联系人
item.name = name[i];//获取它的名字,如果是汉字,获取他对应的拼音
int ascii = (int) name[i].charAt(0);//获取名字首字母,ASCII编码
for (int j = 0; j & 26; j++) {//遍历标志符
int flag = (int) (ascii - 97);
if (flag == j) {//如果是小写字母
if (charFlag[j] != 1) {//如果该小写字母不等于1
item.firstChar = String.valueOf(((char) (j + 65)));//设置其首字母
charFlag[j] = 1;//将标志符设置为1,表示该字母有首字母在出现这个字母,不设置其首字母。
this.nameList.add(item);//添加联系人
this.adapter = new NameAdapter();
this.mListView.setAdapter(this.adapter);//设置适配器
小写字母a~z,ASCII编码为:97到122
大写字母A~Z,ASCII编码为:65到90
这里减去97就是让其在26之内,好作判断之用。
字符强转会变为ASCII编码,int强转也会成为字符。
ⅣMianActivity初始化
代码如下:
private RightView rightV
private EditText editT
private TextView dialogS
private ListView mListV
private NameA
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
this.rightView = (RightView) findViewById(R.id.rightView);
this.editText = (EditText) findViewById(R.id.searchEdit);
this.dialogString = (TextView) findViewById(R.id.dialogString);
this.mListView = (ListView) findViewById(R.id.myList);
this.rightView.setMdialog(this.dialogString);
this.rightView.setOnTextViewChange(this);
initView();
Ⅴ实现自定义控件回调接口
代码如下:
public void onTextChange(String s) {
for (int i = 0; i & nameList.size(); i++) {
MessageItem item = nameList.get(i);//获取item信息
if (item.firstChar != null && item.firstChar.equals(s)) {//判断首字母不为空,并且首字母与弹出TextView字符串相等
final int finalI =
mListView.post(new Runnable() {
public void run() {
mListView.requestFocusFromTouch();//获取焦点
mListView.setSelection(finalI);//跳转到该首字母的item
adapter.notifyDataSetChanged();//更新ListView
为什么ListView不直接调用run中的方法,而是使用post,原因有2:
原因一:界面初始化完成之后listview失去了焦点
原因二:因为listview的item高度不一致,setSelection无法准确定位。
这样更新UI,不会阻塞。
最终的运行效果如下所示:
4.最后的漏洞
如图所示:
当输入法出现后,会挤压自定义控件,这个问题很是苦恼,经过百度多篇文章后,提到如下方法在AndroidManifest.xml的该Activity控件下设置如下属性:
android:windowSoftInputMode="stateAlwaysHidden|adjustPan"
就可以完美解决上面的漏洞。
该属性的参数详情如下:
【A】stateUnspecified:软键盘的状态并没有指定,系统将选择一个合适的状态或依赖于主题的设置
【B】stateUnchanged:当这个activity出现时,软键盘将一直保持在上一个activity里的状态,无论是隐藏还是显示
【C】stateHidden:用户选择activity时,软键盘总是被隐藏
【D】stateAlwaysHidden:当该Activity主窗口获取焦点时,软键盘也总是被隐藏的
【E】stateVisible:软键盘通常是可见的
【F】stateAlwaysVisible:用户选择activity时,软键盘总是显示的状态
【G】adjustUnspecified:默认设置,通常由系统自行决定是隐藏还是显示
【H】adjustResize:该Activity总是调整屏幕的大小以便留出软键盘的空间
【I】adjustPan:当前窗口的内容将自动移动以便当前焦点从不被键盘覆盖和用户能总是看到输入内容的部分
解决方案三:
看我回复的最后,复制多了不好意思。

我要回帖

更多关于 前任3再见前任百度网盘 的文章

 

随机推荐