android自定义控件按钮无法点击

TitleLayout.java

package com.example.uicustomviews;

import android.app.Activity;
import android.content.Context;
import android.util.AttributeSet;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.Toast;

public class TitleLayout extends LinearLayout {

    public TitleLayout(Context context, AttributeSet attrs) {
        super(context, attrs);
        LayoutInflater.from(context).inflate(R.layout.title, this);
        Button titleBack = (Button) findViewById(R.id.title_back);
        Button titleEdit = (Button) findViewById(R.id.title_edit);
        titleBack.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                ((Activity) getContext()).finish();
            }
        });
        titleEdit.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(getContext(), "You clicked Edit button", Toast.LENGTH_SHORT).show();
            }
        });
    }
} 

MainActivity.java

package com.example.uicustomviews;

import android.app.Activity;
import android.os.Bundle;
import android.view.Window;

public class MainActivity extends Activity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        setContentView(R.layout.activity_main);
    }
}

title.xml

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:background="@drawable/title_bg" >

    <Button
        android:id="@+id/title_back"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:layout_margin="5dip"
        android:background="@drawable/back_bg"
        android:text="Back"
        android:textColor="#fff" />

    <TextView
        android:id="@+id/title_text"
        android:layout_width="0dip"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:layout_weight="1"
        android:gravity="center"
        android:text="This is Title"
        android:textColor="#fff"
        android:textSize="22sp" />

    <Button
        android:id="@+id/title_edit"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:layout_margin="5dip"
        android:background="@drawable/edit_bg"
        android:text="Edit"
        android:textColor="#fff" />

</LinearLayout>

activity_main.xml

 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <include layout="@layout/title" />

    <com.example.uicustomviews.TitleLayout 
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >

    </com.example.uicustomviews.TitleLayout>

</LinearLayout>

求助 折腾了好久 导入别人的工程 上面这四份代码完全一样
别人的点击有反应 自己的没反应

6个回答

LZ的自定义控件没有实现所有的构造函数,LinearLayout 在API17以后一共有4个构造函数。

 public TitleLayout(Context context){
    super(context);
    init();
}

public TitleLayout(Context context, AttributeSet attrs) {
        super(context, attrs);
                init();
    }

// 还有2个需要在构造函数里调用init

private void init(){
LayoutInflater.from(getContext()).inflate(R.layout.title, this);
        Button titleBack = (Button) findViewById(R.id.title_back);
        Button titleEdit = (Button) findViewById(R.id.title_edit);
        titleBack.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                ((Activity) getContext()).finish();
            }
        });
        titleEdit.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                Toast.makeText(getContext(), "You clicked Edit button", Toast.LENGTH_SHORT).show();
            }
        });
}
CN_FOOLISHMAN
河马爸爸 按照LZ这种方式生成的自定义控件,貌似会调用第一个构造函数或者第三个,具体要看执行情况
接近 5 年之前 回复

LayoutInflater.from(context).inflate(R.layout.title, this);这种写法不推荐。
你这样写,也就是把一个title.xml里的那个LinearLayout以child的方式加入TitleLayout,相当于有两层linearayout。
你可以直接在main布局文件里使用TitleLayout,把它当做LinearLayout一样使用就行,如下main.xml
这就少了两层LinearLayout,然后你那个TitleLayout也要做调整。
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/title_bg" >

<Button
    android:id="@+id/title_back"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:layout_margin="5dip"
    android:background="@drawable/back_bg"
    android:text="Back"
    android:textColor="#fff" />

<TextView
    android:id="@+id/title_text"
    android:layout_width="0dip"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:layout_weight="1"
    android:gravity="center"
    android:text="This is Title"
    android:textColor="#fff"
    android:textSize="22sp" />

<Button
    android:id="@+id/title_edit"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_gravity="center"
    android:layout_margin="5dip"
    android:background="@drawable/edit_bg"
    android:text="Edit"
    android:textColor="#fff" />

sinat_30276961
盼汕 头没加上<com.example.uicustomviews.TitleLayout xmlns:android="http://schemas.android.com/apk/res/android"
接近 5 年之前 回复

使用两个参数的构造方法

把要点击的控件onClick设为true,不行的话再把focusable和focusableTouchMode(大概是这个名字)属性也设为true试试

楼主,解决没有,我按照上面的方法也没有用。~~

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Android自定义控件,引用里面的方法,如何引用

我自己定义了一个继承自gridview的类,主布局引用,想在主布局里再添加一个button,然后这个button点击处理事件是自定义控件里的一个方法,该怎么调用? new mygridview().方法;不能实现,点击按钮后,程序崩溃

android:自定义控件时,需要的那个ondraw()方法具体是怎么绘制的?

android:自定义控件时,需要的那个ondraw()方法具体是怎么绘制的? 因为不了解现在自定义控件的知识,所以请教大神。。。

android 自定义组合控件的问题

我想自定义一个ViewGroup,里面有4个Button,然后让它们在ViewGroup的底部显示出来,就像下图一样的: ![图片说明](https://img-ask.csdn.net/upload/201707/14/1500023444_862749.png) 但是布局的左上角总是会有一个Button,不知道为啥? ``` public class TableView extends ViewGroup { Button[] mButtons = new Button[4]; public TableView(Context context) { super(context); init(context, null, -1); } public TableView(Context context, @Nullable AttributeSet attrs) { super(context, attrs); init(context, attrs, -1); } public TableView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); init(context, attrs, defStyleAttr); } private void init(Context context, AttributeSet attrs, int defStyleAttr) { setWillNotDraw(false); LayoutParams l; for (int i = 0; i < mButtons.length; i++) { mButtons[i] = new Button(context); l = new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); mButtons[i].setLayoutParams(l); } mButtons[0].setText("首页"); mButtons[1].setText("上一页"); mButtons[2].setText("下一页"); mButtons[3].setText("尾页"); addView(mButtons[0]); addView(mButtons[1]); addView(mButtons[2]); addView(mButtons[3]); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(widthMeasureSpec, heightMeasureSpec); for (Button b : mButtons) { final LayoutParams lp = b.getLayoutParams(); final int childHeightMeasureSpec = MeasureSpec.makeMeasureSpec( 0, lp.height); final int childWidthMeasureSpec = getChildMeasureSpec(widthMeasureSpec, 0, lp.width); b.measure(childHeightMeasureSpec, childWidthMeasureSpec); } } @Override protected void onLayout(boolean changed, int l, int t, int r, int b) { int totalButtonWidth = 0; for (Button bt : mButtons) { totalButtonWidth += bt.getMeasuredWidth(); } int left = (r - l - totalButtonWidth) / 2; for (Button bt : mButtons) { bt.layout(left, b - bt.getMeasuredHeight(), left + bt.getMeasuredWidth(), b); left += bt.getMeasuredWidth(); } } @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas); for (Button b : mButtons) { b.draw(canvas); } } } ```

自定义控件不显示问题

``` 自定义属性 <?xml version="1.0" encoding="utf-8"?> <resources> <declare-styleable name="Bottom"> <attr name="oneText" format="string"/> <attr name="twoText" format="string"/> <attr name="threeText" format="string"/> <attr name="oneTextSize" format="dimension"/> <attr name="twoTextSize" format="dimension"/> <attr name="ThreeTextSize" format="dimension"/> <attr name="oneTextColor" format="color"/> <attr name="twoTextColor" format="color"/> <attr name="ThreeTextColor" format="color"/> <attr name="oneImageIcon" format="reference|color"/> <attr name="twoImageIcon" format="reference|color"/> <attr name="threeImageIcon" format="reference|color"/> <attr name="backColor" format="color"/> </declare-styleable> </resources> ``` 引用 ``` <com.example.myappzdybottom.zdy.MyBottom android:layout_width="fill_parent" android:layout_height="200dp" mybottom:oneText="第一个" mybottom:twoText="第二个" mybottom:oneTextSize="8sp" mybottom:oneTextColor="#FFFFFF" mybottom:twoTextColor="#FF0000" ></com.example.myappzdybottom.zdy.MyBottom> ``` 自定义view ``` public class MyBottom extends RelativeLayout{ //定义自定义属性对应的控件 private TextView textview01,textview02,textview03; private ImageView imageview01,imageview02,imageview03; private String text01,text02,text03; private Drawable drawable01,drawable02,drawable03; private int textColor01,textColor02,textColor03,backColor; private float textSize; private LinearLayout ll01,ll02,ll03; public MyBottom(Context context, AttributeSet attrs) { super(context, attrs); //建立映射 TypedArray obtainStyledAttributes = context.obtainStyledAttributes(attrs, R.styleable.Bottom); text01=obtainStyledAttributes.getString(R.styleable.Bottom_oneText); text02=obtainStyledAttributes.getString(R.styleable.Bottom_twoText); text03=obtainStyledAttributes.getString(R.styleable.Bottom_threeText); drawable01=obtainStyledAttributes.getDrawable(R.styleable.Bottom_oneImageIcon); drawable02=obtainStyledAttributes.getDrawable(R.styleable.Bottom_twoImageIcon); drawable03=obtainStyledAttributes.getDrawable(R.styleable.Bottom_threeImageIcon); textColor01=obtainStyledAttributes.getColor(R.styleable.Bottom_oneTextColor, 0); textColor02=obtainStyledAttributes.getColor(R.styleable.Bottom_twoTextColor, 0); textColor03=obtainStyledAttributes.getColor(R.styleable.Bottom_ThreeTextColor, 0); backColor=obtainStyledAttributes.getColor(R.styleable.Bottom_backColor, 0); textSize=obtainStyledAttributes.getDimension(R.styleable.Bottom_oneTextSize, 0); obtainStyledAttributes.recycle(); //实例化控件 textview01=new TextView(context); textview02=new TextView(context); textview03=new TextView(context); imageview01=new ImageView(context); imageview02=new ImageView(context); imageview03=new ImageView(context); textview01.setText(text01); textview02.setText(text02); textview03.setText(text03); textview01.setTextColor(textColor01); textview02.setTextColor(textColor01); textview03.setTextColor(textColor01); textview01.setTextSize(textSize); textview02.setTextSize(textSize); textview03.setTextSize(textSize); imageview01.setBackground(drawable01); imageview02.setBackground(drawable02); imageview03.setBackground(drawable03); LayoutParams llParams=new LayoutParams(80, LayoutParams.MATCH_PARENT ); llParams.addRule(RelativeLayout.ALIGN_PARENT_LEFT, TRUE); LayoutParams llParams02=new LayoutParams(150, LayoutParams.MATCH_PARENT); llParams02.addRule(RelativeLayout.ALIGN_PARENT_RIGHT, TRUE); ll01=new LinearLayout(context); ll02=new LinearLayout(context); ll03=new LinearLayout(context); ll01.setBackgroundColor(Color.BLACK); ll02.setBackgroundColor(Color.BLUE); /* ll01.setOrientation(LinearLayout.VERTICAL); ll02.setOrientation(LinearLayout.VERTICAL); ll03.setOrientation(LinearLayout.VERTICAL); LayoutParams textParams=new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); LayoutParams imageParams=new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); textview01.setGravity(Gravity.CENTER_HORIZONTAL);*/ LayoutParams textParams=new LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT); ll01.addView(textview01, textParams); //ll01.addView(imageview01, imageParams); ll02.addView(textview02,textParams); //ll02.addView(imageview02, imageParams); /*ll03.addView(textview03, imageParams); ll03.addView(imageview03, imageParams);*/ addView(ll01,llParams); addView(ll02,llParams02); } ``` 想在父view中添加三个字view为LinearLayout 这个可以 但是在子view中在添加TextView 就不行了 TextView 就是不显示 找不到原因,也没报错,请大神指教!!! 万分感谢!!!!

Android Studio自定义布局中的Button不响应点击事件

最近开始跟着郭霖大神的《第一行代码》学习Android开发,遇到一个问题 自定义布局之后,模拟器运行时Button不响应单击事件 代码如下 MainActivity.java package com.example.uilayouttest; import android.support.v7.app.ActionBar; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); ActionBar actionBar = getSupportActionBar(); if (actionBar != null){ actionBar.hide(); } } } activity_main.xml文件 <?xml version="1.0" encoding="UTF-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <!--android:orientation="horizontal"--> <include layout="@layout/title"/> <com.example.uilayouttest.TitleLayout android:layout_width="match_parent" android:layout_height="wrap_content"> </com.example.uilayouttest.TitleLayout> </LinearLayout> title.xml文件 <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="65dp" android:background="@drawable/back_bg" > <Button android:id="@+id/title_back" android:layout_width="60dp" android:layout_height="60dp" android:layout_gravity="top" android:layout_margin="5dp" android:text="Back" android:textColor="#fff"/> <TextView android:id="@+id/title_text" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_gravity="top" android:layout_weight="1" android:gravity="center" android:text="Title Text" android:textColor="#fff" android:textSize="28sp"/> <Button android:id="@+id/title_edit" android:layout_width="60dp" android:layout_height="60dp" android:layout_gravity="top" android:layout_margin="5dp" android:background="@drawable/edit" android:text="" /> </LinearLayout> TitleLayout.java类 package com.example.uilayouttest; import android.app.Activity; import android.content.Context; import android.util.AttributeSet; import android.util.Log; import android.view.LayoutInflater; import android.view.View; import android.widget.Button; import android.widget.LinearLayout; import android.widget.Toast; public class TitleLayout extends LinearLayout { public TitleLayout(Context context, AttributeSet attrs){ super(context,attrs); LayoutInflater.from(context).inflate(R.layout.title, this); Button titleBack = (Button) findViewById(R.id.title_back); Button titleEdit = (Button) findViewById(R.id.title_edit); titleBack.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { ((Activity) getContext()).finish(); Log.d("data", "onClick:到底有没有点击我 "); Toast.makeText(getContext(), "你点击了Back按钮", Toast.LENGTH_SHORT).show(); } }); titleEdit.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { Toast.makeText(getContext(), "你点击了Edit按钮", Toast.LENGTH_SHORT).show(); } }); } } ``` ```

请问在调用自定义控件的button事件时会有空指针错误

出错的代码如下,是菜单中的按钮事件,点击就会出现空指针错误。如果把setOnClickListener注释掉就不会出错。请问各位为什么会报错呢?代码如下。 ``` public boolean onOptionsItemSelected(MenuItem item) { switch(item.getItemId()){ case 1: LayoutInflater inflater = getLayoutInflater(); View layout = inflater.inflate(R.layout.tel_dialog, (ViewGroup) findViewById(R.id.dialog)); AlertDialog.Builder builder = new AlertDialog.Builder(this); builder.setTitle("拨打电话"); builder.setIcon(android.R.drawable.ic_dialog_info); builder.setView(layout); tel = (EditText)findViewById(R.id.telNum); dialing = (Button)findViewById(R.id.dialing); cancel = (Button)findViewById(R.id.cancel); dialing.setOnClickListener(new OnClickListener(){ @Override public void onClick(View v) { // TODO Auto-generated method stub String telNum = tel.getText().toString(); Intent intent = new Intent(Intent.ACTION_CALL,Uri.parse("tel:"+telNum)); startActivity(intent); } }); cancel.setOnClickListener(new OnClickListener(){ @Override public void onClick(View v) { // TODO Auto-generated method stub } }); builder.show(); break; case 2: MainActivity.this.finish(); break; } return true; } ``` 不胜感激!

Android在自定义View控制Activity里控件

最近在学习Android,想做一个效果遇到了困难。我自定义了一个View,然后在View里设置触摸事件,点击一个出现一个按钮, 再点击一下按钮消失。我不知道怎么在自定义View里添加Button,就放在了布局了。但是用在自定义View设置的点击事件来控 制布局里的按钮?跪谢跪谢。

使用wpfcanvas移动自定义控件后回到原位置

具体来讲,我将一个自定义控件放置于canvas中,为了实现拖拽,我在自定义控件中分别处理了鼠标按下,拖动,放开事件,并通过修改自定义控的RenderTransform的TranslateTransform的X,Y值来移动。虽然实现了,但当下一次鼠标点击该自定义控件后该控件又回到了初始位置,请问有知道为什么的吗?

Android,linearlayout中的button控件点击无效

初学者,在一个support.v4.widget.DrawerLayout中放了个linearlayout,又在里面放了两个button,发现按钮的点击事件触发不了,(我用的android:onclick="click"),请问有方法吗 <android.support.v4.widget.DrawerLayout android:id="@+id/drawer_layout" android:layout_width="match_parent" android:layout_height="match_parent"> <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:layout_weight="1" android:background="@null" android:orientation="vertical"> <Button android:id="@+id/button4" android:layout_width="70dp" android:layout_height="70dp" android:onClick="open_door" android:background="@null" android:drawableTop="@drawable/home_icon" android:text="门禁" android:textSize="15dp" /> <Button android:id="@+id/button8" android:layout_width="70dp" android:layout_height="70dp" android:onClick="pay_tax" android:background="@null" android:drawableTop="@drawable/telephone_bill_icon" android:text="话费" android:textSize="15dp" /> </LinearLayout> </android.support.v4.widget.DrawerLayout>

Android拖动按钮时候的问题

我现在碰见的问题是这样的,我在window中添加了一个view,设置这个view为最前面的view,现在上面有两个按钮,这两个按钮是可以被拖动的,现在在Android4.2版本上面拖动没有问题,但是在Android4.4版本上拖动按钮的时候--是拖动到其他view下面然后再点击屏幕其他地方的时候才能显示按钮,不然是隐藏的,求大神解答一下

Android 动态切换标题栏里用户自定义view , view里button的点击事件不响应

Android 动态切换标题栏里用户自定义view , view里button的点击事件不响应, 具体方式是:在activity里,找到view里的button,并设置点击事件,结果点了没反应

android关于自定义seekbar控件的问题(将横向seekbar改成竖向seekbar)

自定义了个seekbar,将横向的seekbar改为了竖向的seekbar,目前只支持触摸,但是用遥控器控制时候按上下按钮没响应,按下左右按钮seekbar才会被拖动 追了下代码seekbar继承自AbsSeekbar,AbsSeekBar继承自progressBar,ProgressBar继承自View,我该如何实现将按下左右键seekbar的progress值发生改变改为按下上下键seekbar的progress值发生改变?以下是我写的自定义seekbar的代码: import android.content.Context; import android.graphics.Canvas; import android.util.AttributeSet; import android.view.KeyEvent; import android.view.MotionEvent; import android.widget.SeekBar; public class VerticalSeekBarTwo extends SeekBar { public VerticalSeekBarTwo(Context context, AttributeSet attrs, int defStyle) { super(context, attrs, defStyle); // TODO Auto-generated constructor stub } public VerticalSeekBarTwo(Context context, AttributeSet attrs) { super(context, attrs); // TODO Auto-generated constructor stub } public VerticalSeekBarTwo(Context context) { super(context); // TODO Auto-generated constructor stub } protected void onSizeChanged(int w, int h, int oldw, int oldh) { super.onSizeChanged(h, w, oldh, oldw); } @Override protected synchronized void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { super.onMeasure(heightMeasureSpec, widthMeasureSpec); setMeasuredDimension(getMeasuredHeight(), getMeasuredWidth()); } protected void onDraw(Canvas c) { c.rotate(-90); c.translate(-getHeight(), 0); super.onDraw(c); } @Override public synchronized void setProgress(int progress) { super.setProgress(progress); onSizeChanged(getWidth(), getHeight(), 0, 0); } @Override public boolean onTouchEvent(MotionEvent event) { if (!isEnabled()) { return false; } switch (event.getAction()) { case MotionEvent.ACTION_DOWN: case MotionEvent.ACTION_MOVE: case MotionEvent.ACTION_UP: setProgress(getMax() - (int) (getMax() * event.getY() / getHeight())); onSizeChanged(getWidth(), getHeight(), 0, 0); break; case MotionEvent.ACTION_CANCEL: break; } return true; } @Override public boolean onKeyDown(int keyCode, KeyEvent event) { if (isEnabled()) { int progress = getProgress(); switch (keyCode) { case KeyEvent.KEYCODE_DPAD_UP: if (progress <= 0) break; setProgress(progress - 1); return true; case KeyEvent.KEYCODE_DPAD_DOWN: if (progress >= getMax()) break; setProgress(progress + 1); return true; case KeyEvent.KEYCODE_DPAD_LEFT: break; case KeyEvent.KEYCODE_DPAD_RIGHT: break; } } return super.onKeyDown(keyCode, event); } } ``` ```

android 可旋转控件

我试过 在ondraw 里面 用 canvas.rotate 方法 然后自己写一个 setOrientation方法 调用 ondraw方法 但是刷新时间 还有效果 都不是很好。谁能给一个 android 自定义 可旋转的控件 可以动态旋转 的那种。

Android Button控件点击区域怎么设置为圆形

如题,怎么将默认的方形Button响应区域设置为圆形响应区域,因为图片是圆形的

android 如何自定义 popupwindow 效果类似 58同城 的筛选功能

效果类似 58同城 的筛选功能 ![图片说明](https://img-ask.csdn.net/upload/201604/22/1461285065_777419.png) ![图片说明](https://img-ask.csdn.net/upload/201604/22/1461285075_820018.png) 我在网上找过带有类似筛选效果的源码,发现个问题。其中一个popupwindow处于打开状态时当我想点击另一个按钮打开其他的popupwindow时,会先关闭之前打开的popupwindow,然后我再次点击按钮才会打开其他的popupwindow。而58同城是直接就关闭旧的popupwindow并打开其他的popupwindow。

Android app开发:按钮拖动后单点按钮 所有按钮回到原来位置

拖动按钮后 ![图片说明](https://img-ask.csdn.net/upload/201807/13/1531471810_88626.png) 然后摁了按钮数字7 ![图片说明](https://img-ask.csdn.net/upload/201807/13/1531471833_980413.png) 所有按钮回到原位 这是关于按钮7的代码 number[7].setOnTouchListener(new OnTouchListener() {//设置按钮被触摸的时间 int lastX, lastY; // 记录移动的最后的位置 @Override public boolean onTouch(View v, MotionEvent event) { // TODO Auto-generated method stub int ea = event.getAction();//获取事件类型 switch (ea) { case MotionEvent.ACTION_DOWN: // 按下事件 lastX = (int) event.getRawX(); lastY = (int) event.getRawY(); downX = lastX; downY = lastY; break; case MotionEvent.ACTION_MOVE: // 拖动事件 // 移动中动态设置位置 int dx = (int) event.getRawX() - lastX;//位移量X int dy = (int) event.getRawY() - lastY;//位移量Y int left = v.getLeft() + dx; int top = v.getTop() + dy; int right = v.getRight() + dx; int bottom = v.getBottom() + dy; //++限定按钮被拖动的范围 if (left < 0) { left = 0; right = left + v.getWidth(); } if (right > screenWidth) { right = screenWidth; left = right - v.getWidth(); } if (top < 0) { top = 0; bottom = top + v.getHeight(); } if (bottom > v.getHeight()) { bottom = v.getHeight(); top = bottom - v.getHeight(); } //--限定按钮被拖动的范围 v.layout(left, top, right, bottom);//按钮重画 // 记录当前的位置 lastX = (int) event.getRawX(); lastY = (int) event.getRawY(); break; case MotionEvent.ACTION_UP: // 弹起事件 //判断是单击事件或是拖动事件,位移量大于5则断定为拖动事件 if (Math.abs((int) (event.getRawX() - downX)) > 5 || Math.abs((int) (event.getRawY() - downY)) > 5) clickormove = false; else clickormove = true; break; } return false; } }); number[7].setOnClickListener(new View.OnClickListener() { public void onClick(View v) { if(clickormove) { utils.soundPlay(7); // TODO Auto-generated method stub if(flag==1){ str=""; str+=7; et.setText(str); flag=0; } else{ str+=7; et.setText(str); } vi=v; }} }); ``` ```

Android中能在一个自定义view中注册广播并发出广播吗

我写的一个Android程序中自定义了一个view,自己画了一个钟表,那个钟表可以调时间,因为调时间的过程中数据是不停的变化的,我想让这变化不停的时间显示在自定义view底下的TextView,虽然我写了一个get方法得到时间并显示在textView中,到get方法只执行了一次,所以并没有变化更新效果,所以我想法是在自定义view中发送广播,只要是表在调整就一直发送最新数据,可是好广播一直报错,是不是广播只能在activity中才能发送,或者各位大神有更好的思路吗?

Android点击按钮后弹窗设置时间

![图片说明](https://img-ask.csdn.net/upload/201810/07/1538899042_996404.jpg) ![图片说明](https://img-ask.csdn.net/upload/201810/07/1538899065_607276.jpg) 弹窗显示这个时间选择器

Android ButterKnife框架怎么绑定动态加载的布局

我在自定义的FlameLayout类里定义了一个成员变量 ``` @BindView(R.id.radio_group) RadioGroup radioGroup ``` 但是这个RadioGroup不在FlameLayout布局里,而是通过FlameLayout的一个点击事件生成的PopupWindow里面的控件。我又不想用findViewById. 我在inflate PopupWindow的contentView后再次调用了ButterKnife.bind(contentView);但是没有什么卵用。怎样才能用ButterKnife绑定。

MySQL 8.0.19安装教程(windows 64位)

话不多说直接开干 目录 1-先去官网下载点击的MySQL的下载​ 2-配置初始化的my.ini文件的文件 3-初始化MySQL 4-安装MySQL服务 + 启动MySQL 服务 5-连接MySQL + 修改密码 先去官网下载点击的MySQL的下载 下载完成后解压 解压完是这个样子 配置初始化的my.ini文件的文件 ...

Python+OpenCV计算机视觉

Python+OpenCV计算机视觉系统全面的介绍。

Vue.js 2.0之全家桶系列视频课程

基于新的Vue.js 2.3版本, 目前新全的Vue.js教学视频,让你少走弯路,直达技术前沿! 1. 包含Vue.js全家桶(vue.js、vue-router、axios、vuex、vue-cli、webpack、ElementUI等) 2. 采用笔记+代码案例的形式讲解,通俗易懂

navicat(内含激活码)

navicat支持mysql的可视化操作,内涵激活码,不用再忍受弹框的痛苦。

HTML期末大作业

这是我自己做的HTML期末大作业,花了很多时间,稍加修改就可以作为自己的作业了,而且也可以作为学习参考

150讲轻松搞定Python网络爬虫

【为什么学爬虫?】 &nbsp; &nbsp; &nbsp; &nbsp;1、爬虫入手容易,但是深入较难,如何写出高效率的爬虫,如何写出灵活性高可扩展的爬虫都是一项技术活。另外在爬虫过程中,经常容易遇到被反爬虫,比如字体反爬、IP识别、验证码等,如何层层攻克难点拿到想要的数据,这门课程,你都能学到! &nbsp; &nbsp; &nbsp; &nbsp;2、如果是作为一个其他行业的开发者,比如app开发,web开发,学习爬虫能让你加强对技术的认知,能够开发出更加安全的软件和网站 【课程设计】 一个完整的爬虫程序,无论大小,总体来说可以分成三个步骤,分别是: 网络请求:模拟浏览器的行为从网上抓取数据。 数据解析:将请求下来的数据进行过滤,提取我们想要的数据。 数据存储:将提取到的数据存储到硬盘或者内存中。比如用mysql数据库或者redis等。 那么本课程也是按照这几个步骤循序渐进的进行讲解,带领学生完整的掌握每个步骤的技术。另外,因为爬虫的多样性,在爬取的过程中可能会发生被反爬、效率低下等。因此我们又增加了两个章节用来提高爬虫程序的灵活性,分别是: 爬虫进阶:包括IP代理,多线程爬虫,图形验证码识别、JS加密解密、动态网页爬虫、字体反爬识别等。 Scrapy和分布式爬虫:Scrapy框架、Scrapy-redis组件、分布式爬虫等。 通过爬虫进阶的知识点我们能应付大量的反爬网站,而Scrapy框架作为一个专业的爬虫框架,使用他可以快速提高我们编写爬虫程序的效率和速度。另外如果一台机器不能满足你的需求,我们可以用分布式爬虫让多台机器帮助你快速爬取数据。 &nbsp; 从基础爬虫到商业化应用爬虫,本套课程满足您的所有需求! 【课程服务】 专属付费社群+每周三讨论会+1v1答疑

三个项目玩转深度学习(附1G源码)

从事大数据与人工智能开发与实践约十年,钱老师亲自见证了大数据行业的发展与人工智能的从冷到热。事实证明,计算机技术的发展,算力突破,海量数据,机器人技术等,开启了第四次工业革命的序章。深度学习图像分类一直是人工智能的经典任务,是智慧零售、安防、无人驾驶等机器视觉应用领域的核心技术之一,掌握图像分类技术是机器视觉学习的重中之重。针对现有线上学习的特点与实际需求,我们开发了人工智能案例实战系列课程。打造:以项目案例实践为驱动的课程学习方式,覆盖了智能零售,智慧交通等常见领域,通过基础学习、项目案例实践、社群答疑,三维立体的方式,打造最好的学习效果。

基于STM32的电子时钟设计

时钟功能 还有闹钟功能,温湿度功能,整点报时功能 你值得拥有

学生成绩管理系统(PHP + MYSQL)

做的是数据库课程设计,使用的php + MySQL,本来是黄金搭配也就没啥说的,推荐使用wamp服务器,里面有详细的使用说明,带有界面的啊!呵呵 不行的话,可以给我留言!

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

程序员的兼职技能课

获取讲师答疑方式: 在付费视频第一节(触摸命令_ALL)片头有二维码及加群流程介绍 限时福利 原价99元,今日仅需39元!购课添加小助手(微信号:itxy41)按提示还可领取价值800元的编程大礼包! 讲师介绍: 苏奕嘉&nbsp;前阿里UC项目工程师 脚本开发平台官方认证满级(六级)开发者。 我将如何教会你通过【定制脚本】赚到你人生的第一桶金? 零基础程序定制脚本开发课程,是完全针对零脚本开发经验的小白而设计,课程内容共分为3大阶段: ①前期将带你掌握Q开发语言和界面交互开发能力; ②中期通过实战来制作有具体需求的定制脚本; ③后期将解锁脚本的更高阶玩法,打通任督二脉; ④应用定制脚本合法赚取额外收入的完整经验分享,带你通过程序定制脚本开发这项副业,赚取到你的第一桶金!

实用主义学Python(小白也容易上手的Python实用案例)

原价169,限时立减100元! 系统掌握Python核心语法16点,轻松应对工作中80%以上的Python使用场景! 69元=72讲+源码+社群答疑+讲师社群分享会&nbsp; 【哪些人适合学习这门课程?】 1)大学生,平时只学习了Python理论,并未接触Python实战问题; 2)对Python实用技能掌握薄弱的人,自动化、爬虫、数据分析能让你快速提高工作效率; 3)想学习新技术,如:人工智能、机器学习、深度学习等,这门课程是你的必修课程; 4)想修炼更好的编程内功,优秀的工程师肯定不能只会一门语言,Python语言功能强大、使用高效、简单易学。 【超实用技能】 从零开始 自动生成工作周报 职场升级 豆瓣电影数据爬取 实用案例 奥运冠军数据分析 自动化办公:通过Python自动化分析Excel数据并自动操作Word文档,最终获得一份基于Excel表格的数据分析报告。 豆瓣电影爬虫:通过Python自动爬取豆瓣电影信息并将电影图片保存到本地。 奥运会数据分析实战 简介:通过Python分析120年间奥运会的数据,从不同角度入手分析,从而得出一些有趣的结论。 【超人气老师】 二两 中国人工智能协会高级会员 生成对抗神经网络研究者 《深入浅出生成对抗网络:原理剖析与TensorFlow实现》一书作者 阿里云大学云学院导师 前大型游戏公司后端工程师 【超丰富实用案例】 0)图片背景去除案例 1)自动生成工作周报案例 2)豆瓣电影数据爬取案例 3)奥运会数据分析案例 4)自动处理邮件案例 5)github信息爬取/更新提醒案例 6)B站百大UP信息爬取与分析案例 7)构建自己的论文网站案例

Java8零基础入门视频教程

这门课程基于主流的java8平台,由浅入深的详细讲解了java SE的开发技术,可以使java方向的入门学员,快速扎实的掌握java开发技术!

Python数据挖掘简易入门

&nbsp; &nbsp; &nbsp; &nbsp; 本课程为Python数据挖掘方向的入门课程,课程主要以真实数据为基础,详细介绍数据挖掘入门的流程和使用Python实现pandas与numpy在数据挖掘方向的运用,并深入学习如何运用scikit-learn调用常用的数据挖掘算法解决数据挖掘问题,为进一步深入学习数据挖掘打下扎实的基础。

零基础学C#编程—C#从小白到大咖

本课程从初学者角度出发,提供了C#从入门到成为程序开发高手所需要掌握的各方面知识和技术。 【课程特点】 1 由浅入深,编排合理; 2 视频讲解,精彩详尽; 3 丰富实例,轻松易学; 4 每章总结配有难点解析文档。 15大章节,228课时,1756分钟与你一同进步!

MySQL数据库面试题(2020最新版)

文章目录数据库基础知识为什么要使用数据库什么是SQL?什么是MySQL?数据库三大范式是什么mysql有关权限的表都有哪几个MySQL的binlog有有几种录入格式?分别有什么区别?数据类型mysql有哪些数据类型引擎MySQL存储引擎MyISAM与InnoDB区别MyISAM索引与InnoDB索引的区别?InnoDB引擎的4大特性存储引擎选择索引什么是索引?索引有哪些优缺点?索引使用场景(重点)...

多功能数字钟.zip

利用数字电子计数知识设计并制作的数字电子钟(含multisim仿真),该数字钟具有显示星期、24小时制时间、闹铃、整点报时、时间校准功能

极简JAVA学习营第四期(报名以后加助教微信:eduxy-1)

想学好JAVA必须要报两万的培训班吗? Java大神勿入 如果你: 零基础想学JAVA却不知道从何入手 看了一堆书和视频却还是连JAVA的环境都搭建不起来 囊中羞涩面对两万起的JAVA培训班不忍直视 在职没有每天大块的时间专门学习JAVA 那么恭喜你找到组织了,在这里有: 1. 一群志同道合立志学好JAVA的同学一起学习讨论JAVA 2. 灵活机动的学习时间完成特定学习任务+每日编程实战练习 3. 热心助人的助教和讲师及时帮你解决问题,不按时完成作业小心助教老师的家访哦 上一张图看看前辈的感悟: &nbsp; &nbsp; 大家一定迫不及待想知道什么是极简JAVA学习营了吧,下面就来给大家说道说道: 什么是极简JAVA学习营? 1. 针对Java小白或者初级Java学习者; 2. 利用9天时间,每天1个小时时间; 3.通过 每日作业 / 组队PK / 助教答疑 / 实战编程 / 项目答辩 / 社群讨论 / 趣味知识抢答等方式让学员爱上学习编程 , 最终实现能独立开发一个基于控制台的‘库存管理系统’ 的学习模式 极简JAVA学习营是怎么学习的? &nbsp; 如何报名? 只要购买了极简JAVA一:JAVA入门就算报名成功! &nbsp;本期为第四期极简JAVA学习营,我们来看看往期学员的学习状态: 作业看这里~ &nbsp; 助教的作业报告是不是很专业 不交作业打屁屁 助教答疑是不是很用心 &nbsp; 有奖抢答大家玩的很嗨啊 &nbsp; &nbsp; 项目答辩终于开始啦 &nbsp; 优秀者的获奖感言 &nbsp; 这是答辩项目的效果 &nbsp; &nbsp; 这么细致的服务,这么好的氛围,这样的学习效果,需要多少钱呢? 不要1999,不要199,不要99,只要9.9 是的你没听错,只要9.9以上所有就都属于你了 如果你: 1、&nbsp;想学JAVA没有基础 2、&nbsp;想学JAVA没有整块的时间 3、&nbsp;想学JAVA没有足够的预算 还等什么?赶紧报名吧,抓紧抢位,本期只招300人,错过只有等时间待定的下一期了 &nbsp; 报名请加小助手微信:eduxy-1 &nbsp; &nbsp;

Python可以这样学(第一季:Python内功修炼)

董付国系列教材《Python程序设计基础》、《Python程序设计(第2版)》、《Python可以这样学》配套视频,讲解Python 3.5.x和3.6.x语法、内置对象用法、选择与循环以及函数设计与使用、lambda表达式用法、字符串与正则表达式应用、面向对象编程、文本文件与二进制文件操作、目录操作与系统运维、异常处理结构。

Java基础知识面试题(2020最新版)

文章目录Java概述何为编程什么是Javajdk1.5之后的三大版本JVM、JRE和JDK的关系什么是跨平台性?原理是什么Java语言有哪些特点什么是字节码?采用字节码的最大好处是什么什么是Java程序的主类?应用程序和小程序的主类有何不同?Java应用程序与小程序之间有那些差别?Java和C++的区别Oracle JDK 和 OpenJDK 的对比基础语法数据类型Java有哪些数据类型switc...

机器学习实战系列套餐(必备基础+经典算法+案例实战)

机器学习实战系列套餐以实战为出发点,帮助同学们快速掌握机器学习领域必备经典算法原理并结合Python工具包进行实战应用。建议学习顺序:1.Python必备工具包:掌握实战工具 2.机器学习算法与实战应用:数学原理与应用方法都是必备技能 3.数据挖掘实战:通过真实数据集进行项目实战。按照下列课程顺序学习即可! 课程风格通俗易懂,用最接地气的方式带领大家轻松进军机器学习!提供所有课程代码,PPT与实战数据,有任何问题欢迎随时与我讨论。

Java面试题大全(2020版)

发现网上很多Java面试题都没有答案,所以花了很长时间搜集整理出来了这套Java面试题大全,希望对大家有帮助哈~ 本套Java面试题大全,全的不能再全,哈哈~ 一、Java 基础 1. JDK 和 JRE 有什么区别? JDK:Java Development Kit 的简称,java 开发工具包,提供了 java 的开发环境和运行环境。 JRE:Java Runtime Environ...

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

深度学习原理+项目实战+算法详解+主流框架(套餐)

深度学习系列课程从深度学习基础知识点开始讲解一步步进入神经网络的世界再到卷积和递归神经网络,详解各大经典网络架构。实战部分选择当下最火爆深度学习框架PyTorch与Tensorflow/Keras,全程实战演示框架核心使用与建模方法。项目实战部分选择计算机视觉与自然语言处理领域经典项目,从零开始详解算法原理,debug模式逐行代码解读。适合准备就业和转行的同学们加入学习! 建议按照下列课程顺序来进行学习 (1)掌握深度学习必备经典网络架构 (2)深度框架实战方法 (3)计算机视觉与自然语言处理项目实战。(按照课程排列顺序即可)

HoloLens2开发入门教程

本课程为HoloLens2开发入门教程,讲解部署开发环境,安装VS2019,Unity版本,Windows SDK,创建Unity项目,讲解如何使用MRTK,编辑器模拟手势交互,打包VS工程并编译部署应用到HoloLens上等。

几率大的Redis面试题(含答案)

本文的面试题如下: Redis 持久化机制 缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题 热点数据和冷数据是什么 Memcache与Redis的区别都有哪些? 单线程的redis为什么这么快 redis的数据类型,以及每种数据类型的使用场景,Redis 内部结构 redis的过期策略以及内存淘汰机制【~】 Redis 为什么是单线程的,优点 如何解决redis的并发竞争key问题 Red...

MFC一站式终极全套课程包

该套餐共包含从C小白到C++到MFC的全部课程,整套学下来绝对成为一名C++大牛!!!

【数据结构与算法综合实验】欢乐连连看(C++ & MFC)案例

这是武汉理工大学计算机学院数据结构与算法综合实验课程的第三次项目:欢乐连连看(C++ & MFC)迭代开发代码。运行环境:VS2017。已经实现功能:开始游戏、消子、判断胜负、提示、重排、计时、帮助。

YOLOv3目标检测实战:训练自己的数据集

YOLOv3是一种基于深度学习的端到端实时目标检测方法,以速度快见长。本课程将手把手地教大家使用labelImg标注和使用YOLOv3训练自己的数据集。课程分为三个小项目:足球目标检测(单目标检测)、梅西目标检测(单目标检测)、足球和梅西同时目标检测(两目标检测)。 本课程的YOLOv3使用Darknet,在Ubuntu系统上做项目演示。包括:安装Darknet、给自己的数据集打标签、整理自己的数据集、修改配置文件、训练自己的数据集、测试训练出的网络模型、性能统计(mAP计算和画出PR曲线)和先验框聚类。 Darknet是使用C语言实现的轻型开源深度学习框架,依赖少,可移植性好,值得深入探究。 除本课程《YOLOv3目标检测实战:训练自己的数据集》外,本人推出了有关YOLOv3目标检测的系列课程,请持续关注该系列的其它课程视频,包括: 《YOLOv3目标检测实战:交通标志识别》 《YOLOv3目标检测:原理与源码解析》 《YOLOv3目标检测:网络模型改进方法》 敬请关注并选择学习!

u-boot-2015.07.tar.bz2

uboot-2015-07最新代码,喜欢的朋友请拿去

相关热词 c# 解析cad c#数字格式化万 c#int转byte c#格式化日期 c# wpf 表格 c# 实现ad域验证登录 c#心跳包机制 c#使用fmod.dll c#dll vb 调用 c# outlook
立即提问
相关内容推荐