- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在 Swing 中遇到了另一个问题。我编写了一个程序,可以打印出可移动的图像,当您单击其中一个图像时,它将被绘制在其他图像的前面。虽然我有一个问题,当我想要移动图像时,如果我单击并拖动角落中的图像,图像会跳跃,因此它位于鼠标下方的中心。
import javax.swing.*;
import java.awt.event.MouseEvent;
import java.nio.file.Paths;
import java.util.ArrayList;
import java.awt.Graphics;
import java.awt.event.MouseAdapter;
public class Bildvisare extends JFrame{
public Bildvisare(){
JPanel panel = new BildPanel();
add(panel);
setSize(640,460);
setVisible(true);
setDefaultCloseOperation(EXIT_ON_CLOSE);
}
public static void main(String[] arg){
new Bildvisare();
}
}
//Ritar ut bilderna i en JPanel o stoppar in dem i en ArrayLista
class BildPanel extends JPanel{
private ArrayList<Image> Bilder = new ArrayList<Image>();
Image place = null;
private int xKoord = 300; private int yKoord = 200;
//Ritar upp alla bilder i ramen
@Override
public void paintComponent(Graphics g){
super.paintComponent(g);
for (Image p : Bilder){
p.draw(g);
}
}
//Lägger till "muslyssnare"
public BildPanel(){
MouseHandler mh = new MouseHandler(this);
addMouseListener(mh);
addMouseMotionListener(mh);
add();
}
//Lägger till bildens fram och baksida i ArrayListan samt deras koorinater
public void print(String fram, String bak){
Bilder.add(new Image(fram,bak,xKoord,yKoord));
}
//Lägger in bilderna i ArrayListan.
public void add(){
print("0.gif","backside.gif"); print("1.gif","backside.gif");
print("2.gif","backside.gif"); print("3.gif","backside.gif");
print("4.gif","backside.gif"); print("5.gif","backside.gif");
print("6.gif","backside.gif");print("7.gif","backside.gif");
}
//Finner vilken bild som klickas på
public Image find(int a, int b){
for (Image p : Bilder){
if (p.imageCheck(a, b)){
place = p;
}
}
// System.out.println(place);
return place;
}
//Flippar bilden
public void flip(Image img){
toFront(img);
img.flipHelp();
repaint();
}
//Gör att den bild man klickat på hamnar "längst fram".
public void toFront(Image img){
Bilder.remove(img);
Bilder.add(img);
}
//Flyttar bilden som klickats på och ritar om ramen med alla bilder.
public void move(Image img, int x0, int y0){
toFront(img);
img.moveHelp(x0,y0);
repaint();
}
}
class Image{
private ImageIcon front,backside,inView;
private int x0,y0,bredd,höjd;
public Image(String img_front, String img_back,int x1, int y1){
backside = new ImageIcon(img_back);
front = new ImageIcon(img_front);
inView=front;
x0=x1;
y0=y1;
getSize();
}
//Draw the image
public void draw(Graphics g){
g.drawImage(inView.getImage(), x0-bredd/2, y0-höjd/2, null);
}
//Flip the image/icon
public void flipHelp(){
if (inView==front){
inView=backside;
}
else{
inView=front;
}
getSize();
}
//Get the size of each image/icon
public void getSize(){
bredd = inView.getIconWidth();
höjd = inView.getIconHeight();
}
//Move the picture
public void moveHelp(int x1, int y1){
x0=x1;
y0=y1;
}
//Check if point is in a certain image
public boolean imageCheck(int x1,int y1){
return (Math.abs(x1-x0)<(1+bredd)/2&&Math.abs(y1-y0)<(1+höjd)/2);
}
}
class MouseHandler extends MouseAdapter{
BildPanel BildPanel;
Image place = null;
private int xKoord; private int yKoord;
//Konstruktor för att kunna vända på bilden i mouseClicked()
public MouseHandler(BildPanel p){
BildPanel = p;
}
//Det som händer då en bild trycks på.
@Override
public void mousePressed(MouseEvent e){
int xKoord = e.getX(); int yKoord = e.getY();
place = BildPanel.find(xKoord, yKoord);
}
//Det som händer då en bild klickas på.
@Override
public void mouseClicked(MouseEvent e){
int xKoord = e.getX(); int yKoord = e.getY();
Image p = BildPanel.find(xKoord, yKoord);
if (p!=null){
BildPanel.flip(p);
}
}
//Det som händer då man "drar" en bild
@Override
public void mouseDragged(MouseEvent e){
int xKoord = e.getX();
int yKoord = e.getY();
if (place!=null){
BildPanel.move(place, xKoord, yKoord);
}
}
}
最佳答案
在面板周围拖动组件的基本逻辑如下:
public class DragListener extends MouseInputAdapter
{
Point location;
MouseEvent pressed;
public void mousePressed(MouseEvent me)
{
pressed = me;
}
public void mouseDragged(MouseEvent me)
{
Component component = me.getComponent();
location = component.getLocation(location);
int x = location.x - pressed.getX() + me.getX();
int y = location.y - pressed.getY() + me.getY();
component.setLocation(x, y);
}
}
我假设拖动图像的逻辑是相同的。我会让您将此工作代码与当前代码进行比较,看看有什么不同。
关于java - 单击时图像不居中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36632600/
我正在尝试将 Bootstrap 输入字段置于列 div 的中心,但我尝试过的所有方法似乎都不起作用。 到目前为止我尝试了什么: Enter the inf
这是它的样子: http://i.imgur.com/H0Oqz4Q.png 这是 CSS: #header{ background:url('header.png'); border-radius:
似乎有一个 align 属性工作得非常好,但是可以对齐元素,因此面板上的所有元素都将对齐,以在彼此底部居中,如果它们都小于容器尺寸?类似顶部中心中心的东西。 类似这样的事情: 或者至少水平方向和垂直方
我用 GUI 创建了一个简单的猜谜游戏。问题是,每当我最大化窗口时,整个 GUI 都会卡在顶部中间。我想知道如何将其居中以及如何使其变大。代码如下: import javax.swing.*;
目前我在另一个 View 中有一个 View (它是一个广告),但是因为我使用的是 MATCH_PARENT,所以宽度是整个屏幕的长度,而我只希望它是广告尺寸。现在 WRAP_CONTENT 解决了这
我有一个 UIViewController 子类,它实例化了一个 UIView 子类(我们称之为 viewA)。然后,viewA 有时会实例化另一个 UIView,我们称之为 viewB。 我希望 v
我是 Cocca 和 IOS 开发的新手,发现自己处于以下情况。 我有一张 1024x1024 的背景图片,我想在所有 View 中显示它。我已将以下代码放在应用程序委托(delegate)中的应用程
我正在尝试使用 MathML 作为 HTML5 的一部分来制作居中的盒装数学方程式。问题是盒子。如果我在我的 div 元素上放置一个边框,边框足够高,但它一直延伸到屏幕的左侧和右侧。如果我在我的数学元
我知道这听起来很简单,但它不适合我。我做错了什么? .popuphdr { background-color:#00477f; height:30px; width
我正在为我的网店创建一个新网站 - 我遇到了这个 css 问题...... 系统是在prestashop平台上制作的,但是这是基本的CSS,所以没关系。 在 CMS 页面上,我在将页面居中时遇到问题,
我有一个横跨整个屏幕宽度的按钮: accusantium quia sunt 44% 我希望第一个段落标签中的文本居中,其背景图像紧挨着文本。问题是第一个 居中
http://makememodern.com/portfolio/ 您会看到我在页面上嵌入了一个网站,并且它与页面右侧对齐。我希望它居中。 最佳答案 您将 iframe 的宽度设置为 1100
我的 header 中有一个元素正在从 js 文件中获取数据。 我试图将该元素置于我的页面的中心,但我所做的一切似乎都有效。 我尝试了 margin-left: auto 和 margin-right
这个问题在这里已经有了答案: What does auto do in margin: 0 auto? (8 个答案) 关闭 7 年前。
我试图让这两个按钮并排对齐,在页面的中心垂直和水平。 几个小时以来,我一直在摆弄它,尝试了所有方法,但我无法让它既与页面居中对齐又并排对齐 我希望有人能给我指出正确的方向。谢谢..
我需要将一个 img 居中(带有 class=“key”的那个,但是 float 元素阻止了它。我应该使用什么技术将其居中? 谢谢! GitHub 存储库:https://github.com/Cal
每次我嵌入来自 Google map 的 iframe 时,它都会将标记保留在中间。 即使有工具提示并且只是剪切工具提示数据,它也会这样做: http://jsfiddle.net/V2SVa/
我无法将这些按钮置于页面中央。我只知道我错过了一些愚蠢的东西,但我不知道是什么。这是页面: All Time Last 2 Weeks La
我如何将 div 内的表格 div 对齐到 align=center 最佳答案 asd 关于html - div对齐=居中,我们在Stack Overflow上找到一个类似的问题: htt
有人知道如何在调整浏览器窗口大小时也实现垂直居中吗? 水平效果很好,图像大小调整也很好。我希望图片和链接始终在浏览器中间居中。 另外,为什么 ul 没有像图像那样居中而是向右移动了一点? Here i
我是一名优秀的程序员,十分优秀!